Merge pull request #3494 from HyperBrain/move-event-spawns-to-framework-level

Control command flow for deploy at framework level.
This commit is contained in:
Eslam λ Hefnawy 2017-04-20 19:56:49 +07:00 committed by GitHub
commit b2fe5b6aba
4 changed files with 67 additions and 8 deletions

View File

@ -69,9 +69,7 @@ class AwsDeploy {
.then(() => this.serverless.pluginManager.spawn('aws:common:validate'))
.then(() => {
if (!this.options.package && !this.serverless.service.package.path) {
return BbPromise.bind(this)
.then(() => this.serverless.pluginManager.spawn('package'))
.then(this.extendedValidate);
return this.extendedValidate();
}
return BbPromise.bind(this)
.then(() => this.serverless.pluginManager.spawn('aws:common:moveArtifactsToTemp'))

View File

@ -126,8 +126,7 @@ describe('AwsDeploy', () => {
return awsDeploy.hooks['before:deploy:deploy']().then(() => {
expect(spawnAwsCommonValidateStub.calledOnce).to.equal(true);
expect(spawnPackageStub.calledAfter(spawnAwsCommonValidateStub)).to.equal(true);
expect(extendedValidateStub.calledAfter(spawnPackageStub)).to.equal(true);
expect(extendedValidateStub.calledAfter(spawnAwsCommonValidateStub)).to.equal(true);
expect(spawnAwsCommonMoveArtifactsToTemp.calledOnce).to.equal(false);
});
});

View File

@ -1,8 +1,11 @@
'use strict';
const BbPromise = require('bluebird');
class Deploy {
constructor(serverless) {
constructor(serverless, options) {
this.serverless = serverless;
this.options = options || {};
this.commands = {
deploy: {
@ -68,6 +71,16 @@ class Deploy {
},
},
};
this.hooks = {
'before:deploy:deploy': () => BbPromise.bind(this)
.then(() => {
if (!this.options.package && !this.serverless.service.package.path) {
return this.serverless.pluginManager.spawn('package');
}
return BbPromise.resolve();
}),
};
}
}

View File

@ -3,18 +3,67 @@
const expect = require('chai').expect;
const Deploy = require('./deploy');
const Serverless = require('../../Serverless');
const sinon = require('sinon');
describe('Deploy', () => {
let deploy;
let serverless;
let options;
beforeEach(() => {
serverless = new Serverless();
deploy = new Deploy(serverless);
options = {};
deploy = new Deploy(serverless, options);
});
describe('#constructor()', () => {
it('should have commands', () => expect(deploy.commands).to.be.not.empty);
it('should have hooks', () => expect(deploy.hooks).to.be.not.empty);
it('should work without options', () => {
const noOptionDeploy = new Deploy(serverless);
expect(noOptionDeploy).to.have.property('options').to.be.eql({});
});
});
describe('"before:deploy:deploy" hook', () => {
let spawnStub;
let spawnPackageStub;
beforeEach(() => {
spawnStub = sinon
.stub(serverless.pluginManager, 'spawn');
spawnPackageStub = spawnStub.withArgs('package').resolves();
});
afterEach(() => {
serverless.pluginManager.spawn.restore();
});
it('should resolve if the package option is set', () => {
deploy.options.package = false;
deploy.serverless.service.package.path = 'some_path';
return deploy.hooks['before:deploy:deploy']().then(() => {
expect(spawnPackageStub.called).to.equal(false);
});
});
it('should resolve if the service package path is set', () => {
deploy.options.package = 'some_path';
deploy.serverless.service.package.path = false;
return deploy.hooks['before:deploy:deploy']().then(() => {
expect(spawnPackageStub.called).to.equal(false);
});
});
it('should use the default packaging mechanism if no packaging config is provided', () => {
deploy.options.package = false;
deploy.serverless.service.package.path = false;
return deploy.hooks['before:deploy:deploy']().then(() => {
expect(spawnPackageStub.calledOnce).to.equal(true);
});
});
});
});