send/test/frontend/tests/workflow-tests.js

227 lines
6.4 KiB
JavaScript
Raw Normal View History

2018-02-21 04:31:27 +00:00
import assert from 'assert';
2018-07-26 05:26:11 +00:00
import Archive from '../../../app/archive';
2018-02-21 04:31:27 +00:00
import FileSender from '../../../app/fileSender';
import FileReceiver from '../../../app/fileReceiver';
const headless = /Headless/.test(navigator.userAgent);
// TODO: save on headless doesn't work as it used to since it now
// follows a link instead of fetch. Maybe there's a way to make it
// work? For now always set noSave.
2018-07-31 18:29:26 +00:00
const options = { noSave: true || !headless, stream: true }; // only run the saveFile code if headless
2018-02-21 04:31:27 +00:00
// FileSender uses a File in real life but a Blob works for testing
const blob = new Blob([new ArrayBuffer(1024 * 128)], { type: 'text/plain' });
2018-02-21 04:31:27 +00:00
blob.name = 'test.txt';
2018-07-26 05:26:11 +00:00
const archive = new Archive([blob]);
2018-07-11 23:52:46 +00:00
navigator.serviceWorker.register('/serviceWorker.js');
2018-02-21 04:31:27 +00:00
describe('Upload / Download flow', function() {
this.timeout(0);
2018-02-21 04:31:27 +00:00
it('can only download once by default', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const file = await fs.upload(archive);
2018-02-21 04:31:27 +00:00
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
nonce: file.keychain.nonce,
requiresPassword: false
});
await fr.getMetadata();
2018-07-31 18:29:26 +00:00
await fr.download(options);
2018-02-21 04:31:27 +00:00
try {
2018-07-31 18:29:26 +00:00
await fr.download(options);
2018-02-21 04:31:27 +00:00
assert.fail('downloaded again');
} catch (e) {
assert.equal(e.message, '404');
}
});
it('downloads with the correct password', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const file = await fs.upload(archive);
2018-02-21 04:31:27 +00:00
await file.setPassword('magic');
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
url: file.url,
nonce: file.keychain.nonce,
requiresPassword: true,
password: 'magic'
});
await fr.getMetadata();
2018-07-31 18:29:26 +00:00
await fr.download(options);
2018-02-21 04:31:27 +00:00
assert.equal(fr.state, 'complete');
});
it('blocks invalid passwords from downloading', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const file = await fs.upload(archive);
2018-02-21 04:31:27 +00:00
await file.setPassword('magic');
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
url: file.url,
nonce: file.keychain.nonce,
requiresPassword: true,
password: 'password'
});
try {
await fr.getMetadata();
assert.fail('got metadata with bad password');
} catch (e) {
assert.equal(e.message, '401');
}
try {
// We can't decrypt without IV from metadata
// but let's try to download anyway
2018-07-31 18:29:26 +00:00
await fr.download(options);
2018-02-21 04:31:27 +00:00
assert.fail('downloaded file with bad password');
} catch (e) {
assert.equal(e.message, '401');
}
});
it('retries a bad nonce', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const file = await fs.upload(archive);
2018-02-21 04:31:27 +00:00
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
nonce: null, // oops
requiresPassword: false
});
await fr.getMetadata();
2018-07-26 05:26:11 +00:00
assert.equal(fr.fileInfo.name, archive.name);
2018-02-21 04:31:27 +00:00
});
it('can cancel the upload', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const up = fs.upload(archive);
fs.cancel(); // before encrypting
try {
await up;
2018-06-21 00:05:33 +00:00
assert.fail('not cancelled 1');
} catch (e) {
assert.equal(e.message, '0');
}
fs.reset();
fs.once('encrypting', () => fs.cancel());
try {
2018-08-31 21:20:15 +00:00
await fs.upload(archive);
2018-06-21 00:05:33 +00:00
assert.fail('not cancelled 2');
} catch (e) {
assert.equal(e.message, '0');
}
fs.reset();
fs.once('progress', () => fs.cancel());
try {
2018-08-31 21:20:15 +00:00
await fs.upload(archive);
2018-06-21 00:05:33 +00:00
assert.fail('not cancelled 3');
} catch (e) {
assert.equal(e.message, '0');
}
});
it('can cancel the download', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const file = await fs.upload(archive);
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
nonce: file.keychain.nonce,
requiresPassword: false
});
await fr.getMetadata();
fr.once('progress', () => fr.cancel());
try {
2018-07-31 18:29:26 +00:00
await fr.download(options);
assert.fail('not cancelled');
} catch (e) {
assert.equal(e.message, '0');
}
});
2018-07-17 16:48:47 +00:00
it('can increase download count on download', async function() {
this.timeout(0);
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const file = await fs.upload(archive);
2018-07-17 16:48:47 +00:00
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
nonce: file.keychain.nonce,
requiresPassword: false
});
await fr.getMetadata();
2018-07-31 18:29:26 +00:00
await fr.download(options);
2018-07-17 16:48:47 +00:00
await file.updateDownloadCount();
assert.equal(file.dtotal, 1);
});
it('does not increase download count when download cancelled', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const file = await fs.upload(archive);
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
nonce: file.keychain.nonce,
requiresPassword: false
});
await fr.getMetadata();
fr.once('progress', () => fr.cancel());
2018-07-12 23:07:18 +00:00
try {
2018-07-31 18:29:26 +00:00
await fr.download(options);
assert.fail('not cancelled');
} catch (e) {
await file.updateDownloadCount();
assert.equal(file.dtotal, 0);
}
});
2018-07-12 23:07:18 +00:00
2018-02-21 04:31:27 +00:00
it('can allow multiple downloads', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const a = new Archive([blob]);
a.dlimit = 2;
const file = await fs.upload(a);
2018-02-21 04:31:27 +00:00
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
nonce: file.keychain.nonce,
requiresPassword: false
});
await fr.getMetadata();
2018-07-31 18:29:26 +00:00
await fr.download(options);
2018-02-21 04:31:27 +00:00
await file.updateDownloadCount();
assert.equal(file.dtotal, 1);
2018-07-31 18:29:26 +00:00
await fr.download(options);
2018-02-21 04:31:27 +00:00
await file.updateDownloadCount();
assert.equal(file.dtotal, 2);
try {
2018-07-31 18:29:26 +00:00
await fr.download(options);
2018-02-21 04:31:27 +00:00
assert.fail('downloaded too many times');
} catch (e) {
assert.equal(e.message, '404');
}
});
it('can delete the file before download', async function() {
2018-08-31 21:20:15 +00:00
const fs = new FileSender();
const file = await fs.upload(archive);
2018-02-21 04:31:27 +00:00
const fr = new FileReceiver({
secretKey: file.toJSON().secretKey,
id: file.id,
nonce: file.keychain.nonce,
requiresPassword: false
});
await file.del();
try {
await fr.getMetadata();
assert.fail('file still exists');
} catch (e) {
assert.equal(e.message, '404');
}
});
});