-
Notifications
You must be signed in to change notification settings - Fork 7
/
index.spec.js
116 lines (80 loc) · 3.52 KB
/
index.spec.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
'use strict';
var expect = require('chai').expect;
var util = require('util');
/**
* Test /register/emailLink
*/
describe('urlCrypt', function() {
it('should not take a weak password', function(done) {
var urlCryptFunc = require('./index');
// Throws error because wrong key
expect(urlCryptFunc.bind('weak-key')).to.throw(Error);
done();
});
it('should work on a string', function(done) {
var data = 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa';
var urlCrypt = require('./index')('~{ry*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var urlCrypt2 = require('./index')('differenty*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var encrypted = urlCrypt.cryptObj(data);
// Same
expect(urlCrypt.decryptObj(encrypted)).to.eql(data);
// Throws error because wrong key
expect(urlCrypt2.decryptObj.bind(urlCrypt2.decryptObj, encrypted)).to.throw(Error);
done();
});
it('should work on a number', function(done) {
var data = 42;
var urlCrypt = require('./index')('~{ry*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var urlCrypt2 = require('./index')('differenty*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var encrypted = urlCrypt.cryptObj(data);
// Same
expect(urlCrypt.decryptObj(encrypted)).to.eql(data);
// Throws error because wrong key
expect(urlCrypt2.decryptObj.bind(urlCrypt2.decryptObj, encrypted)).to.throw(Error);
done();
});
it('should work on a simple object', function(done) {
var data = { hello: 'world', this: 'is a test', of: 'url-crypt' };
var urlCrypt = require('./index')('~{ry*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var urlCrypt2 = require('./index')('differenty*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var encrypted = urlCrypt.cryptObj(data);
// Same
expect(urlCrypt.decryptObj(encrypted)).to.eql(data);
// Throws error because wrong key
expect(urlCrypt2.decryptObj.bind(urlCrypt2.decryptObj, encrypted)).to.throw(Error);
done();
});
it('should work on a complex object', function(done) {
var data = util.inspect(process);
var urlCrypt = require('./index')('~{ry*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var urlCrypt2 = require('./index')('differenty*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var encrypted = urlCrypt.cryptObj(data);
// Same
expect(urlCrypt.decryptObj(encrypted)).to.eql(data);
// Throws error because wrong key
expect(urlCrypt2.decryptObj.bind(urlCrypt2.decryptObj, encrypted)).to.throw(Error);
done();
});
it('fail same key, different salt bytes', function(done) {
var data = util.inspect(process);
var urlCrypt = require('./index')('~{ry*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF', 2);
var urlCrypt2 = require('./index')('~{ry*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF', 3);
var encrypted = urlCrypt.cryptObj(data);
// Same
expect(urlCrypt.decryptObj(encrypted)).to.eql(data);
// Throws error because wrong key
expect(urlCrypt2.decryptObj.bind(urlCrypt2.decryptObj, encrypted)).to.throw(Error);
done();
});
it('should work with different encoders', function(done) {
var data = 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa';
var urlCrypt = require('./index')('~{ry*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var urlCrypt2 = require('./index')('~{ry*I)==yU/]9<7DPk!Hj"R#:-/Z7(hTBnlRS=4CXF');
var encrypted = urlCrypt.cryptObj(data);
// Same
expect(urlCrypt.decryptObj(encrypted)).to.eql(data);
// Same
expect(urlCrypt2.decryptObj(encrypted)).to.eql(data);
done();
});
});