Philipp Muens 60e7be805d Rename "awsRemoveResources" to "awsRemove"
This way it's less verbose and sticks to the overall used naming convention.
2016-06-10 10:40:37 +02:00

46 lines
1.5 KiB
JavaScript

'use strict';
const expect = require('chai').expect;
const BbPromise = require('bluebird');
const sinon = require('sinon');
const AwsRemove = require('../awsRemove');
const Serverless = require('../../../Serverless');
describe('AwsRemove', () => {
const serverless = new Serverless();
serverless.init();
const options = {
stage: 'dev',
region: 'us-east-1',
};
const awsRemove = new AwsRemove(serverless, options);
describe('#constructor()', () => {
it('should have hooks', () => expect(awsRemove.hooks).to.be.not.empty);
it('should have access to the serverless instance', () => {
expect(awsRemove.serverless).to.deep.equal(serverless);
});
it('should run promise chain in order', () => {
const validateInputStub = sinon
.stub(awsRemove, 'validateInput').returns(BbPromise.resolve());
const emptyS3BucketStub = sinon
.stub(awsRemove, 'emptyS3Bucket').returns(BbPromise.resolve());
const removeStackStub = sinon
.stub(awsRemove, 'removeStack').returns(BbPromise.resolve());
return awsRemove.hooks['remove:remove']()
.then(() => {
expect(validateInputStub.calledOnce).to.be.equal(true);
expect(emptyS3BucketStub.calledAfter(validateInputStub)).to.be.equal(true);
expect(removeStackStub.calledAfter(emptyS3BucketStub)).to.be.equal(true);
awsRemove.validateInput.restore();
awsRemove.emptyS3Bucket.restore();
awsRemove.removeStack.restore();
});
});
});
});