mirror of
https://github.com/serverless/serverless.git
synced 2026-01-25 15:07:39 +00:00
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:
commit
b2fe5b6aba
@ -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'))
|
||||
|
||||
@ -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);
|
||||
});
|
||||
});
|
||||
|
||||
@ -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();
|
||||
}),
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -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);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user