2015-06-15 20:56:09 +00:00
|
|
|
'use strict';
|
|
|
|
|
2016-01-10 16:37:19 +00:00
|
|
|
var expect = require('expect.js'),
|
2015-06-15 20:56:09 +00:00
|
|
|
sinon = require('sinon'),
|
2016-01-10 16:37:19 +00:00
|
|
|
helpers = require('./helpers');
|
2015-06-15 20:56:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
describe('Distributor trigger after', function() {
|
|
|
|
var distributor, executorRunSpy, projects;
|
|
|
|
|
|
|
|
var nodes = [{type: 'local', maxExecutorsCount: 1}];
|
|
|
|
|
|
|
|
describe('done when project is done', function() {
|
|
|
|
before(function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
projects = [{
|
2015-06-15 20:56:09 +00:00
|
|
|
name: 'project1',
|
|
|
|
trigger: {
|
|
|
|
after: [{status: 'done', project: 'project2'}]
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
name: 'project2'
|
2016-01-10 16:37:19 +00:00
|
|
|
}];
|
2015-06-15 20:56:09 +00:00
|
|
|
executorRunSpy = sinon.stub().callsArgAsync(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('distributor should be created without errors', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
distributor = helpers.createDistributor({
|
|
|
|
projects: projects,
|
|
|
|
nodes: nodes,
|
|
|
|
executorRun: executorRunSpy
|
|
|
|
});
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run without errors', function(done) {
|
|
|
|
distributor.run({projectName: 'project1'}, function(err) {
|
|
|
|
expect(err).not.ok();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run project1 at first call', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
expect(executorRunSpy.getCall(0).thisValue.project).eql(projects[0]);
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run project2 at second call', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
expect(executorRunSpy.getCall(1).thisValue.project).eql(projects[1]);
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run totally 2 times', function() {
|
|
|
|
expect(executorRunSpy.callCount).equal(2);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('done when project is error', function() {
|
|
|
|
before(function() {
|
|
|
|
executorRunSpy = sinon.stub().callsArgWithAsync(1, new Error(
|
|
|
|
'Some error'
|
|
|
|
));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('distributor should be created without errors', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
distributor = helpers.createDistributor({
|
|
|
|
projects: projects,
|
|
|
|
nodes: nodes,
|
|
|
|
executorRun: executorRunSpy
|
|
|
|
});
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run without errors', function(done) {
|
|
|
|
distributor.run({projectName: 'project1'}, function(err) {
|
|
|
|
expect(err).not.ok();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run project1 at first call', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
expect(executorRunSpy.getCall(0).thisValue.project).eql(projects[0]);
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run totally 1 time', function() {
|
|
|
|
expect(executorRunSpy.callCount).equal(1);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('status is not set when project is done', function() {
|
|
|
|
before(function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
projects = [{
|
2015-06-15 20:56:09 +00:00
|
|
|
name: 'project1',
|
|
|
|
trigger: {
|
|
|
|
after: [{project: 'project2'}]
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
name: 'project2'
|
2016-01-10 16:37:19 +00:00
|
|
|
}];
|
2015-06-15 20:56:09 +00:00
|
|
|
executorRunSpy = sinon.stub().callsArgAsync(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('distributor should be created without errors', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
distributor = helpers.createDistributor({
|
|
|
|
projects: projects,
|
|
|
|
nodes: nodes,
|
|
|
|
executorRun: executorRunSpy
|
|
|
|
});
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run without errors', function(done) {
|
|
|
|
distributor.run({projectName: 'project1'}, function(err) {
|
|
|
|
expect(err).not.ok();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run project1 at first call', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
expect(executorRunSpy.getCall(0).thisValue.project).eql(projects[0]);
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run project2 at second call', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
expect(executorRunSpy.getCall(1).thisValue.project).eql(projects[1]);
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run totally 2 times', function() {
|
|
|
|
expect(executorRunSpy.callCount).equal(2);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('status is not set when project is error', function() {
|
|
|
|
before(function() {
|
|
|
|
executorRunSpy = sinon.stub().callsArgWithAsync(1, new Error(
|
|
|
|
'Some error'
|
|
|
|
));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('distributor should be created without errors', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
distributor = helpers.createDistributor({
|
|
|
|
projects: projects,
|
|
|
|
nodes: nodes,
|
|
|
|
executorRun: executorRunSpy
|
|
|
|
});
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run without errors', function(done) {
|
|
|
|
distributor.run({projectName: 'project1'}, function(err) {
|
|
|
|
expect(err).not.ok();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run project1 at first call', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
expect(executorRunSpy.getCall(0).thisValue.project).eql(projects[0]);
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run project2 at second call', function() {
|
2016-01-10 16:37:19 +00:00
|
|
|
expect(executorRunSpy.getCall(1).thisValue.project).eql(projects[1]);
|
2015-06-15 20:56:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should run totally 2 times', function() {
|
|
|
|
expect(executorRunSpy.callCount).equal(2);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|