You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
74 lines
2.2 KiB
74 lines
2.2 KiB
11 years ago
|
var should = require('chai').should();
|
||
11 years ago
|
var AESCBC = require('../lib/expmt/aescbc');
|
||
11 years ago
|
|
||
11 years ago
|
describe('AESCBC', function() {
|
||
11 years ago
|
|
||
|
describe('@encrypt', function() {
|
||
|
|
||
|
it('should return encrypt one block', function() {
|
||
|
var password = "password";
|
||
|
var messagebuf = new Buffer(128 / 8 - 1);
|
||
|
messagebuf.fill(0);
|
||
11 years ago
|
var encbuf = AESCBC.encrypt(messagebuf, password);
|
||
11 years ago
|
encbuf.length.should.equal(128 / 8 + 128 / 8);
|
||
|
});
|
||
|
|
||
|
});
|
||
|
|
||
|
describe('@decrypt', function() {
|
||
|
|
||
|
it('should decrypt that which was encrypted', function() {
|
||
|
var password = "password";
|
||
|
var messagebuf = new Buffer(128 / 8 - 1);
|
||
|
messagebuf.fill(0);
|
||
11 years ago
|
var encbuf = AESCBC.encrypt(messagebuf, password);
|
||
|
var messagebuf2 = AESCBC.decrypt(encbuf, password);
|
||
11 years ago
|
messagebuf2.toString('hex').should.equal(messagebuf.toString('hex'));
|
||
|
});
|
||
|
|
||
|
});
|
||
|
|
||
|
describe('@encryptCipherkey', function() {
|
||
|
|
||
|
it('should return encrypt one block', function() {
|
||
|
var cipherkeybuf = new Buffer(256 / 8);
|
||
|
cipherkeybuf.fill(0x10);
|
||
|
var ivbuf = new Buffer(128 / 8);
|
||
|
ivbuf.fill(0);
|
||
|
var messagebuf = new Buffer(128 / 8 - 1);
|
||
|
messagebuf.fill(0);
|
||
11 years ago
|
var encbuf = AESCBC.encryptCipherkey(messagebuf, cipherkeybuf, ivbuf);
|
||
11 years ago
|
encbuf.length.should.equal(128 / 8 + 128 / 8);
|
||
|
});
|
||
|
|
||
|
it('should return encrypt two blocks', function() {
|
||
|
var cipherkeybuf = new Buffer(256 / 8);
|
||
|
cipherkeybuf.fill(0x10);
|
||
|
var ivbuf = new Buffer(128 / 8);
|
||
|
ivbuf.fill(0);
|
||
|
var messagebuf = new Buffer(128 / 8);
|
||
|
messagebuf.fill(0);
|
||
11 years ago
|
var encbuf = AESCBC.encryptCipherkey(messagebuf, cipherkeybuf, ivbuf);
|
||
11 years ago
|
encbuf.length.should.equal(128 / 8 + 128 / 8 + 128 / 8);
|
||
|
});
|
||
|
|
||
|
});
|
||
|
|
||
|
describe('@decryptCipherkey', function() {
|
||
|
|
||
|
it('should decrypt that which was encrypted', function() {
|
||
|
var cipherkeybuf = new Buffer(256 / 8);
|
||
|
cipherkeybuf.fill(0x10);
|
||
|
var ivbuf = new Buffer(128 / 8);
|
||
|
ivbuf.fill(0);
|
||
|
var messagebuf = new Buffer(128 / 8);
|
||
|
messagebuf.fill(0);
|
||
11 years ago
|
var encbuf = AESCBC.encryptCipherkey(messagebuf, cipherkeybuf, ivbuf);
|
||
|
var messagebuf2 = AESCBC.decryptCipherkey(encbuf, cipherkeybuf);
|
||
11 years ago
|
messagebuf2.toString('hex').should.equal(messagebuf.toString('hex'));
|
||
|
});
|
||
|
|
||
|
});
|
||
|
|
||
|
});
|