2015-07-22 19:48:08 +00:00
|
|
|
'use strict';
|
|
|
|
|
2016-04-27 22:54:31 +00:00
|
|
|
describe('Protocol Wrapper', function() {
|
2016-04-22 20:39:05 +00:00
|
|
|
var store = textsecure.storage.protocol;
|
2015-07-22 19:48:08 +00:00
|
|
|
var identifier = '+5558675309';
|
|
|
|
var another_identifier = '+5555590210';
|
2016-04-27 22:21:44 +00:00
|
|
|
var prekeys, identityKey, testKey;
|
|
|
|
this.timeout(5000);
|
|
|
|
before(function(done) {
|
|
|
|
localStorage.clear();
|
2016-04-28 22:07:34 +00:00
|
|
|
libsignal.KeyHelper.generateIdentityKeyPair().then(function(identityKey) {
|
2016-05-03 21:54:57 +00:00
|
|
|
return textsecure.storage.protocol.saveIdentity(identifier, identityKey);
|
2017-05-27 00:39:20 +00:00
|
|
|
}).then(function() {
|
|
|
|
done();
|
|
|
|
});
|
2016-04-27 22:21:44 +00:00
|
|
|
});
|
2016-04-27 22:54:31 +00:00
|
|
|
describe('processPreKey', function() {
|
2015-07-22 19:48:08 +00:00
|
|
|
it('rejects if the identity key changes', function(done) {
|
2016-05-01 21:46:16 +00:00
|
|
|
var address = new libsignal.SignalProtocolAddress(identifier, 1);
|
|
|
|
var builder = new libsignal.SessionBuilder(store, address);
|
|
|
|
return builder.processPreKey({
|
2016-04-27 22:21:44 +00:00
|
|
|
identityKey: textsecure.crypto.getRandomBytes(33),
|
2016-05-01 21:46:16 +00:00
|
|
|
encodedNumber: address.toString()
|
2015-07-22 19:48:08 +00:00
|
|
|
}).then(function() {
|
2016-04-27 22:21:44 +00:00
|
|
|
done(new Error('Allowed to overwrite identity key'));
|
|
|
|
}).catch(function(e) {
|
|
|
|
assert.strictEqual(e.message, 'Identity key changed');
|
|
|
|
done();
|
2015-07-22 19:48:08 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|