2015-04-09 18:55:29 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var Distributor = require('../lib/distributor').Distributor,
|
|
|
|
Node = require('../lib/node').Node,
|
2015-05-04 21:41:23 +00:00
|
|
|
expect = require('expect.js'),
|
|
|
|
EventEmitter = require('events').EventEmitter;
|
2015-04-09 18:55:29 +00:00
|
|
|
|
|
|
|
|
|
|
|
describe('Distributor', function() {
|
|
|
|
var distributor,
|
|
|
|
project1 = {name: 'project1'};
|
|
|
|
|
2015-04-09 19:39:22 +00:00
|
|
|
var createNodeMock = function(executorRun) {
|
|
|
|
return function(params) {
|
|
|
|
var node = new Node(params);
|
|
|
|
node._createExecutor = function() {
|
2015-05-04 21:41:23 +00:00
|
|
|
var executor = new EventEmitter();
|
|
|
|
executor.run = executorRun;
|
|
|
|
return executor;
|
2015-04-09 19:39:22 +00:00
|
|
|
};
|
|
|
|
return node;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
var expectUpdateBuild = function(distributor, build, number, conditionsHash) {
|
|
|
|
var conditions = conditionsHash[number];
|
|
|
|
expect(distributor.queue).length(conditions.queue.length);
|
|
|
|
expect(build.status).equal(conditions.build.status);
|
|
|
|
if (build.status === 'error') {
|
|
|
|
expect(build.error.message).eql(conditions.build.error.message);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-04-09 18:55:29 +00:00
|
|
|
describe('with sucess project', function() {
|
2015-04-09 19:39:22 +00:00
|
|
|
var originalCreateNode;
|
2015-04-09 18:55:29 +00:00
|
|
|
|
|
|
|
before(function() {
|
|
|
|
originalCreateNode = Distributor.prototype._createNode;
|
2015-04-09 19:39:22 +00:00
|
|
|
Distributor.prototype._createNode = createNodeMock(
|
|
|
|
function(params, callback) {
|
|
|
|
setTimeout(callback, 10);
|
2015-04-09 18:55:29 +00:00
|
|
|
}
|
2015-04-09 19:39:22 +00:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('instance should be created without errors', function() {
|
|
|
|
var number = 1;
|
|
|
|
var conditionsHash = {
|
2015-05-04 21:28:59 +00:00
|
|
|
1: {queue: {length: 0}, build: {status: 'queued'}},
|
2015-04-09 19:39:22 +00:00
|
|
|
2: {queue: {length: 1}, build: {status: 'in-progress'}},
|
|
|
|
3: {queue: {length: 0}, build: {status: 'done'}},
|
|
|
|
4: 'Should never happend'
|
|
|
|
};
|
|
|
|
var onBuildUpdate = function(build, callback) {
|
|
|
|
expectUpdateBuild(distributor, build, number, conditionsHash);
|
|
|
|
number++;
|
2015-04-09 18:55:29 +00:00
|
|
|
callback(null, build)
|
|
|
|
};
|
2015-04-09 19:39:22 +00:00
|
|
|
|
|
|
|
distributor = new Distributor({
|
|
|
|
nodes: [{type: 'local', maxExecutorsCount: 1}],
|
|
|
|
onBuildUpdate: onBuildUpdate
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should run without errors', function() {
|
|
|
|
distributor.run(project1, {}, function(err) {
|
|
|
|
expect(err).not.ok();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('wait for project done (should no errors)', function(done) {
|
|
|
|
setTimeout(done, 20);
|
|
|
|
});
|
|
|
|
|
|
|
|
after(function() {
|
|
|
|
Distributor.prototype._createNode = originalCreateNode;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with fail project', function() {
|
|
|
|
var originalCreateNode;
|
|
|
|
|
|
|
|
before(function() {
|
|
|
|
originalCreateNode = Distributor.prototype._createNode;
|
|
|
|
Distributor.prototype._createNode = createNodeMock(
|
|
|
|
function(params, callback) {
|
|
|
|
setTimeout(function() {
|
|
|
|
callback(new Error('Some error'));
|
|
|
|
}, 10);
|
|
|
|
}
|
|
|
|
);
|
2015-04-09 18:55:29 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('instance should be created without errors', function() {
|
2015-04-09 19:39:22 +00:00
|
|
|
var number = 1;
|
|
|
|
var conditionsHash = {
|
2015-05-04 21:28:59 +00:00
|
|
|
1: {queue: {length: 0}, build: {status: 'queued'}},
|
2015-04-09 19:39:22 +00:00
|
|
|
2: {queue: {length: 1}, build: {status: 'in-progress'}},
|
|
|
|
3: {
|
|
|
|
queue: {length: 0},
|
|
|
|
build: {status: 'error', error: {message: 'Some error'}}
|
|
|
|
},
|
|
|
|
4: 'Should never happend'
|
|
|
|
};
|
|
|
|
var onBuildUpdate = function(build, callback) {
|
|
|
|
expectUpdateBuild(distributor, build, number, conditionsHash);
|
|
|
|
number++;
|
|
|
|
callback(null, build)
|
|
|
|
};
|
|
|
|
|
2015-04-09 18:55:29 +00:00
|
|
|
distributor = new Distributor({
|
2015-04-09 19:39:22 +00:00
|
|
|
nodes: [{type: 'local', maxExecutorsCount: 1}],
|
|
|
|
onBuildUpdate: onBuildUpdate
|
2015-04-09 18:55:29 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2015-04-09 19:39:22 +00:00
|
|
|
it('should run with errors', function() {
|
2015-04-09 18:55:29 +00:00
|
|
|
distributor.run(project1, {}, function(err) {
|
|
|
|
expect(err).not.ok();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('wait for project done (should no errors)', function(done) {
|
2015-04-09 19:39:22 +00:00
|
|
|
setTimeout(done, 20);
|
2015-04-09 18:55:29 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
after(function() {
|
|
|
|
Distributor.prototype._createNode = originalCreateNode;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|