mirror of
https://github.com/serverless/serverless.git
synced 2026-01-18 14:58:43 +00:00
* fix #1854 - added latest version of eslint-config-airbnb-base package * fix #1854 - added latest npm shrinkwrap scheme * fix #1854 - added latest npm coveralls package * fix #1854 - added latest npm eslint package * fix #1854 - added latest npm eslint-config-airbnb package * fix #1854 - added latest npm eslint-plugin-import package * fix #1854 - added latest npm eslint-plugin-jsx-a11y package * fix #1854 - added latest npm eslint-plugin-react package * fix #1854 - fixed estlint new-parens errors for integration test * fix #1854 - fixed estlint new-parens errors for yaml parsers tests * fix #1854 - fixed estlint max-len errors for util tests * fix #1854 - disabled no-extraneous-dependencies on eslintrc for NodeJS 4 incapability on this feature * fix #1854 - fixed eslint new-parens errors for Service tests * fix #1854 - fixed eslint new-parens errors for Serverless tests * fix #1854 - fixed eslint new-parens errors for plugin manager tests * fix #1854 - fixed eslint new-parens errors for plugin tracking tests * fix #1854 - fixed eslint new-parens errors for plugin package zipService lib * fix #1854 - fixed eslint new-parens errors for plugin package zipService tests * fix #1854 - fixed eslint trailing spaces errors for plugin package zipService lib * fix #1854 - fixed eslint new-parens errors for plugin package cleanup tests * fix #1854 - fixed eslint new-parens errors for plugin create tests * fix #1854 - fixed eslint dot same line expectation error on plugin aws logs index * fix #1854 - fixed eslint operator assignment error on plugin aws logs index * fix #1854 - fixed eslint dot location error on plugin aws invoke tests * fix #1854 - fixed eslint new-parens error on plugin aws invoke tests * fix #1854 - fixed eslint new-parens error on plugin aws deployFunction tests * fix #1854 - fixed eslint new-parens error on plugin aws deploy uploadDeploymentPackage tests * fix #1854 - fixed eslint new-parens error on plugin aws deploy updateStack tests * fix #1854 - fixed eslint new-parens error on plugin aws deploy createStack tests * fix #1854 - fixed eslint new-parens error on plugin aws deploy apiGateway lib deployment * fix #1854 - fixed eslint unary typeof whitespace req error on Serverless Service class * fix #1854 - fixed eslint unary typeof whitespace req error on Serverless Service class ( second fix ) * fix #1854 - fixed eslint no-lonely-if req error on Serverless Service class * fix #1854 - disabled react/require-extension on eslintrc because it's deprecated * fix #1854 - AwsCompileApigEvents #constructor() should resolve if no functions are given: Error: Resolution method is overspecified. Specify a callback *or* return a Promise; not both. * fix #1854 - createStack #postCreate() should resolve: Error: Resolution method is overspecified. Specify a callback *or* return a Promise; not both. * fix #1854 - emptyS3Bucket #deleteObjects() should resolve if objectsInBucket is empty: Error: Resolution method is overspecified. Specify a callback *or* return a Promise; not both. * fix #1854 - AwsInvoke #extendedValidate() should resolve if path is not given: Error: Resolution method is overspecified. Specify a callback *or* return a Promise; not both. * fix #1854 - #cleanup() should resolve if the .serverless directory is not present: Error: Resolution method is overspecified. Specify a callback *or* return a Promise; not both. * fix #1854 -#validate() should resolve if servicePath is given: Error: Resolution method is overspecified. Specify a callback *or* return a Promise; not both. * fix #1854 - Service #load() should resolve if no servicePath is found: Error: Resolution method is overspecified. Specify a callback *or* return a Promise; not both. * fix #1854 - added latest mocha package * fix #1854 - added latest sinon npm package * fix #1854 - serverless/lib/plugins/aws/deploy/tests/createStack.js 136:48 error Missing semicolon semi * fix #1854 - serverless/lib/plugins/package/tests/cleanup.js 35:7 error Missing semicolon semi * fix #1854 - serverless/lib/plugins/package/tests/validate.js 22:49 error Missing semicolon semi * fix #1854 - added latest npm shrinkwrap * fix #1854 - fixed no-extra-boolean-cast eslint error on aws deploy apiGateway methods * fix #1854 - fixed new-parens eslint error on serverless tests for Service class
168 lines
6.1 KiB
JavaScript
168 lines
6.1 KiB
JavaScript
'use strict';
|
|
|
|
const expect = require('chai').expect;
|
|
const path = require('path');
|
|
const os = require('os');
|
|
const fse = require('fs-extra');
|
|
const BbPromise = require('bluebird');
|
|
const Create = require('../create');
|
|
const Serverless = require('../../../Serverless');
|
|
const sinon = require('sinon');
|
|
|
|
describe('Create', () => {
|
|
let create;
|
|
|
|
before(() => {
|
|
const serverless = new Serverless();
|
|
const options = {};
|
|
create = new Create(serverless, options);
|
|
create.serverless.cli = new serverless.classes.CLI();
|
|
});
|
|
|
|
describe('#constructor()', () => {
|
|
it('should have commands', () => expect(create.commands).to.be.not.empty);
|
|
|
|
it('should have hooks', () => expect(create.hooks).to.be.not.empty);
|
|
|
|
it('should run promise chain in order for "create:create" hook', () => {
|
|
const createStub = sinon
|
|
.stub(create, 'create').returns(BbPromise.resolve());
|
|
|
|
return create.hooks['create:create']().then(() => {
|
|
expect(createStub.calledOnce).to.be.equal(true);
|
|
|
|
create.create.restore();
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('#create()', () => {
|
|
it('should throw error if user passed unsupported template', () => {
|
|
create.options.template = 'invalid-template';
|
|
expect(() => create.create()).to.throw(Error);
|
|
});
|
|
|
|
it('should set servicePath based on cwd', () => {
|
|
const tmpDir = path.join(os.tmpdir(), (new Date()).getTime().toString());
|
|
const cwd = process.cwd();
|
|
fse.mkdirsSync(tmpDir);
|
|
process.chdir(tmpDir);
|
|
create.options.template = 'aws-nodejs';
|
|
return create.create().then(() => {
|
|
expect(create.serverless.config.servicePath).to.be.equal(process.cwd());
|
|
process.chdir(cwd);
|
|
});
|
|
});
|
|
|
|
it('should display ascii greeting', () => {
|
|
const greetingStub = sinon.stub(create.serverless.cli, 'asciiGreeting');
|
|
create.create();
|
|
expect(greetingStub.callCount).to.be.equal(1);
|
|
});
|
|
|
|
it('should generate scaffolding for "aws-nodejs" template', () => {
|
|
const tmpDir = path.join(os.tmpdir(), (new Date()).getTime().toString());
|
|
const cwd = process.cwd();
|
|
fse.mkdirsSync(tmpDir);
|
|
process.chdir(tmpDir);
|
|
create.options.template = 'aws-nodejs';
|
|
|
|
return create.create().then(() => {
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'serverless.yml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'serverless.env.yml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'handler.js')))
|
|
.to.be.equal(true);
|
|
|
|
process.chdir(cwd);
|
|
});
|
|
});
|
|
|
|
it('should generate scaffolding for "aws-python" template', () => {
|
|
const tmpDir = path.join(os.tmpdir(), (new Date()).getTime().toString());
|
|
const cwd = process.cwd();
|
|
fse.mkdirsSync(tmpDir);
|
|
process.chdir(tmpDir);
|
|
create.options.template = 'aws-python';
|
|
|
|
return create.create().then(() => {
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'serverless.yml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'serverless.env.yml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'handler.py')))
|
|
.to.be.equal(true);
|
|
|
|
process.chdir(cwd);
|
|
});
|
|
});
|
|
|
|
it('should generate scaffolding for "aws-java-maven" template', () => {
|
|
const tmpDir = path.join(os.tmpdir(), (new Date()).getTime().toString());
|
|
const cwd = process.cwd();
|
|
fse.mkdirsSync(tmpDir);
|
|
process.chdir(tmpDir);
|
|
create.options.template = 'aws-java-maven';
|
|
|
|
return create.create().then(() => {
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'serverless.yml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'serverless.env.yml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'event.json')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'pom.xml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'src', 'main', 'java',
|
|
'hello', 'Handler.java'
|
|
)))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'src', 'main', 'java',
|
|
'hello', 'Request.java'
|
|
)))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'src', 'main', 'java',
|
|
'hello', 'Response.java'
|
|
)))
|
|
.to.be.equal(true);
|
|
|
|
process.chdir(cwd);
|
|
});
|
|
});
|
|
|
|
it('should generate scaffolding for "aws-java-gradle" template', () => {
|
|
const tmpDir = path.join(os.tmpdir(), (new Date()).getTime().toString());
|
|
const cwd = process.cwd();
|
|
fse.mkdirsSync(tmpDir);
|
|
process.chdir(tmpDir);
|
|
create.options.template = 'aws-java-gradle';
|
|
|
|
return create.create().then(() => {
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'serverless.yml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'serverless.env.yml')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'event.json')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'build.gradle')))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'src', 'main', 'java',
|
|
'hello', 'Handler.java'
|
|
)))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'src', 'main', 'java',
|
|
'hello', 'Request.java'
|
|
)))
|
|
.to.be.equal(true);
|
|
expect(create.serverless.utils.fileExistsSync(path.join(tmpDir, 'src', 'main', 'java',
|
|
'hello', 'Response.java'
|
|
)))
|
|
.to.be.equal(true);
|
|
|
|
process.chdir(cwd);
|
|
});
|
|
});
|
|
});
|
|
});
|