aboutsummaryrefslogtreecommitdiff
path: root/node_modules/public-encrypt/test/nodeTests.js
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2017-05-03 15:35:00 +0200
committerFlorian Dold <florian.dold@gmail.com>2017-05-03 15:35:00 +0200
commitde98e0b232509d5f40c135d540a70e415272ff85 (patch)
treea79222a5b58484ab3b80d18efcaaa7ccc4769b33 /node_modules/public-encrypt/test/nodeTests.js
parente0c9d480a73fa629c1e4a47d3e721f1d2d345406 (diff)
node_modules
Diffstat (limited to 'node_modules/public-encrypt/test/nodeTests.js')
-rw-r--r--node_modules/public-encrypt/test/nodeTests.js51
1 files changed, 51 insertions, 0 deletions
diff --git a/node_modules/public-encrypt/test/nodeTests.js b/node_modules/public-encrypt/test/nodeTests.js
new file mode 100644
index 000000000..f168e9348
--- /dev/null
+++ b/node_modules/public-encrypt/test/nodeTests.js
@@ -0,0 +1,51 @@
+var crypto = require('../browser');
+var test = require('tape');
+var fs = require('fs');
+
+// Test RSA encryption/decryption
+test('node tests', function (t) {
+ var certPem = fs.readFileSync(__dirname + '/test_cert.pem', 'ascii');
+ var keyPem = fs.readFileSync(__dirname + '/test_key.pem', 'ascii');
+ var rsaPubPem = fs.readFileSync(__dirname + '/test_rsa_pubkey.pem',
+ 'ascii');
+ var rsaKeyPem = fs.readFileSync(__dirname + '/test_rsa_privkey.pem',
+ 'ascii');
+ var rsaKeyPemEncrypted = fs.readFileSync(
+ __dirname + '/test_rsa_privkey_encrypted.pem', 'ascii');
+ var input = 'I AM THE WALRUS';
+ var bufferToEncrypt = new Buffer(input);
+
+ var encryptedBuffer = crypto.publicEncrypt(rsaPubPem, bufferToEncrypt);
+
+ var decryptedBuffer = crypto.privateDecrypt(rsaKeyPem, encryptedBuffer);
+ t.equal(input, decryptedBuffer.toString());
+
+ var decryptedBufferWithPassword = crypto.privateDecrypt({
+ key: rsaKeyPemEncrypted,
+ passphrase: 'password'
+ }, encryptedBuffer);
+ t.equal(input, decryptedBufferWithPassword.toString());
+
+ // encryptedBuffer = crypto.publicEncrypt(certPem, bufferToEncrypt);
+
+ // decryptedBuffer = crypto.privateDecrypt(keyPem, encryptedBuffer);
+ // t.equal(input, decryptedBuffer.toString());
+
+ encryptedBuffer = crypto.publicEncrypt(keyPem, bufferToEncrypt);
+
+ decryptedBuffer = crypto.privateDecrypt(keyPem, encryptedBuffer);
+ t.equal(input, decryptedBuffer.toString());
+
+ encryptedBuffer = crypto.privateEncrypt(keyPem, bufferToEncrypt);
+
+ decryptedBuffer = crypto.publicDecrypt(keyPem, encryptedBuffer);
+ t.equal(input, decryptedBuffer.toString());
+
+ t.throws(function() {
+ crypto.privateDecrypt({
+ key: rsaKeyPemEncrypted,
+ passphrase: 'wrong'
+ }, encryptedBuffer);
+ });
+ t.end();
+}); \ No newline at end of file