2013-08-19 15:13:32 -04:00
define ( function ( require ) {
'use strict' ;
2013-12-03 13:21:50 -05:00
var EmailDAO = require ( 'js/dao/email-dao' ) ,
KeychainDAO = require ( 'js/dao/keychain-dao' ) ,
2013-09-19 12:35:12 -04:00
ImapClient = require ( 'imap-client' ) ,
2013-12-03 13:21:50 -05:00
SmtpClient = require ( 'smtp-client' ) ,
2013-10-11 21:19:01 -04:00
PGP = require ( 'js/crypto/pgp' ) ,
2013-12-03 13:21:50 -05:00
DeviceStorageDAO = require ( 'js/dao/devicestorage-dao' ) ,
2013-08-19 15:13:32 -04:00
expect = chai . expect ;
2013-12-04 06:06:27 -05:00
describe ( 'Email DAO unit tests' , function ( ) {
2013-12-03 13:21:50 -05:00
var dao , keychainStub , imapClientStub , smtpClientStub , pgpStub , devicestorageStub ;
2013-08-28 08:12:39 -04:00
2013-12-03 13:21:50 -05:00
var emailAddress , passphrase , asymKeySize , mockkeyId , dummyEncryptedMail ,
2014-01-18 05:42:28 -05:00
dummyDecryptedMail , dummyLegacyDecryptedMail , mockKeyPair , account , publicKey , verificationMail , verificationUuid ,
2014-01-08 10:04:18 -05:00
corruptedVerificationMail , corruptedVerificationUuid ,
2013-12-03 14:24:12 -05:00
nonWhitelistedMail ;
2013-08-19 15:13:32 -04:00
2013-12-09 13:21:52 -05:00
beforeEach ( function ( done ) {
2013-12-03 13:21:50 -05:00
emailAddress = 'asdf@asdf.com' ;
passphrase = 'asdf' ;
asymKeySize = 2048 ;
mockkeyId = 1234 ;
dummyEncryptedMail = {
uid : 1234 ,
2013-08-28 08:12:39 -04:00
from : [ {
2013-12-03 13:21:50 -05:00
address : 'asd@asd.de'
} ] ,
2013-08-28 08:12:39 -04:00
to : [ {
2013-12-03 13:21:50 -05:00
address : 'qwe@qwe.de'
} ] ,
subject : '[whiteout] qweasd' ,
2013-12-05 12:28:18 -05:00
body : '-----BEGIN PGP MESSAGE-----\nasd\n-----END PGP MESSAGE-----' ,
unread : false ,
answered : false
2013-12-03 13:21:50 -05:00
} ;
2014-01-08 10:04:18 -05:00
verificationUuid = '9A858952-17EE-4273-9E74-D309EAFDFAFB' ;
2013-12-03 13:21:50 -05:00
verificationMail = {
2013-11-08 03:29:04 -05:00
from : [ {
name : 'Whiteout Test' ,
address : 'whiteout.test@t-online.de'
} ] , // sender address
to : [ {
address : 'safewithme.testuser@gmail.com'
} ] , // list of receivers
subject : "[whiteout] New public key uploaded" , // Subject line
2013-12-03 13:21:50 -05:00
body : 'yadda yadda bla blabla foo bar https://keys.whiteout.io/verify/' + verificationUuid , // plaintext body
2013-12-05 12:28:18 -05:00
unread : true ,
answered : false
2013-12-03 13:21:50 -05:00
} ;
2014-01-08 10:04:18 -05:00
corruptedVerificationUuid = 'OMFG_FUCKING_BASTARD_UUID_FROM_HELL!' ;
corruptedVerificationMail = {
from : [ {
name : 'Whiteout Test' ,
address : 'whiteout.test@t-online.de'
} ] , // sender address
to : [ {
address : 'safewithme.testuser@gmail.com'
} ] , // list of receivers
subject : "[whiteout] New public key uploaded" , // Subject line
body : 'yadda yadda bla blabla foo bar https://keys.whiteout.io/verify/' + corruptedVerificationUuid , // plaintext body
unread : true ,
answered : false
} ;
2013-12-03 13:21:50 -05:00
dummyDecryptedMail = {
2014-01-18 05:42:28 -05:00
uid : 1234 ,
from : [ {
address : 'asd@asd.de'
} ] ,
to : [ {
address : 'qwe@qwe.de'
} ] ,
subject : 'qweasd' ,
body : 'Content-Type: multipart/signed;\r\n boundary="Apple-Mail=_1D8756C0-F347-4D7A-A8DB-7869CBF14FD2";\r\n protocol="application/pgp-signature";\r\n micalg=pgp-sha512\r\n\r\n\r\n--Apple-Mail=_1D8756C0-F347-4D7A-A8DB-7869CBF14FD2\r\nContent-Type: multipart/mixed;\r\n boundary="Apple-Mail=_8ED7DC84-6AD9-4A08-8327-80B62D6BCBFA"\r\n\r\n\r\n--Apple-Mail=_8ED7DC84-6AD9-4A08-8327-80B62D6BCBFA\r\nContent-Transfer-Encoding: 7bit\r\nContent-Type: text/plain;\r\n charset=us-ascii\r\n\r\nasdasd \r\n--Apple-Mail=_8ED7DC84-6AD9-4A08-8327-80B62D6BCBFA\r\nContent-Disposition: attachment;\r\n filename=dummy.txt\r\nContent-Type: text/plain;\r\n name="dummy.txt"\r\nContent-Transfer-Encoding: 7bit\r\n\r\noaudbcoaurbvosuabvlasdjbfalwubjvawvb\r\n--Apple-Mail=_8ED7DC84-6AD9-4A08-8327-80B62D6BCBFA--\r\n\r\n--Apple-Mail=_1D8756C0-F347-4D7A-A8DB-7869CBF14FD2\r\nContent-Transfer-Encoding: 7bit\r\nContent-Disposition: attachment;\r\n filename=signature.asc\r\nContent-Type: application/pgp-signature;\r\n name=signature.asc\r\nContent-Description: Message signed with OpenPGP using GPGMail\r\n\r\n-----BEGIN PGP SIGNATURE-----\r\nComment: GPGTools - https://gpgtools.org\r\n\r\niQEcBAEBCgAGBQJS2kO1AAoJEDzmUwH7XO/cP+YH/2PSBxX1ZZd83Uf9qBGDY807\r\niHOdgPFXm64YjSnohO7XsPcnmihqP1ipS2aaCXFC3/Vgb9nc4isQFS+i1VdPwfuR\r\n1Pd2l3dC4/nD4xO9h/W6JW7Yd24NS5TJD5cA7LYwQ8LF+rOzByMatiTMmecAUCe8\r\nEEalEjuogojk4IacA8dg/bfLqQu9E+0GYUJBcI97dx/0jZ0qMOxbWOQLsJ3DnUnV\r\nOad7pAIbHEO6T0EBsH7TyTj4RRHkP6SKE0mm6ZYUC7KCk2Z3MtkASTxUrnqW5qZ5\r\noaXUO9GEc8KZcmbCdhZY2Y5h+dmucaO0jpbeSKkvtYyD4KZrSvt7NTb/0dSLh4Y=\r\n=G8km\r\n-----END PGP SIGNATURE-----\r\n\r\n--Apple-Mail=_1D8756C0-F347-4D7A-A8DB-7869CBF14FD2--\r\n' ,
unread : false ,
answered : false ,
receiverKeys : [ '-----BEGIN PGP PUBLIC KEY-----\nasd\n-----END PGP PUBLIC KEY-----' ]
} ;
dummyLegacyDecryptedMail = {
2013-12-03 13:21:50 -05:00
uid : 1234 ,
2013-11-08 03:29:04 -05:00
from : [ {
2013-12-03 13:21:50 -05:00
address : 'asd@asd.de'
} ] ,
2013-11-08 03:29:04 -05:00
to : [ {
2013-12-03 13:21:50 -05:00
address : 'qwe@qwe.de'
} ] ,
2013-12-04 11:35:44 -05:00
subject : 'qweasd' ,
2013-12-05 12:28:18 -05:00
body : 'asd' ,
unread : false ,
2014-01-14 07:26:23 -05:00
answered : false ,
receiverKeys : [ '-----BEGIN PGP PUBLIC KEY-----\nasd\n-----END PGP PUBLIC KEY-----' ]
2013-12-03 13:21:50 -05:00
} ;
2013-12-03 14:24:12 -05:00
nonWhitelistedMail = {
uid : 1234 ,
from : [ {
address : 'asd@asd.de'
} ] ,
to : [ {
address : 'qwe@qwe.de'
} ] ,
subject : 'qweasd' ,
body : 'asd'
} ;
2013-12-03 13:21:50 -05:00
mockKeyPair = {
publicKey : {
_id : mockkeyId ,
userId : emailAddress ,
publicKey : 'publicpublicpublicpublic'
} ,
privateKey : {
_id : mockkeyId ,
userId : emailAddress ,
encryptedKey : 'privateprivateprivateprivate'
}
2013-08-28 08:12:39 -04:00
} ;
2013-08-20 07:30:35 -04:00
account = {
2013-12-03 13:21:50 -05:00
emailAddress : emailAddress ,
asymKeySize : asymKeySize ,
busy : false
2013-08-20 07:30:35 -04:00
} ;
2013-12-03 13:21:50 -05:00
publicKey = "-----BEGIN PUBLIC KEY-----\r\n" + "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCxy+Te5dyeWd7g0P+8LNO7fZDQ\r\n" + "g96xTb1J6pYE/pPTMlqhB6BRItIYjZ1US5q2vk5Zk/5KasBHAc9RbCqvh9v4XFEY\r\n" + "JVmTXC4p8ft1LYuNWIaDk+R3dyYXmRNct/JC4tks2+8fD3aOvpt0WNn3R75/FGBt\r\n" + "h4BgojAXDE+PRQtcVQIDAQAB\r\n" + "-----END PUBLIC KEY-----" ;
2013-08-19 15:13:32 -04:00
keychainStub = sinon . createStubInstance ( KeychainDAO ) ;
imapClientStub = sinon . createStubInstance ( ImapClient ) ;
smtpClientStub = sinon . createStubInstance ( SmtpClient ) ;
2013-10-11 21:19:01 -04:00
pgpStub = sinon . createStubInstance ( PGP ) ;
2013-09-26 07:26:57 -04:00
devicestorageStub = sinon . createStubInstance ( DeviceStorageDAO ) ;
2013-08-19 15:13:32 -04:00
2013-12-09 13:21:52 -05:00
dao = new EmailDAO ( keychainStub , pgpStub , devicestorageStub ) ;
2013-12-03 13:21:50 -05:00
dao . _account = account ;
expect ( dao . _keychain ) . to . equal ( keychainStub ) ;
expect ( dao . _crypto ) . to . equal ( pgpStub ) ;
expect ( dao . _devicestorage ) . to . equal ( devicestorageStub ) ;
2013-12-09 13:21:52 -05:00
// connect
expect ( dao . _imapClient ) . to . not . exist ;
expect ( dao . _smtpClient ) . to . not . exist ;
expect ( dao . _account . online ) . to . be . undefined ;
dao . _account . folders = [ ] ;
imapClientStub . login . yields ( ) ;
dao . onConnect ( {
imapClient : imapClientStub ,
smtpClient : smtpClientStub
} , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . online ) . to . be . true ;
expect ( dao . _imapClient ) . to . equal ( dao . _imapClient ) ;
expect ( dao . _smtpClient ) . to . equal ( dao . _smtpClient ) ;
done ( ) ;
} ) ;
2013-08-19 15:13:32 -04:00
} ) ;
2013-12-09 13:21:52 -05:00
afterEach ( function ( done ) {
dao . onDisconnect ( null , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . online ) . to . be . false ;
expect ( dao . _imapClient ) . to . not . exist ;
expect ( dao . _smtpClient ) . to . not . exist ;
done ( ) ;
} ) ;
} ) ;
2013-08-19 15:13:32 -04:00
2013-12-04 06:06:27 -05:00
describe ( 'push' , function ( ) {
it ( 'should work' , function ( done ) {
var o = { } ;
dao . onIncomingMessage = function ( obj ) {
expect ( obj ) . to . equal ( o ) ;
done ( ) ;
} ;
2013-12-05 12:28:18 -05:00
2013-12-04 06:06:27 -05:00
dao . _imapClient . onIncomingMessage ( o ) ;
} ) ;
} ) ;
2013-08-19 15:13:32 -04:00
describe ( 'init' , function ( ) {
2013-10-21 07:10:42 -04:00
beforeEach ( function ( ) {
2013-12-03 13:21:50 -05:00
delete dao . _account ;
2013-10-21 07:10:42 -04:00
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should init' , function ( done ) {
2013-12-09 13:21:52 -05:00
var listFolderStub , folders ;
2013-12-03 13:21:50 -05:00
2013-12-06 11:47:38 -05:00
folders = [ { } , { } ] ;
2013-12-03 13:21:50 -05:00
// initKeychain
devicestorageStub . init . withArgs ( emailAddress ) . yields ( ) ;
keychainStub . getUserKeyPair . yields ( null , mockKeyPair ) ;
// initFolders
listFolderStub = sinon . stub ( dao , '_imapListFolders' ) ;
listFolderStub . yields ( null , folders ) ;
dao . init ( {
account : account
} , function ( err , keyPair ) {
expect ( err ) . to . not . exist ;
2013-12-09 13:21:52 -05:00
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . online ) . to . be . false ;
2013-12-03 13:21:50 -05:00
expect ( keyPair ) . to . equal ( mockKeyPair ) ;
expect ( dao . _account ) . to . equal ( account ) ;
expect ( dao . _account . folders ) . to . equal ( folders ) ;
expect ( devicestorageStub . init . calledOnce ) . to . be . true ;
expect ( keychainStub . getUserKeyPair . calledOnce ) . to . be . true ;
expect ( listFolderStub . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
2013-12-10 17:05:17 -05:00
it ( 'should not fail when offline' , function ( done ) {
var listFolderStub ;
// initKeychain
devicestorageStub . init . withArgs ( emailAddress ) . yields ( ) ;
keychainStub . getUserKeyPair . yields ( null , mockKeyPair ) ;
// initFolders
listFolderStub = sinon . stub ( dao , '_imapListFolders' ) ;
2014-01-08 10:04:18 -05:00
listFolderStub . yields ( {
code : 42
} ) ;
2013-12-10 17:05:17 -05:00
dao . init ( {
account : account
} , function ( err , keyPair ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . online ) . to . be . false ;
expect ( keyPair ) . to . equal ( mockKeyPair ) ;
expect ( dao . _account ) . to . equal ( account ) ;
expect ( dao . _account . folders ) . to . equal ( undefined ) ;
expect ( devicestorageStub . init . calledOnce ) . to . be . true ;
expect ( keychainStub . getUserKeyPair . calledOnce ) . to . be . true ;
expect ( listFolderStub . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should fail due to error while listing folders' , function ( done ) {
2013-12-09 13:21:52 -05:00
var listFolderStub ;
2013-08-19 15:13:32 -04:00
2013-12-03 13:21:50 -05:00
// initKeychain
devicestorageStub . init . withArgs ( emailAddress ) . yields ( ) ;
keychainStub . getUserKeyPair . yields ( null , mockKeyPair ) ;
// initFolders
listFolderStub = sinon . stub ( dao , '_imapListFolders' ) ;
listFolderStub . yields ( { } ) ;
dao . init ( {
account : account
} , function ( err , keyPair ) {
expect ( err ) . to . exist ;
expect ( keyPair ) . to . not . exist ;
expect ( dao . _account ) . to . equal ( account ) ;
2013-09-26 07:26:57 -04:00
expect ( devicestorageStub . init . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( keychainStub . getUserKeyPair . calledOnce ) . to . be . true ;
expect ( listFolderStub . calledOnce ) . to . be . true ;
2013-08-19 15:13:32 -04:00
done ( ) ;
} ) ;
} ) ;
2013-12-09 13:21:52 -05:00
it ( 'should fail due to error in getUserKeyPair' , function ( done ) {
devicestorageStub . init . yields ( ) ;
keychainStub . getUserKeyPair . yields ( { } ) ;
2013-12-03 13:21:50 -05:00
dao . init ( {
account : account
} , function ( err , keyPair ) {
expect ( err ) . to . exist ;
expect ( keyPair ) . to . not . exist ;
2013-10-21 07:10:42 -04:00
expect ( devicestorageStub . init . calledOnce ) . to . be . true ;
2013-12-09 13:21:52 -05:00
done ( ) ;
} ) ;
} ) ;
} ) ;
describe ( 'onConnect' , function ( ) {
var imapLoginStub , imapListFoldersStub ;
beforeEach ( function ( done ) {
// imap login
imapLoginStub = sinon . stub ( dao , '_imapLogin' ) ;
imapListFoldersStub = sinon . stub ( dao , '_imapListFolders' ) ;
2013-12-03 13:21:50 -05:00
2013-12-09 13:21:52 -05:00
dao . onDisconnect ( null , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( dao . _imapClient ) . to . not . exist ;
expect ( dao . _smtpClient ) . to . not . exist ;
expect ( dao . _account . online ) . to . be . false ;
2013-12-03 13:21:50 -05:00
done ( ) ;
} ) ;
} ) ;
2013-12-09 13:21:52 -05:00
afterEach ( function ( ) {
imapLoginStub . restore ( ) ;
imapListFoldersStub . restore ( ) ;
} ) ;
2013-12-03 13:21:50 -05:00
2013-12-09 13:21:52 -05:00
it ( 'should fail due to error in imap login' , function ( done ) {
imapLoginStub . yields ( { } ) ;
dao . onConnect ( {
imapClient : imapClientStub ,
smtpClient : smtpClientStub
} , function ( err ) {
2013-12-03 13:21:50 -05:00
expect ( err ) . to . exist ;
2013-12-09 13:21:52 -05:00
expect ( imapLoginStub . calledOnce ) . to . be . true ;
expect ( dao . _account . online ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
2013-12-09 13:21:52 -05:00
it ( 'should work when folder already initiated' , function ( done ) {
dao . _account . folders = [ ] ;
imapLoginStub . yields ( ) ;
2013-12-03 13:21:50 -05:00
2013-12-09 13:21:52 -05:00
dao . onConnect ( {
imapClient : imapClientStub ,
smtpClient : smtpClientStub
} , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . online ) . to . be . true ;
expect ( dao . _imapClient ) . to . equal ( dao . _imapClient ) ;
expect ( dao . _smtpClient ) . to . equal ( dao . _smtpClient ) ;
done ( ) ;
} ) ;
} ) ;
it ( 'should work when folder not yet initiated' , function ( done ) {
var folders = [ ] ;
imapLoginStub . yields ( ) ;
imapListFoldersStub . yields ( null , folders ) ;
dao . onConnect ( {
imapClient : imapClientStub ,
smtpClient : smtpClientStub
} , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . online ) . to . be . true ;
expect ( dao . _imapClient ) . to . equal ( dao . _imapClient ) ;
expect ( dao . _smtpClient ) . to . equal ( dao . _smtpClient ) ;
expect ( dao . _account . folders ) . to . deep . equal ( folders ) ;
2013-10-21 07:10:42 -04:00
done ( ) ;
} ) ;
} ) ;
} ) ;
describe ( 'unlock' , function ( ) {
2013-12-03 13:21:50 -05:00
it ( 'should unlock' , function ( done ) {
var importMatcher = sinon . match ( function ( o ) {
expect ( o . passphrase ) . to . equal ( passphrase ) ;
expect ( o . privateKeyArmored ) . to . equal ( mockKeyPair . privateKey . encryptedKey ) ;
expect ( o . publicKeyArmored ) . to . equal ( mockKeyPair . publicKey . publicKey ) ;
return true ;
} ) ;
2013-08-19 15:13:32 -04:00
2013-12-03 13:21:50 -05:00
pgpStub . importKeys . withArgs ( importMatcher ) . yields ( ) ;
dao . unlock ( {
passphrase : passphrase ,
keypair : mockKeyPair
} , function ( err ) {
2013-10-21 07:10:42 -04:00
expect ( err ) . to . not . exist ;
2013-10-13 13:04:49 -04:00
expect ( pgpStub . importKeys . calledOnce ) . to . be . true ;
2013-10-21 07:10:42 -04:00
2013-08-19 15:13:32 -04:00
done ( ) ;
} ) ;
} ) ;
2013-10-11 21:19:01 -04:00
2013-12-03 13:21:50 -05:00
it ( 'should generate a keypair and unlock' , function ( done ) {
var genKeysMatcher , persistKeysMatcher , importMatcher , keypair ;
keypair = {
keyId : 123 ,
publicKeyArmored : mockKeyPair . publicKey . publicKey ,
privateKeyArmored : mockKeyPair . privateKey . encryptedKey
} ;
genKeysMatcher = sinon . match ( function ( o ) {
expect ( o . emailAddress ) . to . equal ( emailAddress ) ;
expect ( o . keySize ) . to . equal ( asymKeySize ) ;
expect ( o . passphrase ) . to . equal ( passphrase ) ;
return true ;
} ) ;
importMatcher = sinon . match ( function ( o ) {
expect ( o . passphrase ) . to . equal ( passphrase ) ;
expect ( o . privateKeyArmored ) . to . equal ( mockKeyPair . privateKey . encryptedKey ) ;
expect ( o . publicKeyArmored ) . to . equal ( mockKeyPair . publicKey . publicKey ) ;
return true ;
} ) ;
persistKeysMatcher = sinon . match ( function ( o ) {
expect ( o ) . to . deep . equal ( mockKeyPair ) ;
return true ;
} ) ;
2013-10-21 07:10:42 -04:00
2013-12-03 13:21:50 -05:00
pgpStub . generateKeys . withArgs ( genKeysMatcher ) . yields ( null , keypair ) ;
pgpStub . importKeys . withArgs ( importMatcher ) . yields ( ) ;
keychainStub . putUserKeyPair . withArgs ( ) . yields ( ) ;
dao . unlock ( {
passphrase : passphrase
} , function ( err ) {
2013-10-21 07:10:42 -04:00
expect ( err ) . to . not . exist ;
2013-12-03 13:21:50 -05:00
expect ( pgpStub . generateKeys . calledOnce ) . to . be . true ;
2013-10-21 07:10:42 -04:00
expect ( pgpStub . importKeys . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( keychainStub . putUserKeyPair . calledOnce ) . to . be . true ;
2013-10-21 07:10:42 -04:00
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should fail when persisting fails' , function ( done ) {
var keypair = {
keyId : 123 ,
publicKeyArmored : 'qwerty' ,
privateKeyArmored : 'asdfgh'
} ;
pgpStub . generateKeys . yields ( null , keypair ) ;
pgpStub . importKeys . withArgs ( ) . yields ( ) ;
keychainStub . putUserKeyPair . yields ( { } ) ;
dao . unlock ( {
passphrase : passphrase
} , function ( err ) {
2013-10-21 07:10:42 -04:00
expect ( err ) . to . exist ;
expect ( pgpStub . generateKeys . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( pgpStub . importKeys . calledOnce ) . to . be . true ;
expect ( keychainStub . putUserKeyPair . calledOnce ) . to . be . true ;
2013-10-21 07:10:42 -04:00
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should fail when import fails' , function ( done ) {
var keypair = {
keyId : 123 ,
publicKeyArmored : 'qwerty' ,
privateKeyArmored : 'asdfgh'
} ;
pgpStub . generateKeys . withArgs ( ) . yields ( null , keypair ) ;
pgpStub . importKeys . withArgs ( ) . yields ( { } ) ;
2013-10-21 07:10:42 -04:00
2013-12-03 13:21:50 -05:00
dao . unlock ( {
passphrase : passphrase
} , function ( err ) {
2013-10-21 07:10:42 -04:00
expect ( err ) . to . exist ;
expect ( pgpStub . generateKeys . calledOnce ) . to . be . true ;
expect ( pgpStub . importKeys . calledOnce ) . to . be . true ;
done ( ) ;
2013-10-11 21:19:01 -04:00
} ) ;
2013-10-21 07:10:42 -04:00
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should fail when generation fails' , function ( done ) {
pgpStub . generateKeys . yields ( { } ) ;
2013-10-11 21:19:01 -04:00
2013-12-03 13:21:50 -05:00
dao . unlock ( {
passphrase : passphrase
} , function ( err ) {
2013-10-21 07:10:42 -04:00
expect ( err ) . to . exist ;
expect ( pgpStub . generateKeys . calledOnce ) . to . be . true ;
2013-10-11 21:19:01 -04:00
done ( ) ;
} ) ;
} ) ;
2013-08-19 15:13:32 -04:00
} ) ;
2014-01-18 05:42:28 -05:00
describe ( '_imapParseMessageBlock' , function ( ) {
it ( 'should parse a message' , function ( done ) {
imapClientStub . parseDecryptedMessageBlock . yields ( null , { } ) ;
dao . _imapParseMessageBlock ( function ( err , msg ) {
expect ( err ) . to . not . exist ;
expect ( msg ) . to . exist ;
done ( ) ;
} ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
describe ( '_imapLogin' , function ( ) {
2013-12-09 13:21:52 -05:00
it ( 'should fail when disconnected' , function ( done ) {
dao . onDisconnect ( null , function ( err ) {
expect ( err ) . to . not . exist ;
dao . _imapLogin ( function ( err ) {
expect ( err . code ) . to . equal ( 42 ) ;
done ( ) ;
} ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should work' , function ( done ) {
imapClientStub . login . yields ( ) ;
dao . _imapLogin ( function ( err ) {
expect ( err ) . to . not . exist ;
done ( ) ;
} ) ;
} ) ;
2013-09-26 11:37:56 -04:00
it ( 'should fail due to error in imap login' , function ( done ) {
2013-12-03 13:21:50 -05:00
imapClientStub . login . yields ( { } ) ;
2013-09-26 11:37:56 -04:00
2013-12-03 13:21:50 -05:00
dao . _imapLogin ( function ( err ) {
expect ( err ) . to . exist ;
2013-09-26 11:37:56 -04:00
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
} ) ;
2013-09-26 11:37:56 -04:00
2013-12-03 13:21:50 -05:00
describe ( '_imapLogout' , function ( ) {
2013-12-09 13:21:52 -05:00
it ( 'should fail when disconnected' , function ( done ) {
dao . onDisconnect ( null , function ( err ) {
expect ( err ) . to . not . exist ;
dao . _imapLogout ( function ( err ) {
expect ( err . code ) . to . equal ( 42 ) ;
done ( ) ;
} ) ;
} ) ;
} ) ;
2013-09-26 11:37:56 -04:00
it ( 'should work' , function ( done ) {
2013-12-03 13:21:50 -05:00
imapClientStub . logout . yields ( ) ;
2013-09-26 11:37:56 -04:00
2013-12-03 13:21:50 -05:00
dao . _imapLogout ( function ( err ) {
2013-09-26 11:37:56 -04:00
expect ( err ) . to . not . exist ;
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should fail due to error in imap login' , function ( done ) {
imapClientStub . logout . yields ( { } ) ;
dao . _imapLogout ( function ( err ) {
expect ( err ) . to . exist ;
done ( ) ;
2013-08-20 07:30:35 -04:00
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
} ) ;
2013-08-20 07:30:35 -04:00
2013-12-03 13:21:50 -05:00
describe ( '_imapListFolders' , function ( ) {
var dummyFolders = [ {
type : 'Inbox' ,
path : 'INBOX'
} , {
type : 'Outbox' ,
path : 'OUTBOX'
} ] ;
it ( 'should list from storage' , function ( done ) {
devicestorageStub . listItems . withArgs ( 'folders' ) . yields ( null , [ dummyFolders ] ) ;
dao . _imapListFolders ( function ( err , folders ) {
2013-08-20 07:30:35 -04:00
expect ( err ) . to . not . exist ;
2013-12-03 13:21:50 -05:00
expect ( devicestorageStub . listItems . calledOnce ) . to . be . true ;
expect ( folders [ 0 ] . type ) . to . equal ( 'Inbox' ) ;
2013-08-20 07:30:35 -04:00
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should not list from storage due to error' , function ( done ) {
devicestorageStub . listItems . yields ( { } ) ;
2013-10-10 13:15:16 -04:00
2013-12-03 13:21:50 -05:00
dao . _imapListFolders ( function ( err , folders ) {
expect ( err ) . to . exist ;
expect ( folders ) . to . not . exist ;
expect ( devicestorageStub . listItems . calledOnce ) . to . be . true ;
expect ( imapClientStub . listWellKnownFolders . called ) . to . be . false ;
done ( ) ;
2013-10-10 13:15:16 -04:00
} ) ;
2013-12-03 13:21:50 -05:00
} ) ;
2013-10-10 13:15:16 -04:00
2013-12-09 13:21:52 -05:00
it ( 'should fail when disconnected' , function ( done ) {
devicestorageStub . listItems . yields ( null , [ ] ) ;
dao . onDisconnect ( null , function ( err ) {
expect ( err ) . to . not . exist ;
dao . _imapListFolders ( function ( err ) {
expect ( err . code ) . to . equal ( 42 ) ;
done ( ) ;
} ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should list from imap' , function ( done ) {
devicestorageStub . listItems . yields ( null , [ ] ) ;
imapClientStub . listWellKnownFolders . yields ( null , {
inbox : dummyFolders [ 0 ]
} ) ;
devicestorageStub . storeList . yields ( ) ;
2013-10-10 13:15:16 -04:00
2013-12-03 13:21:50 -05:00
dao . _imapListFolders ( function ( err , folders ) {
expect ( err ) . to . not . exist ;
expect ( devicestorageStub . listItems . calledOnce ) . to . be . true ;
expect ( imapClientStub . listWellKnownFolders . calledOnce ) . to . be . true ;
expect ( devicestorageStub . storeList . calledOnce ) . to . be . true ;
expect ( folders [ 0 ] . type ) . to . equal ( 'Inbox' ) ;
done ( ) ;
2013-09-20 12:44:14 -04:00
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should not list from imap due to store error' , function ( done ) {
devicestorageStub . listItems . yields ( null , [ ] ) ;
imapClientStub . listWellKnownFolders . yields ( null , {
inbox : dummyFolders [ 0 ]
2013-08-20 07:30:35 -04:00
} ) ;
2013-12-03 13:21:50 -05:00
devicestorageStub . storeList . yields ( { } ) ;
2013-08-20 13:48:49 -04:00
2013-12-03 13:21:50 -05:00
dao . _imapListFolders ( function ( err , folders ) {
expect ( err ) . to . exist ;
expect ( folders ) . to . not . exist ;
expect ( devicestorageStub . listItems . calledOnce ) . to . be . true ;
expect ( imapClientStub . listWellKnownFolders . calledOnce ) . to . be . true ;
expect ( devicestorageStub . storeList . calledOnce ) . to . be . true ;
done ( ) ;
2013-08-20 13:48:49 -04:00
} ) ;
} ) ;
2013-08-21 07:43:19 -04:00
2013-12-03 13:21:50 -05:00
it ( 'should not list from imap due to imap error' , function ( done ) {
devicestorageStub . listItems . yields ( null , [ ] ) ;
imapClientStub . listWellKnownFolders . yields ( { } ) ;
2013-08-21 10:07:59 -04:00
2013-12-03 13:21:50 -05:00
dao . _imapListFolders ( function ( err , folders ) {
expect ( err ) . to . exist ;
expect ( folders ) . to . not . exist ;
expect ( devicestorageStub . listItems . calledOnce ) . to . be . true ;
expect ( imapClientStub . listWellKnownFolders . calledOnce ) . to . be . true ;
expect ( devicestorageStub . storeList . called ) . to . be . false ;
done ( ) ;
2013-11-08 03:29:04 -05:00
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
} ) ;
2013-11-08 03:29:04 -05:00
2013-12-12 07:14:49 -05:00
describe ( '_imapSearch' , function ( ) {
2013-12-09 13:21:52 -05:00
it ( 'should fail when disconnected' , function ( done ) {
dao . onDisconnect ( null , function ( err ) {
expect ( err ) . to . not . exist ;
2013-12-12 08:27:20 -05:00
dao . _imapSearch ( { } , function ( err ) {
2013-12-09 13:21:52 -05:00
expect ( err . code ) . to . equal ( 42 ) ;
done ( ) ;
} ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should work' , function ( done ) {
var path = 'FOLDAAAA' ;
2013-11-08 03:29:04 -05:00
2013-12-12 07:14:49 -05:00
imapClientStub . search . withArgs ( {
2013-12-03 13:21:50 -05:00
path : path ,
2013-12-12 07:14:49 -05:00
subject : '[whiteout] '
2013-12-03 13:21:50 -05:00
} ) . yields ( ) ;
2013-12-12 07:14:49 -05:00
dao . _imapSearch ( {
2013-12-03 13:21:50 -05:00
folder : path
} , done ) ;
2013-09-26 07:26:57 -04:00
} ) ;
2013-12-12 07:14:49 -05:00
it ( 'should work' , function ( done ) {
var path = 'FOLDAAAA' ;
imapClientStub . search . withArgs ( {
path : path ,
subject : '[whiteout] ' ,
answered : true
} ) . yields ( ) ;
dao . _imapSearch ( {
folder : path ,
answered : true
} , done ) ;
} ) ;
it ( 'should work' , function ( done ) {
var path = 'FOLDAAAA' ;
imapClientStub . search . withArgs ( {
path : path ,
subject : '[whiteout] ' ,
unread : true
} ) . yields ( ) ;
dao . _imapSearch ( {
folder : path ,
unread : true
} , done ) ;
} ) ;
2013-10-04 11:02:27 -04:00
} ) ;
2013-12-03 13:21:50 -05:00
describe ( '_imapDeleteMessage' , function ( ) {
2013-12-09 13:21:52 -05:00
it ( 'should fail when disconnected' , function ( done ) {
dao . onDisconnect ( null , function ( err ) {
expect ( err ) . to . not . exist ;
dao . _imapDeleteMessage ( { } , function ( err ) {
expect ( err . code ) . to . equal ( 42 ) ;
done ( ) ;
} ) ;
} ) ;
} ) ;
2013-10-04 11:02:27 -04:00
it ( 'should work' , function ( done ) {
2013-12-03 13:21:50 -05:00
var path = 'FOLDAAAA' ,
uid = 1337 ;
imapClientStub . deleteMessage . withArgs ( {
path : path ,
uid : uid
} ) . yields ( ) ;
dao . _imapDeleteMessage ( {
folder : path ,
uid : uid
} , done ) ;
} ) ;
} ) ;
2013-09-26 07:26:57 -04:00
2013-12-03 13:21:50 -05:00
describe ( '_imapGetMessage' , function ( ) {
2013-12-09 13:21:52 -05:00
it ( 'should fail when disconnected' , function ( done ) {
dao . onDisconnect ( null , function ( err ) {
expect ( err ) . to . not . exist ;
dao . _imapGetMessage ( { } , function ( err ) {
expect ( err . code ) . to . equal ( 42 ) ;
done ( ) ;
} ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should work' , function ( done ) {
var path = 'FOLDAAAA' ,
uid = 1337 ;
2014-01-14 10:32:36 -05:00
imapClientStub . getMessage . withArgs ( {
2013-12-03 13:21:50 -05:00
path : path ,
uid : uid
2014-01-14 10:32:36 -05:00
} ) . yields ( null , { } ) ;
2013-12-03 13:21:50 -05:00
dao . _imapGetMessage ( {
folder : path ,
uid : uid
2013-12-12 07:14:49 -05:00
} , function ( err , msg ) {
expect ( err ) . to . not . exist ;
expect ( msg ) . to . exist ;
2014-01-14 10:32:36 -05:00
expect ( imapClientStub . getMessage . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
done ( ) ;
} ) ;
} ) ;
2014-01-14 10:32:36 -05:00
it ( 'should not work when getMessage fails' , function ( done ) {
2013-12-12 07:14:49 -05:00
var path = 'FOLDAAAA' ,
uid = 1337 ;
2014-01-14 10:32:36 -05:00
imapClientStub . getMessage . yields ( { } ) ;
2013-12-12 07:14:49 -05:00
dao . _imapGetMessage ( {
folder : path ,
uid : uid
} , function ( err , msg ) {
expect ( err ) . to . exist ;
expect ( msg ) . to . not . exist ;
2014-01-14 10:32:36 -05:00
expect ( imapClientStub . getMessage . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
done ( ) ;
} ) ;
2013-12-03 13:21:50 -05:00
} ) ;
} ) ;
describe ( '_localListMessages' , function ( ) {
2013-12-06 09:03:42 -05:00
it ( 'should work without uid' , function ( done ) {
2013-12-03 13:21:50 -05:00
var folder = 'FOLDAAAA' ;
devicestorageStub . listItems . withArgs ( 'email_' + folder , 0 , null ) . yields ( ) ;
dao . _localListMessages ( {
folder : folder
} , done ) ;
} ) ;
2013-12-06 09:03:42 -05:00
it ( 'should work with uid' , function ( done ) {
var folder = 'FOLDAAAA' ,
uid = 123 ;
devicestorageStub . listItems . withArgs ( 'email_' + folder + '_' + uid , 0 , null ) . yields ( ) ;
dao . _localListMessages ( {
folder : folder ,
uid : uid
} , done ) ;
} ) ;
2013-12-03 13:21:50 -05:00
} ) ;
describe ( '_localStoreMessages' , function ( ) {
it ( 'should work' , function ( done ) {
var folder = 'FOLDAAAA' ,
emails = [ { } ] ;
devicestorageStub . storeList . withArgs ( emails , 'email_' + folder ) . yields ( ) ;
dao . _localStoreMessages ( {
folder : folder ,
emails : emails
} , done ) ;
} ) ;
} ) ;
describe ( '_localDeleteMessage' , function ( ) {
it ( 'should work' , function ( done ) {
var folder = 'FOLDAAAA' ,
uid = 1337 ;
devicestorageStub . removeList . withArgs ( 'email_' + folder + '_' + uid ) . yields ( ) ;
dao . _localDeleteMessage ( {
folder : folder ,
uid : uid
} , done ) ;
} ) ;
it ( 'should fail when uid is missing' , function ( done ) {
var folder = 'FOLDAAAA' ;
dao . _localDeleteMessage ( {
folder : folder
2013-10-04 11:02:27 -04:00
} , function ( err ) {
2013-12-03 13:21:50 -05:00
expect ( err ) . to . exist ;
2013-10-04 11:02:27 -04:00
done ( ) ;
} ) ;
} ) ;
2013-08-20 07:30:35 -04:00
} ) ;
2013-10-04 11:02:27 -04:00
2013-12-03 13:21:50 -05:00
describe ( 'sync' , function ( ) {
it ( 'should work initially' , function ( done ) {
2014-01-18 05:42:28 -05:00
var folder , localListStub , invocations , imapSearchStub , imapParseStub ;
2013-11-13 11:05:21 -05:00
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder
} ] ;
2013-12-06 11:47:38 -05:00
dummyDecryptedMail . unread = true ;
dummyEncryptedMail . unread = true ;
2013-12-03 13:21:50 -05:00
localListStub = sinon . stub ( dao , '_localListMessages' ) . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail ] ) ;
keychainStub . getReceiverPublicKey . withArgs ( dummyEncryptedMail . from [ 0 ] . address ) . yields ( null , mockKeyPair ) ;
pgpStub . decrypt . withArgs ( dummyEncryptedMail . body , mockKeyPair . publicKey ) . yields ( null , dummyDecryptedMail . body ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
2013-12-03 13:21:50 -05:00
folder : folder
2013-12-12 07:14:49 -05:00
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
2014-01-18 05:42:28 -05:00
imapParseStub = sinon . stub ( dao , '_imapParseMessageBlock' ) ;
imapParseStub . withArgs ( {
message : dummyEncryptedMail ,
block : dummyDecryptedMail . body
} ) . yields ( null , dummyDecryptedMail ) ;
2013-12-03 13:21:50 -05:00
dao . sync ( {
folder : folder
2013-11-13 11:05:21 -05:00
} , function ( err ) {
expect ( err ) . to . not . exist ;
2013-12-03 13:21:50 -05:00
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( keychainStub . getReceiverPublicKey . calledOnce ) . to . be . true ;
expect ( pgpStub . decrypt . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-06 11:47:38 -05:00
expect ( dao . _account . folders [ 0 ] . count ) . to . equal ( 1 ) ;
2014-01-18 05:42:28 -05:00
expect ( imapParseStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
2013-11-13 11:05:21 -05:00
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should initially error on decryption' , function ( done ) {
var folder , localListStub , invocations ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ dummyEncryptedMail ] ) ;
keychainStub . getReceiverPublicKey . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( keychainStub . getReceiverPublicKey . calledOnce ) . to . be . true ;
done ( ) ;
2013-11-21 11:37:07 -05:00
} ) ;
2013-12-03 13:21:50 -05:00
} ) ;
2013-11-21 11:37:07 -05:00
2013-12-03 13:21:50 -05:00
it ( 'should initially sync downstream when storage is empty' , function ( done ) {
2014-01-18 05:42:28 -05:00
var folder , localListStub , localStoreStub , invocations , imapSearchStub , imapGetStub , imapParseStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder
} ] ;
2014-01-18 05:42:28 -05:00
dummyDecryptedMail . unread = true ;
dummyDecryptedMail . answered = true ;
2013-12-06 11:47:38 -05:00
2013-12-03 13:21:50 -05:00
localListStub = sinon . stub ( dao , '_localListMessages' ) . withArgs ( {
folder : folder
} ) . yields ( null , [ ] ) ;
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . withArgs ( {
folder : folder ,
uid : dummyEncryptedMail . uid
} ) . yields ( null , dummyEncryptedMail ) ;
2013-12-12 07:14:49 -05:00
keychainStub . getReceiverPublicKey . withArgs ( dummyEncryptedMail . from [ 0 ] . address ) . yields ( null , mockKeyPair ) ;
pgpStub . decrypt . withArgs ( dummyEncryptedMail . body , mockKeyPair . publicKey ) . yields ( null , dummyDecryptedMail . body ) ;
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
2014-01-18 05:42:28 -05:00
imapParseStub = sinon . stub ( dao , '_imapParseMessageBlock' ) ;
imapParseStub . yields ( null , dummyDecryptedMail ) ;
2013-12-03 13:21:50 -05:00
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
2013-11-21 11:37:07 -05:00
expect ( err ) . to . not . exist ;
2013-12-03 13:21:50 -05:00
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
expect ( keychainStub . getReceiverPublicKey . calledOnce ) . to . be . true ;
expect ( pgpStub . decrypt . calledOnce ) . to . be . true ;
2013-12-06 11:47:38 -05:00
expect ( dao . _account . folders [ 0 ] . count ) . to . equal ( 1 ) ;
2014-01-18 05:42:28 -05:00
expect ( imapParseStub . calledOnce ) . to . be . true ;
2013-11-21 11:37:07 -05:00
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should not work when busy' , function ( done ) {
dao . _account . busy = true ;
dao . sync ( {
folder : 'OOGA'
} , function ( err ) {
expect ( err ) . to . exist ;
done ( ) ;
} ) ;
} ) ;
it ( 'should fetch messages downstream from the remote' , function ( done ) {
dao . sync ( { } , function ( err ) {
expect ( err ) . to . exist ;
done ( ) ;
} ) ;
} ) ;
it ( 'should not work when initial setup errors' , function ( done ) {
var folder , localListStub ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( localListStub . calledOnce ) . to . be . true ;
done ( ) ;
2013-11-21 11:37:07 -05:00
} ) ;
2013-12-03 13:21:50 -05:00
} ) ;
it ( 'should be up to date' , function ( done ) {
2013-12-12 07:14:49 -05:00
var folder , localListStub , imapSearchStub , invocations ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
2013-11-21 11:37:07 -05:00
2013-12-03 13:21:50 -05:00
localListStub = sinon . stub ( dao , '_localListMessages' ) . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
2013-12-03 13:21:50 -05:00
folder : folder
2013-12-12 07:14:49 -05:00
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
dao . sync ( {
folder : folder
} , function ( err ) {
2013-11-21 11:37:07 -05:00
expect ( err ) . to . not . exist ;
2013-12-03 13:21:50 -05:00
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-11-21 11:37:07 -05:00
done ( ) ;
} ) ;
} ) ;
2013-08-19 15:13:32 -04:00
2013-12-12 07:14:49 -05:00
it ( 'should error while searching on imap' , function ( done ) {
var folder , localListStub , imapSearchStub , invocations ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ dummyEncryptedMail ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( { } ) ;
2013-12-03 13:21:50 -05:00
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
done ( ) ;
} ) ;
} ) ;
it ( 'should error while listing local messages' , function ( done ) {
var folder , localListStub ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( localListStub . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
it ( 'should remove messages from the remote' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , localDeleteStub , imapDeleteStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ dummyEncryptedMail ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) . yields ( ) ;
localDeleteStub = sinon . stub ( dao , '_localDeleteMessage' ) . yields ( ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( localDeleteStub . calledOnce ) . to . be . true ;
expect ( imapDeleteStub . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
2014-01-18 05:42:28 -05:00
it ( 'should error while removing messages from local' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , localDeleteStub , imapDeleteStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ dummyEncryptedMail ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
2013-12-03 13:21:50 -05:00
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) . yields ( ) ;
localDeleteStub = sinon . stub ( dao , '_localDeleteMessage' ) . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( localDeleteStub . calledOnce ) . to . be . true ;
expect ( imapDeleteStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . called ) . to . be . false ;
2013-12-03 13:21:50 -05:00
done ( ) ;
} ) ;
} ) ;
it ( 'should error while removing messages from the remote' , function ( done ) {
2013-12-12 07:14:49 -05:00
var folder , localListStub , imapSearchStub , localDeleteStub , imapDeleteStub ;
2013-12-03 13:21:50 -05:00
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ dummyEncryptedMail ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
2013-12-03 13:21:50 -05:00
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) . yields ( { } ) ;
localDeleteStub = sinon . stub ( dao , '_localDeleteMessage' ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( imapDeleteStub . calledOnce ) . to . be . true ;
expect ( localDeleteStub . called ) . to . be . false ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . called ) . to . be . false ;
2013-12-03 13:21:50 -05:00
done ( ) ;
} ) ;
} ) ;
it ( 'should delete messages locally if not present on remote' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , localDeleteStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
2013-12-03 13:21:50 -05:00
folder : folder
} ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
localDeleteStub = sinon . stub ( dao , '_localDeleteMessage' ) . withArgs ( {
folder : folder ,
uid : dummyEncryptedMail . uid
} ) . yields ( ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( localDeleteStub . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
it ( 'should error while deleting locally if not present on remote' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , localDeleteStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ dummyEncryptedMail ] ) ;
localDeleteStub = sinon . stub ( dao , '_localDeleteMessage' ) . yields ( { } ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) . withArgs ( {
folder : folder
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
2013-12-06 10:37:55 -05:00
expect ( dao . _account . folders [ 0 ] . messages ) . to . not . be . empty ;
2013-12-03 13:21:50 -05:00
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( localDeleteStub . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
2014-01-18 05:42:28 -05:00
it ( 'should fetch legacy messages downstream from the remote' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , imapGetStub , localStoreStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . withArgs ( {
folder : folder
} ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
2013-12-03 13:21:50 -05:00
folder : folder
2013-12-12 07:14:49 -05:00
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . withArgs ( {
folder : folder ,
uid : dummyEncryptedMail . uid
} ) . yields ( null , dummyEncryptedMail ) ;
2013-12-12 07:14:49 -05:00
2014-01-18 05:42:28 -05:00
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( ) ;
keychainStub . getReceiverPublicKey . withArgs ( dummyEncryptedMail . from [ 0 ] . address ) . yields ( null , mockKeyPair ) ;
pgpStub . decrypt . withArgs ( dummyEncryptedMail . body , mockKeyPair . publicKey ) . yields ( null , dummyLegacyDecryptedMail . body ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( imapSearchStub . calledThrice ) . to . be . true ;
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
expect ( keychainStub . getReceiverPublicKey . calledOnce ) . to . be . true ;
expect ( pgpStub . decrypt . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
it ( 'should fetch valid pgp messages downstream from the remote' , function ( done ) {
var invocations , folder , localListStub , imapSearchStub , imapGetStub , localStoreStub , imapParseStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . withArgs ( {
folder : folder
} ) . yields ( null , [ ] ) ;
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . withArgs ( {
folder : folder ,
uid : dummyEncryptedMail . uid
} ) . yields ( null , dummyEncryptedMail ) ;
2013-12-03 13:21:50 -05:00
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( ) ;
keychainStub . getReceiverPublicKey . withArgs ( dummyEncryptedMail . from [ 0 ] . address ) . yields ( null , mockKeyPair ) ;
pgpStub . decrypt . withArgs ( dummyEncryptedMail . body , mockKeyPair . publicKey ) . yields ( null , dummyDecryptedMail . body ) ;
2014-01-18 05:42:28 -05:00
imapParseStub = sinon . stub ( dao , '_imapParseMessageBlock' ) ;
imapParseStub . withArgs ( {
message : dummyEncryptedMail ,
block : dummyDecryptedMail . body
} ) . yields ( null , dummyDecryptedMail ) ;
2013-12-03 13:21:50 -05:00
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
expect ( keychainStub . getReceiverPublicKey . calledOnce ) . to . be . true ;
expect ( pgpStub . decrypt . calledOnce ) . to . be . true ;
2014-01-18 05:42:28 -05:00
expect ( imapParseStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
done ( ) ;
} ) ;
} ) ;
2013-12-03 14:24:12 -05:00
it ( 'should not fetch non-whitelisted mails' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , imapGetStub , localStoreStub ;
2013-12-03 14:24:12 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ nonWhitelistedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 14:24:12 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , nonWhitelistedMail ) ;
2013-12-12 07:14:49 -05:00
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) ;
2013-12-03 14:24:12 -05:00
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
expect ( imapGetStub . calledOnce ) . to . be . true ;
2013-12-03 14:24:12 -05:00
expect ( localStoreStub . called ) . to . be . false ;
expect ( keychainStub . getReceiverPublicKey . called ) . to . be . false ;
expect ( pgpStub . decrypt . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
2013-12-03 13:21:50 -05:00
it ( 'should error while decrypting fetch messages from the remote' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , imapGetStub , localStoreStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , dummyEncryptedMail ) ;
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( ) ;
keychainStub . getReceiverPublicKey . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
expect ( keychainStub . getReceiverPublicKey . calledOnce ) . to . be . true ;
expect ( pgpStub . decrypt . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
it ( 'should error while storing messages from the remote locally' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , imapGetStub , localStoreStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , dummyEncryptedMail ) ;
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
expect ( keychainStub . getReceiverPublicKey . called ) . to . be . false ;
expect ( pgpStub . decrypt . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
it ( 'should error while fetching messages from the remote' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , imapGetStub , localStoreStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( { } ) ;
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . called ) . to . be . false ;
expect ( keychainStub . getReceiverPublicKey . called ) . to . be . false ;
expect ( pgpStub . decrypt . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
it ( 'should verify an authentication mail' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub , imapGetStub , markReadStub , imapDeleteStub ;
2013-12-03 13:21:50 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ verificationMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , verificationMail ) ;
keychainStub . verifyPublicKey . withArgs ( verificationUuid ) . yields ( ) ;
2013-12-05 13:10:30 -05:00
markReadStub = sinon . stub ( dao , '_imapMark' ) . withArgs ( {
2013-12-03 13:21:50 -05:00
folder : folder ,
2013-12-05 12:28:18 -05:00
uid : verificationMail . uid ,
unread : false
2013-12-03 13:21:50 -05:00
} ) . yields ( ) ;
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) . withArgs ( {
folder : folder ,
uid : verificationMail . uid
} ) . yields ( ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( keychainStub . verifyPublicKey . calledOnce ) . to . be . true ;
expect ( markReadStub . calledOnce ) . to . be . true ;
expect ( imapDeleteStub . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
it ( 'should fail during deletion of an authentication mail' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub ,
2013-12-03 13:21:50 -05:00
imapGetStub , markReadStub , imapDeleteStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ verificationMail . uid ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , verificationMail ) ;
keychainStub . verifyPublicKey . yields ( ) ;
2013-12-05 13:10:30 -05:00
markReadStub = sinon . stub ( dao , '_imapMark' ) . yields ( ) ;
2013-12-03 13:21:50 -05:00
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( keychainStub . verifyPublicKey . calledOnce ) . to . be . true ;
expect ( markReadStub . calledOnce ) . to . be . true ;
expect ( imapDeleteStub . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
2013-12-12 07:14:49 -05:00
2013-12-03 13:21:50 -05:00
it ( 'should fail during marking an authentication mail read' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub ,
2013-12-03 13:21:50 -05:00
imapGetStub , markReadStub , imapDeleteStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ verificationMail . uid ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , verificationMail ) ;
keychainStub . verifyPublicKey . yields ( ) ;
2013-12-05 13:10:30 -05:00
markReadStub = sinon . stub ( dao , '_imapMark' ) . yields ( { } ) ;
2013-12-03 13:21:50 -05:00
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( keychainStub . verifyPublicKey . calledOnce ) . to . be . true ;
expect ( markReadStub . calledOnce ) . to . be . true ;
expect ( imapDeleteStub . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
2013-12-12 07:14:49 -05:00
2013-12-03 13:21:50 -05:00
it ( 'should fail during verifying authentication' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub ,
2013-12-03 13:21:50 -05:00
imapGetStub , markReadStub , imapDeleteStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ verificationMail . uid ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , verificationMail ) ;
keychainStub . verifyPublicKey . yields ( { } ) ;
2013-12-05 13:10:30 -05:00
markReadStub = sinon . stub ( dao , '_imapMark' ) ;
2013-12-03 13:21:50 -05:00
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( keychainStub . verifyPublicKey . calledOnce ) . to . be . true ;
expect ( markReadStub . called ) . to . be . false ;
expect ( imapDeleteStub . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
2013-12-12 07:14:49 -05:00
2013-12-03 13:21:50 -05:00
it ( 'should not bother about read authentication mails' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub ,
2013-12-03 13:21:50 -05:00
imapGetStub , markReadStub , imapDeleteStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
verificationMail . unread = false ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ verificationMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , verificationMail ) ;
2013-12-05 13:10:30 -05:00
markReadStub = sinon . stub ( dao , '_imapMark' ) ;
2013-12-03 13:21:50 -05:00
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) ;
2014-01-08 10:04:18 -05:00
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( imapSearchStub . calledThrice ) . to . be . true ;
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( keychainStub . verifyPublicKey . called ) . to . be . false ;
expect ( markReadStub . called ) . to . be . false ;
expect ( imapDeleteStub . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
it ( 'should not bother about corrupted authentication mails' , function ( done ) {
var invocations , folder , localListStub , imapSearchStub , imapGetStub , markReadStub , imapDeleteStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ corruptedVerificationMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , corruptedVerificationMail ) ;
markReadStub = sinon . stub ( dao , '_imapMark' ) ;
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) ;
2013-12-03 13:21:50 -05:00
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( keychainStub . verifyPublicKey . called ) . to . be . false ;
expect ( markReadStub . called ) . to . be . false ;
expect ( imapDeleteStub . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
2013-12-12 07:14:49 -05:00
2014-01-08 10:04:18 -05:00
it ( 'should not bother about corrupted authentication mails no verification link' , function ( done ) {
2013-12-12 07:14:49 -05:00
var invocations , folder , localListStub , imapSearchStub ,
2013-12-03 13:21:50 -05:00
imapGetStub , markReadStub , imapDeleteStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ ]
} ] ;
verificationMail . body = 'url? there is no url.' ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ verificationMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-03 13:21:50 -05:00
imapGetStub = sinon . stub ( dao , '_imapGetMessage' ) . yields ( null , verificationMail ) ;
2013-12-05 13:10:30 -05:00
markReadStub = sinon . stub ( dao , '_imapMark' ) ;
2013-12-03 13:21:50 -05:00
imapDeleteStub = sinon . stub ( dao , '_imapDeleteMessage' ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] . messages ) . to . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-03 13:21:50 -05:00
expect ( imapGetStub . calledOnce ) . to . be . true ;
expect ( keychainStub . verifyPublicKey . called ) . to . be . false ;
expect ( markReadStub . called ) . to . be . false ;
expect ( imapDeleteStub . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
2013-12-05 12:28:18 -05:00
it ( 'should sync tags from memory to imap and storage' , function ( done ) {
2013-12-12 07:14:49 -05:00
var folder , localListStub , imapSearchStub , invocations ,
2013-12-05 12:28:18 -05:00
markStub , localStoreStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
var inStorage = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
var inImap = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
dummyDecryptedMail . unread = inImap . unread = true ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ inStorage ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ inImap . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ inImap . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-05 13:10:30 -05:00
markStub = sinon . stub ( dao , '_imapMark' ) . withArgs ( {
2013-12-05 12:28:18 -05:00
folder : folder ,
uid : dummyDecryptedMail . uid ,
unread : dummyDecryptedMail . unread ,
answered : dummyDecryptedMail . answered
} ) . yields ( ) ;
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . withArgs ( {
folder : folder ,
2013-12-06 09:03:42 -05:00
emails : [ inStorage ]
2013-12-03 13:21:50 -05:00
} ) . yields ( ) ;
2013-12-05 12:28:18 -05:00
dao . sync ( {
folder : folder
2013-12-03 13:21:50 -05:00
} , function ( err ) {
expect ( err ) . to . not . exist ;
2013-12-05 12:28:18 -05:00
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-05 12:28:18 -05:00
expect ( markStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
2013-12-06 09:03:42 -05:00
expect ( inStorage . unread ) . to . equal ( dummyDecryptedMail . unread ) ;
expect ( inStorage . answered ) . to . equal ( dummyDecryptedMail . answered ) ;
2013-12-05 12:28:18 -05:00
done ( ) ;
} ) ;
} ) ;
2013-12-12 07:14:49 -05:00
it ( 'should error while syncing unread tags from memory to storage' , function ( done ) {
var folder , localListStub , imapSearchStub , invocations , markStub , localStoreStub ;
2013-12-05 12:28:18 -05:00
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
var inStorage = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
var inImap = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
dummyDecryptedMail . unread = inImap . unread = true ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ inStorage ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
2013-12-05 13:10:30 -05:00
markStub = sinon . stub ( dao , '_imapMark' ) . yields ( ) ;
2013-12-05 12:28:18 -05:00
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( markStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
it ( 'should error while syncing answered tags from memory to storage' , function ( done ) {
var folder , localListStub , imapSearchStub , invocations , markStub , localStoreStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
var inStorage = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
var inImap = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
dummyDecryptedMail . unread = inImap . unread = true ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ inStorage ] ) ;
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
markStub = sinon . stub ( dao , '_imapMark' ) . yields ( ) ;
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( markStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
expect ( imapSearchStub . called ) . to . be . false ;
2013-12-05 12:28:18 -05:00
done ( ) ;
} ) ;
} ) ;
it ( 'should error while syncing tags from memory to imap' , function ( done ) {
2013-12-12 07:14:49 -05:00
var folder , localListStub , imapSearchStub , invocations ,
2013-12-05 12:28:18 -05:00
markStub , localStoreStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
var inStorage = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
var inImap = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
dummyDecryptedMail . unread = inImap . unread = true ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ inStorage ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
2013-12-05 13:10:30 -05:00
markStub = sinon . stub ( dao , '_imapMark' ) . yields ( { } ) ;
2013-12-05 12:28:18 -05:00
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( markStub . calledOnce ) . to . be . true ;
expect ( localStoreStub . called ) . to . be . false ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . called ) . to . be . false ;
2013-12-05 12:28:18 -05:00
done ( ) ;
} ) ;
} ) ;
it ( 'should sync tags from imap to memory and storage' , function ( done ) {
2013-12-12 07:14:49 -05:00
var folder , localListStub , imapSearchStub , invocations ,
2013-12-05 12:28:18 -05:00
markStub , localStoreStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
var inStorage = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
dummyDecryptedMail . unread = inStorage . unread = true ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ inStorage ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-05 13:10:30 -05:00
markStub = sinon . stub ( dao , '_imapMark' ) ;
2013-12-06 09:03:42 -05:00
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( ) ;
2013-12-05 12:28:18 -05:00
dao . sync ( {
folder : folder
} , function ( err ) {
expect ( err ) . to . not . exist ;
if ( invocations === 0 ) {
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
2013-12-06 09:03:42 -05:00
expect ( localListStub . calledTwice ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-05 12:28:18 -05:00
expect ( markStub . called ) . to . be . false ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( dummyDecryptedMail . unread ) . to . equal ( false ) ;
expect ( inStorage . unread ) . to . equal ( false ) ;
done ( ) ;
} ) ;
} ) ;
it ( 'should error while searching for unread tags on imap' , function ( done ) {
var folder , localListStub , imapSearchStub , invocations , markStub , localStoreStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
var inStorage = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
dummyDecryptedMail . unread = inStorage . unread = true ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ inStorage ] ) ;
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( { } ) ;
markStub = sinon . stub ( dao , '_imapMark' ) ;
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( markStub . called ) . to . be . false ;
expect ( imapSearchStub . calledTwice ) . to . be . true ;
expect ( localStoreStub . called ) . to . be . false ;
expect ( inStorage . unread ) . to . equal ( true ) ;
expect ( dummyDecryptedMail . unread ) . to . equal ( true ) ; // the live object has not been touched!
done ( ) ;
} ) ;
} ) ;
it ( 'should error while searching for answered tags on imap' , function ( done ) {
var folder , localListStub , imapSearchStub , invocations , markStub , localStoreStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
var inStorage = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
dummyDecryptedMail . unread = inStorage . unread = true ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ inStorage ] ) ;
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( { } ) ;
markStub = sinon . stub ( dao , '_imapMark' ) ;
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
expect ( localListStub . calledOnce ) . to . be . true ;
expect ( markStub . called ) . to . be . false ;
expect ( imapSearchStub . calledThrice ) . to . be . true ;
expect ( localStoreStub . called ) . to . be . false ;
expect ( inStorage . unread ) . to . equal ( true ) ;
expect ( dummyDecryptedMail . unread ) . to . equal ( true ) ; // the live object has not been touched!
2013-12-05 12:28:18 -05:00
done ( ) ;
} ) ;
} ) ;
it ( 'should error while syncing tags from imap to storage' , function ( done ) {
2013-12-12 07:14:49 -05:00
var folder , localListStub , imapSearchStub , invocations ,
2013-12-05 12:28:18 -05:00
markStub , localStoreStub ;
invocations = 0 ;
folder = 'FOLDAAAA' ;
dao . _account . folders = [ {
type : 'Folder' ,
path : folder ,
messages : [ dummyDecryptedMail ]
} ] ;
var inStorage = JSON . parse ( JSON . stringify ( dummyEncryptedMail ) ) ;
dummyDecryptedMail . unread = inStorage . unread = true ;
localListStub = sinon . stub ( dao , '_localListMessages' ) . yields ( null , [ inStorage ] ) ;
2013-12-12 07:14:49 -05:00
imapSearchStub = sinon . stub ( dao , '_imapSearch' ) ;
imapSearchStub . withArgs ( {
folder : folder
} ) . yields ( null , [ dummyEncryptedMail . uid ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
unread : true
} ) . yields ( null , [ ] ) ;
imapSearchStub . withArgs ( {
folder : folder ,
answered : true
} ) . yields ( null , [ ] ) ;
2013-12-05 13:10:30 -05:00
markStub = sinon . stub ( dao , '_imapMark' ) ;
2013-12-05 12:28:18 -05:00
localStoreStub = sinon . stub ( dao , '_localStoreMessages' ) . yields ( { } ) ;
dao . sync ( {
folder : folder
} , function ( err ) {
if ( invocations === 0 ) {
expect ( err ) . to . not . exist ;
expect ( dao . _account . busy ) . to . be . true ;
invocations ++ ;
return ;
}
expect ( err ) . to . exist ;
expect ( dao . _account . busy ) . to . be . false ;
expect ( dao . _account . folders [ 0 ] ) . to . not . be . empty ;
2013-12-06 09:03:42 -05:00
expect ( localListStub . calledTwice ) . to . be . true ;
2013-12-12 07:14:49 -05:00
expect ( imapSearchStub . calledThrice ) . to . be . true ;
2013-12-05 12:28:18 -05:00
expect ( markStub . called ) . to . be . false ;
expect ( localStoreStub . calledOnce ) . to . be . true ;
2013-12-03 13:21:50 -05:00
done ( ) ;
} ) ;
} ) ;
} ) ;
2013-12-05 12:28:18 -05:00
describe ( 'mark' , function ( ) {
2013-12-03 13:21:50 -05:00
it ( 'should work' , function ( done ) {
imapClientStub . updateFlags . withArgs ( {
path : 'asdf' ,
uid : 1 ,
2013-12-05 12:28:18 -05:00
unread : false ,
answered : false
2013-12-03 13:21:50 -05:00
} ) . yields ( ) ;
2013-12-05 13:10:30 -05:00
dao . _imapMark ( {
2013-12-03 13:21:50 -05:00
folder : 'asdf' ,
2013-12-05 12:28:18 -05:00
uid : 1 ,
unread : false ,
answered : false
2013-12-03 13:21:50 -05:00
} , function ( err ) {
expect ( imapClientStub . updateFlags . calledOnce ) . to . be . true ;
expect ( err ) . to . not . exist ;
done ( ) ;
} ) ;
} ) ;
} ) ;
describe ( 'move' , function ( ) {
it ( 'should work' , function ( done ) {
imapClientStub . moveMessage . withArgs ( {
path : 'asdf' ,
uid : 1 ,
destination : 'asdasd'
} ) . yields ( ) ;
dao . move ( {
folder : 'asdf' ,
uid : 1 ,
destination : 'asdasd'
} , function ( err ) {
expect ( imapClientStub . moveMessage . calledOnce ) . to . be . true ;
expect ( err ) . to . not . exist ;
done ( ) ;
} ) ;
} ) ;
} ) ;
describe ( 'sendPlaintext' , function ( ) {
it ( 'should work' , function ( done ) {
smtpClientStub . send . withArgs ( dummyEncryptedMail ) . yields ( ) ;
dao . sendPlaintext ( {
email : dummyEncryptedMail
} , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( smtpClientStub . send . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
} ) ;
describe ( 'sendEncrypted' , function ( ) {
it ( 'should work' , function ( done ) {
var encryptStub = sinon . stub ( dao , '_encrypt' ) . yields ( null , { } ) ;
2014-01-14 07:26:23 -05:00
2013-12-03 13:21:50 -05:00
smtpClientStub . send . yields ( ) ;
dao . sendEncrypted ( {
email : dummyDecryptedMail
} , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( encryptStub . calledOnce ) . to . be . true ;
expect ( smtpClientStub . send . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
it ( 'should not work when encryption fails' , function ( done ) {
var encryptStub = sinon . stub ( dao , '_encrypt' ) . yields ( { } ) ;
dao . sendEncrypted ( {
email : dummyDecryptedMail
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( encryptStub . calledOnce ) . to . be . true ;
expect ( smtpClientStub . send . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
it ( 'should not work without recipients' , function ( done ) {
var encryptStub = sinon . stub ( dao , '_encrypt' ) ;
delete dummyDecryptedMail . to ;
dao . sendEncrypted ( {
email : dummyDecryptedMail
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( encryptStub . called ) . to . be . false ;
expect ( smtpClientStub . send . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
it ( 'should not work with without sender' , function ( done ) {
var encryptStub = sinon . stub ( dao , '_encrypt' ) ;
delete dummyDecryptedMail . from ;
dao . sendEncrypted ( {
email : dummyDecryptedMail
} , function ( err ) {
expect ( err ) . to . exist ;
expect ( encryptStub . called ) . to . be . false ;
expect ( smtpClientStub . send . called ) . to . be . false ;
done ( ) ;
} ) ;
} ) ;
} ) ;
describe ( '_encrypt' , function ( ) {
it ( 'should work without attachments' , function ( done ) {
var ct = 'OMGSOENCRYPTED' ;
pgpStub . exportKeys . yields ( null , {
privateKeyArmored : mockKeyPair . privateKey . encryptedKey ,
publicKeyArmored : mockKeyPair . publicKey . publicKey
} ) ;
pgpStub . encrypt . yields ( null , ct ) ;
dao . _encrypt ( {
email : dummyDecryptedMail
} , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( pgpStub . exportKeys . calledOnce ) . to . be . true ;
expect ( pgpStub . encrypt . calledOnce ) . to . be . true ;
expect ( dummyDecryptedMail . body ) . to . contain ( ct ) ;
done ( ) ;
} ) ;
} ) ;
} ) ;
describe ( 'store' , function ( ) {
it ( 'should work' , function ( done ) {
pgpStub . exportKeys . yields ( null , {
publicKeyArmored : 'omgsocrypto'
} ) ;
pgpStub . encrypt . yields ( null , 'asdfasfd' ) ;
devicestorageStub . storeList . yields ( ) ;
dao . store ( dummyDecryptedMail , function ( err ) {
expect ( err ) . to . not . exist ;
expect ( pgpStub . exportKeys . calledOnce ) . to . be . true ;
expect ( pgpStub . encrypt . calledOnce ) . to . be . true ;
expect ( devicestorageStub . storeList . calledOnce ) . to . be . true ;
done ( ) ;
} ) ;
} ) ;
} ) ;
describe ( 'list' , function ( ) {
it ( 'should work' , function ( done ) {
devicestorageStub . listItems . yields ( null , [ dummyEncryptedMail ] ) ;
pgpStub . exportKeys . yields ( null , {
publicKeyArmored : 'omgsocrypto'
} ) ;
pgpStub . decrypt . yields ( null , dummyDecryptedMail . body ) ;
dao . list ( function ( err , mails ) {
expect ( err ) . to . not . exist ;
expect ( devicestorageStub . listItems . calledOnce ) . to . be . true ;
expect ( pgpStub . exportKeys . calledOnce ) . to . be . true ;
expect ( pgpStub . decrypt . calledOnce ) . to . be . true ;
expect ( mails . length ) . to . equal ( 1 ) ;
expect ( mails [ 0 ] . body ) . to . equal ( dummyDecryptedMail . body ) ;
expect ( mails [ 0 ] . subject ) . to . equal ( dummyDecryptedMail . subject ) ;
done ( ) ;
} ) ;
} ) ;
} ) ;
} ) ;
2013-08-19 15:13:32 -04:00
} ) ;