mirror of
https://gitlab.silvrtree.co.uk/martind2000/nci.git
synced 2025-01-25 19:06:16 +00:00
242 lines
5.4 KiB
JavaScript
242 lines
5.4 KiB
JavaScript
'use strict';
|
|
|
|
var Notifier = require('../lib/notifier').Notifier,
|
|
expect = require('expect.js'),
|
|
sinon = require('sinon'),
|
|
_ = require('underscore');
|
|
|
|
|
|
describe('notifier module', function() {
|
|
|
|
var notifier = new Notifier({});
|
|
|
|
function TestTransport() {
|
|
}
|
|
TestTransport.prototype.init = sinon.stub().callsArg(1);
|
|
TestTransport.prototype.send = sinon.stub().callsArg(1);
|
|
|
|
var sendSpy = TestTransport.prototype.send;
|
|
|
|
describe('test notifier', function() {
|
|
it('should be rigestered', function() {
|
|
notifier.register('test', TestTransport);
|
|
});
|
|
|
|
it('should be intialized without errors', function(done) {
|
|
notifier.init({}, done);
|
|
});
|
|
|
|
it('init method should be called once during init', function() {
|
|
expect(TestTransport.prototype.init.calledOnce).equal(true);
|
|
});
|
|
});
|
|
|
|
var build;
|
|
|
|
describe('exceptions', function() {
|
|
it('set build to uncompleted', function() {
|
|
build = {completed: false};
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('error should be thrown for uncompleted build', function(done) {
|
|
notifier.send(build, function(err) {
|
|
expect(err).ok();
|
|
expect(err.message).match(/Build should be completed/);
|
|
expect(sendSpy.calledOnce).equal(false);
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('set build to completed', function() {
|
|
build = {completed: true, status: 'done', project: {}};
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('will do nothing if notify section isn`t set for project', function(done) {
|
|
notifier.send(build, function(err) {
|
|
expect(err).not.ok();
|
|
expect(sendSpy.calledOnce).equal(false);
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
|
|
var makeBuild = function(build) {
|
|
var project = build.project;
|
|
delete build.project;
|
|
|
|
var notify = project.notify;
|
|
delete project.notify;
|
|
|
|
return _({
|
|
completed: true,
|
|
project: {
|
|
notify: _({
|
|
to: {test: ['recipient1', 'recipient2']}
|
|
}).extend(notify)
|
|
}
|
|
}).extend(build);
|
|
};
|
|
|
|
describe('notify on done', function() {
|
|
it('set build info', function() {
|
|
build = makeBuild({
|
|
status: 'done',
|
|
project: {notify: {on: ['done']}}
|
|
});
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('should notify when build is done', function(done) {
|
|
notifier.send(build, function(err) {
|
|
expect(err).not.ok();
|
|
expect(sendSpy.calledOnce).equal(true);
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should be notified with right params', function() {
|
|
expect(sendSpy.calledWith({
|
|
notifyReason: {strategy: 'done'},
|
|
build: build
|
|
})).equal(true);
|
|
});
|
|
|
|
it('set build to error', function() {
|
|
build.status = 'error';
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('should not notify when build is error', function(done) {
|
|
notifier.send(build, function(err) {
|
|
expect(err).not.ok();
|
|
expect(sendSpy.calledOnce).equal(false);
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('notify on error', function() {
|
|
it('set build info', function() {
|
|
build = makeBuild({
|
|
status: 'error',
|
|
project: {notify: {on: ['error']}}
|
|
});
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('should notify when build with error', function(done) {
|
|
notifier.send(build, function(err) {
|
|
expect(err).not.ok();
|
|
expect(sendSpy.calledOnce).equal(true);
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should be notified with right params', function() {
|
|
expect(sendSpy.calledWith({
|
|
notifyReason: {strategy: 'error'},
|
|
build: build
|
|
})).equal(true);
|
|
});
|
|
|
|
it('set build to done', function() {
|
|
build.status = 'done';
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('should not notify when build is done', function(done) {
|
|
notifier.send(build, function(err) {
|
|
expect(err).not.ok();
|
|
expect(sendSpy.calledOnce).equal(false);
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
|
|
var prevBuild;
|
|
|
|
// for all previos build related strategies
|
|
describe('Stub getting of previos build', function() {
|
|
it('', function() {
|
|
sinon.stub(notifier, '_getPrevBuild', function(build, callback) {
|
|
callback(null, prevBuild);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('notify on change', function() {
|
|
it('set build info', function() {
|
|
build = makeBuild({
|
|
number: 1,
|
|
status: 'done',
|
|
project: {notify: {on: ['change']}}
|
|
});
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('should notify for the first build (without get prev build)',
|
|
function(done) {
|
|
notifier._getPrevBuild.reset();
|
|
notifier.send(build, function(err) {
|
|
expect(err).not.ok();
|
|
expect(sendSpy.calledOnce).equal(true);
|
|
expect(notifier._getPrevBuild.calledOnce).equal(false);
|
|
done();
|
|
});
|
|
}
|
|
);
|
|
|
|
it('should be notified with right params', function() {
|
|
expect(sendSpy.calledWith({
|
|
notifyReason: {strategy: 'change'},
|
|
build: build
|
|
})).equal(true);
|
|
});
|
|
|
|
it('set previos build info (same status)', function() {
|
|
build.number = 2;
|
|
prevBuild = _(build).clone();
|
|
prevBuild.number = 1;
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('should not notify when same previos build status', function(done) {
|
|
notifier.send(build, function(err) {
|
|
expect(err).not.ok();
|
|
expect(sendSpy.calledOnce).equal(false);
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('set previos build info (changed status)', function() {
|
|
prevBuild.status = 'error';
|
|
sendSpy.reset();
|
|
});
|
|
|
|
it('should notify when status is changed', function(done) {
|
|
notifier.send(build, function(err) {
|
|
expect(err).not.ok();
|
|
expect(sendSpy.calledOnce).equal(true);
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should be notified with right params', function() {
|
|
expect(sendSpy.calledWith({
|
|
notifyReason: {strategy: 'change'},
|
|
build: build
|
|
})).equal(true);
|
|
});
|
|
|
|
});
|
|
|
|
describe('Restore getting of previos build', function() {
|
|
it('', function() {
|
|
notifier._getPrevBuild.restore();
|
|
});
|
|
});
|
|
|
|
});
|