send/test/aws.storage.test.js

165 lines
4.8 KiB
JavaScript
Raw Normal View History

2017-06-19 20:37:56 +00:00
const assert = require('assert');
const sinon = require('sinon');
const proxyquire = require('proxyquire');
2017-06-20 17:21:11 +00:00
const crypto = require('crypto');
2017-06-19 20:37:56 +00:00
const conf = require('../server/config.js');
conf.notLocalHost = true;
let redisStub = {};
let exists = sinon.stub();
let hget = sinon.stub();
let hmset = sinon.stub();
2017-06-20 17:21:11 +00:00
let expire = sinon.spy();
2017-06-19 20:37:56 +00:00
let del = sinon.stub();
redisStub.createClient = function() {
return {
on: sinon.spy(),
exists: exists,
hget: hget,
hmset: hmset,
expire: expire,
del: del
}
}
let fsStub = {};
fsStub.statSync = sinon.stub();
fsStub.createReadStream = sinon.stub();
fsStub.createWriteStream = sinon.stub();
fsStub.unlinkSync = sinon.stub();
let logStub = {};
logStub.info = sinon.stub();
logStub.error = sinon.stub();
let s3Stub = {};
s3Stub.headObject = sinon.stub();
s3Stub.getObject = sinon.stub();
s3Stub.upload = sinon.stub();
s3Stub.deleteObject = sinon.stub();
let awsStub = {
S3: function() {
return s3Stub;
}
}
const storage = proxyquire('../server/storage', {
'redis': redisStub,
'fs': fsStub,
'./log.js': function() { return logStub },
'aws-sdk': awsStub
});
describe('Testing Length using aws', function() {
it('Filesize returns properly if id exists', function() {
s3Stub.headObject.callsArgWith(1, null, {ContentLength: 1});
return storage.length('123')
2017-06-20 17:21:11 +00:00
.then(reply => assert.equal(reply, 1))
2017-06-19 20:37:56 +00:00
.catch(err => assert.fail())
})
it('Filesize fails if the id does not exist', function() {
s3Stub.headObject.callsArgWith(1, new Error(), null);
return storage.length('123')
.then(reply => assert.fail())
.catch(err => assert(1))
})
});
describe('Testing Get using aws', function() {
2017-06-20 17:21:11 +00:00
2017-06-19 20:37:56 +00:00
it('Should not error out when the file exists', function() {
2017-06-20 17:21:11 +00:00
let spy = sinon.spy();
2017-06-19 20:37:56 +00:00
s3Stub.getObject.returns({
2017-06-20 17:21:11 +00:00
createReadStream: spy
2017-06-19 20:37:56 +00:00
});
2017-06-20 17:21:11 +00:00
storage.get('123');
assert(spy.calledOnce);
2017-06-19 20:37:56 +00:00
})
it('Should error when the file does not exist', function() {
2017-06-20 17:21:11 +00:00
let err = function() { throw new Error(); }
let spy = sinon.spy(err);
2017-06-19 20:37:56 +00:00
s3Stub.getObject.returns({
2017-06-20 17:21:11 +00:00
createReadStream: spy
2017-06-19 20:37:56 +00:00
});
2017-06-20 17:21:11 +00:00
assert.equal(storage.get('123'), null);
assert(spy.threw());
2017-06-19 20:37:56 +00:00
})
});
describe('Testing Set using aws', function() {
2017-06-20 17:21:11 +00:00
beforeEach(function() {
expire.reset();
})
after(function() {
crypto.randomBytes.restore();
})
2017-06-19 20:37:56 +00:00
it('Should pass when the file is successfully uploaded and no bitly key', function() {
conf.bitly_key = null;
2017-06-20 17:21:11 +00:00
const buf = new Buffer(10);
sinon.stub(crypto, 'randomBytes').returns(buf);
2017-06-19 20:37:56 +00:00
s3Stub.upload.callsArgWith(1, null, {});
return storage.set('123', {}, 'Filename.moz', 'url.com')
2017-06-20 17:21:11 +00:00
.then(reply => {
assert.equal(reply.uuid, buf.toString('hex'));
assert.equal(reply.url, 'url.com');
assert.notEqual(reply.uuid, null);
assert(expire.calledOnce);
assert(expire.calledWith('123', 86400000));
})
.catch(err => assert.fail());
2017-06-19 20:37:56 +00:00
})
it('Should fail if there was an error during uploading', function() {
s3Stub.upload.callsArgWith(1, new Error(), null);
return storage.set('123', {}, 'Filename.moz', 'url.com')
2017-06-20 17:21:11 +00:00
.then(reply => assert.fail())
.catch(err => assert(1));
2017-06-19 20:37:56 +00:00
})
});
describe('Testing Delete from aws', function() {
it('Returns successfully if the id is deleted off aws', function() {
hget.callsArgWith(2, null, 'delete_token');
s3Stub.deleteObject.callsArgWith(1, null, {});
return storage.delete('file_id', 'delete_token')
.then(reply => assert(1), err => assert.fail())
})
it('Delete fails if id exists locally but does not in aws', function() {
hget.callsArgWith(2, null, 'delete_token');
s3Stub.deleteObject.callsArgWith(1, new Error(), {});
return storage.delete('file_id', 'delete_token')
.then(reply => assert.fail(), err => assert(1))
})
it('Delete fails if the delete token does not match', function() {
hget.callsArgWith(2, null, {});
return storage.delete('Filename.moz', 'delete_token')
.then(reply => assert.fail())
.catch(reply => assert(1))
})
});
describe('Testing Forced Delete from aws', function() {
it('Deletes properly if id exists', function() {
s3Stub.deleteObject.callsArgWith(1, null, {});
return storage.forceDelete('file_id', 'delete_token')
.then(reply => assert(1), err => assert.fail());
})
it('Deletes fails if id does not exist', function() {
s3Stub.deleteObject.callsArgWith(1, new Error(), {});
return storage.forceDelete('file_id')
.then(reply => assert.fail(), err => assert(1))
})
})