mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-28 14:34:48 +00:00
7881e6a3ac
In d6bf5c24b9
we've ensured that certain modules of
embark only executed if their functionality is actually enabled.
This broke one of our tests in the communication module.
This commit fixes the test by explicitly enabling the module's functionality.
71 lines
2.0 KiB
JavaScript
71 lines
2.0 KiB
JavaScript
import sinon from 'sinon';
|
|
import assert from 'assert';
|
|
import { fakeEmbark, Plugins } from 'embark-testing';
|
|
import Communication from '../src/';
|
|
|
|
describe('stack/communication', () => {
|
|
|
|
let communication, communicationNodeLaunchFn, doneCb;
|
|
|
|
const { embark } = fakeEmbark();
|
|
|
|
beforeEach(() => {
|
|
embark.setConfig({
|
|
communicationConfig: {
|
|
connection: {
|
|
host: 'localhost',
|
|
}
|
|
},
|
|
embarkConfig: {}
|
|
});
|
|
|
|
communication = new Communication(embark);
|
|
|
|
communicationNodeLaunchFn = sinon.spy(done => {
|
|
embark.events.request('processes:register', 'communication', {
|
|
launchFn: cb => cb(),
|
|
stopFn: cb => cb(),
|
|
});
|
|
|
|
embark.events.request('processes:launch', 'communication', err => {
|
|
done();
|
|
});
|
|
});
|
|
|
|
doneCb = sinon.fake();
|
|
});
|
|
|
|
afterEach(() => {
|
|
embark.teardown();
|
|
sinon.restore();
|
|
});
|
|
|
|
test('it should register and start communication node', () => {
|
|
const communicationConfig = {
|
|
provider: 'whisper',
|
|
enabled: true
|
|
};
|
|
|
|
const processRegisterHandler = sinon.spy((name, fns) => {});
|
|
const processLaunchHandler = sinon.spy((name, fn) => fn());
|
|
|
|
embark.events.setCommandHandler('processes:register', processRegisterHandler);
|
|
embark.events.setCommandHandler('processes:launch', processLaunchHandler);
|
|
|
|
embark.events.request('communication:node:register', 'whisper', communicationNodeLaunchFn);
|
|
embark.events.request('communication:node:start', communicationConfig, doneCb);
|
|
|
|
assert(communicationNodeLaunchFn.calledOnce);
|
|
assert(doneCb.calledOnce);
|
|
});
|
|
|
|
test('it should register artifact file from configuration', () => {
|
|
const pipelineRegisterHandler = sinon.spy((params, fn) => fn());
|
|
embark.events.setCommandHandler('pipeline:register', pipelineRegisterHandler);
|
|
embark.plugins.emitAndRunActionsForEvent('pipeline:generateAll:before', {}, doneCb);
|
|
|
|
assert(pipelineRegisterHandler.calledOnce);
|
|
assert(doneCb.calledOnce);
|
|
});
|
|
});
|