- Add a new plugin type: `publish` - Add support for multi-plugin. A plugin module can now return an object with a property for each plugin type - Uses by default [npm](https://github.com/semantic-release/npm) and [github](https://github.com/semantic-release/github) in addition of Travis for the verify condition plugin - Uses by default [npm](https://github.com/semantic-release/npm) and [github](https://github.com/semantic-release/github) for the publish plugin - `gitTag` if one can be found is passed to `generateNotes` for both `lastRelease` and `nextRelease` - `semantic-release` now verifies the plugin configuration (in the `release` property of `package.json`) and throws an error if it's invalid - `semantic-release` now verifies each plugin output and will throw an error if a plugin returns an unexpected value. BREAKING CHANGE: `githubToken`, `githubUrl` and `githubApiPathPrefix` have to be set at the [github](https://github.com/semantic-release/github) plugin level. They can be set via `GH_TOKEN`, `GH_URL` and `GH_PREFIX` environment variables. BREAKING CHANGE: the `npm` parameter is not passed to any plugin anymore. Each plugin have to read `.npmrc` if they needs to (with https://github.com/kevva/npm-conf for example).
41 lines
1.3 KiB
JavaScript
41 lines
1.3 KiB
JavaScript
import test from 'ava';
|
|
import {stub} from 'sinon';
|
|
import pipeline from '../../lib/plugins/pipeline';
|
|
|
|
test('Execute each function in series passing the same input', async t => {
|
|
const step1 = stub().resolves(1);
|
|
const step2 = stub().resolves(2);
|
|
const step3 = stub().resolves(3);
|
|
|
|
const result = await pipeline([step1, step2, step3])(0);
|
|
t.deepEqual(result, [1, 2, 3]);
|
|
t.true(step1.calledWith(0));
|
|
t.true(step2.calledWith(0));
|
|
t.true(step3.calledWith(0));
|
|
});
|
|
|
|
test('Execute each function in series passing a transformed input', async t => {
|
|
const step1 = stub().resolves(1);
|
|
const step2 = stub().resolves(2);
|
|
const step3 = stub().resolves(3);
|
|
|
|
const result = await pipeline([step1, step2, step3])(0, (prevResult, result) => prevResult + result);
|
|
|
|
t.deepEqual(result, [1, 2, 3]);
|
|
t.true(step1.calledWith(0));
|
|
t.true(step2.calledWith(1));
|
|
t.true(step3.calledWith(3));
|
|
});
|
|
|
|
test('Stop execution and throw error is a step rejects', async t => {
|
|
const step1 = stub().resolves(1);
|
|
const step2 = stub().throws(new Error('test error'));
|
|
const step3 = stub().resolves(3);
|
|
|
|
const error = await t.throws(pipeline([step1, step2, step3])(0));
|
|
t.is(error.message, 'test error');
|
|
t.true(step1.calledWith(0));
|
|
t.true(step2.calledWith(0));
|
|
t.true(step3.notCalled);
|
|
});
|