taskbuffer/test/test.js

213 lines
16 KiB
JavaScript
Raw Normal View History

2016-05-05 17:30:24 +00:00
"use strict";
2016-08-01 11:17:15 +00:00
require("typings-test");
2016-07-31 22:53:27 +00:00
const taskbuffer = require("../dist/index");
2017-02-15 21:52:29 +00:00
const smartchai_1 = require("smartchai");
const q = require("smartq");
2016-05-15 01:16:50 +00:00
// setup some testData to work with
2016-07-31 22:53:27 +00:00
let testTask;
let testTaskFunction = function () {
2016-08-01 11:17:15 +00:00
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('main function executed!');
2016-05-06 00:05:45 +00:00
done.resolve();
return done.promise;
};
2016-08-01 14:10:00 +00:00
let testTaskFunctionTimeout = function () {
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('main function started!');
2016-08-01 14:10:00 +00:00
setTimeout(() => {
2017-02-15 21:52:29 +00:00
console.log('main function ended!');
2016-08-01 14:10:00 +00:00
done.resolve();
}, 2000);
return done.promise;
};
2016-07-31 22:53:27 +00:00
let testPreTask = new taskbuffer.Task({
2016-05-14 02:28:22 +00:00
taskFunction: function () {
2016-08-01 11:17:15 +00:00
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('preTask executed');
2016-08-01 11:17:15 +00:00
done.resolve();
return done.promise;
2016-05-14 02:28:22 +00:00
},
preTask: testTask
});
2016-08-01 14:10:00 +00:00
// some more tasks to wirj with
let task1 = new taskbuffer.Task({
2017-02-15 21:52:29 +00:00
name: 'Task 1',
2016-08-01 14:10:00 +00:00
taskFunction: () => {
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('Task1 started');
2016-08-01 14:10:00 +00:00
setTimeout(() => {
2017-02-15 21:52:29 +00:00
console.log('Task1 executed');
2016-08-01 14:10:00 +00:00
done.resolve();
}, 5000);
return done.promise;
}
});
let task2 = new taskbuffer.Task({
2017-02-15 21:52:29 +00:00
name: 'Task 1',
2016-08-01 14:10:00 +00:00
taskFunction: () => {
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('Task2 started');
2016-08-01 14:10:00 +00:00
setTimeout(() => {
2017-02-15 21:52:29 +00:00
console.log('Task2 executed');
2016-08-01 14:10:00 +00:00
done.resolve();
}, 5000);
return done.promise;
}
});
let task3 = new taskbuffer.Task({
2017-02-15 21:52:29 +00:00
name: 'Task 3',
2016-08-01 14:10:00 +00:00
taskFunction: () => {
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('Task3 started');
2016-08-01 14:10:00 +00:00
setTimeout(() => {
2017-02-15 21:52:29 +00:00
console.log('Task3 executed');
2016-08-01 14:10:00 +00:00
done.resolve();
}, 5000);
return done.promise;
}
});
// the actual tests
2017-02-15 21:52:29 +00:00
describe('taskbuffer', function () {
describe('.Task', function () {
it('new Task() should return a new task', function () {
2016-05-06 00:05:45 +00:00
testTask = new taskbuffer.Task({ taskFunction: testTaskFunction, preTask: testPreTask });
2016-05-04 00:49:43 +00:00
});
2017-02-15 21:52:29 +00:00
it('testTask should be and instance of Task', function () {
smartchai_1.expect(testTask).to.be.instanceof(taskbuffer.Task);
2016-05-04 00:49:43 +00:00
});
2017-02-15 21:52:29 +00:00
it('testTask.idle is true', function () {
2016-05-04 00:49:43 +00:00
if (!testTask.idle) {
2017-02-15 21:52:29 +00:00
throw new Error('testTask.idle is not true');
2016-05-04 00:49:43 +00:00
}
});
2017-02-15 21:52:29 +00:00
it('testTask.running is type boolean and initially false', function () {
smartchai_1.expect(testTask.running).to.be.a('boolean');
smartchai_1.expect(testTask.running).to.be.false;
2016-02-12 03:49:31 +00:00
});
2017-02-15 21:52:29 +00:00
it('testTask.trigger() expect return Promise', function () {
smartchai_1.expect(testTask.trigger()).to.be.instanceof(Promise);
2016-05-06 00:05:45 +00:00
});
2017-02-15 21:52:29 +00:00
it('testTask.trigger() returned Promise expect be fullfilled', function (done) {
2016-05-06 00:05:45 +00:00
testTask.trigger()
.then(done);
});
2017-02-15 21:52:29 +00:00
it('expect run a task without pre and afterTask', function (done) {
2016-07-31 22:53:27 +00:00
let localTestTask = new taskbuffer.Task({ taskFunction: testTaskFunction });
2016-05-15 01:16:50 +00:00
localTestTask.trigger().then(done);
});
2017-02-15 21:52:29 +00:00
it('expect run buffered', function (done) {
2016-08-01 14:10:00 +00:00
this.timeout(10000);
let localTestTask = new taskbuffer.Task({
taskFunction: testTaskFunctionTimeout,
buffered: true,
bufferMax: 2
});
localTestTask.trigger();
localTestTask.trigger();
localTestTask.trigger();
localTestTask.trigger().then(() => {
done();
});
});
2016-05-15 01:16:50 +00:00
});
2017-02-15 21:52:29 +00:00
describe('Taskchain', function () {
2016-07-31 22:53:27 +00:00
let testTaskchain;
let testTaskArray = [
2016-05-15 01:16:50 +00:00
new taskbuffer.Task({
2017-02-15 21:52:29 +00:00
name: 'task1',
2016-05-15 01:16:50 +00:00
taskFunction: function () {
2016-08-01 11:17:15 +00:00
let done = q.defer();
2016-05-15 13:52:59 +00:00
setTimeout(done.resolve, 2000);
2016-05-15 01:16:50 +00:00
return done.promise;
}
}),
new taskbuffer.Task({
2017-02-15 21:52:29 +00:00
name: 'task2',
2016-05-15 01:16:50 +00:00
taskFunction: function () {
2016-08-01 11:17:15 +00:00
let done = q.defer();
2016-05-15 13:52:59 +00:00
setTimeout(done.resolve, 2000);
2016-05-15 01:16:50 +00:00
return done.promise;
}
2017-02-15 21:52:29 +00:00
})
2016-05-15 01:16:50 +00:00
];
2017-02-15 21:52:29 +00:00
it('expect run tasks in sequence', function (done) {
2016-05-15 13:52:59 +00:00
this.timeout(5000);
2016-05-15 01:16:50 +00:00
testTaskchain = new taskbuffer.Taskchain({
2017-02-15 21:52:29 +00:00
name: 'Taskchain1',
2016-05-15 01:16:50 +00:00
taskArray: testTaskArray
});
testTaskchain.trigger().then(done);
});
2016-02-12 03:49:31 +00:00
});
2017-02-15 21:52:29 +00:00
describe('taskparallel', function () {
it('expect run in Parallel', function (done) {
2017-01-20 20:36:18 +00:00
this.timeout(7000);
2016-08-01 11:17:15 +00:00
let testTaskparallel = new taskbuffer.Taskparallel({
taskArray: [task1, task2, task3]
});
testTaskparallel.trigger().then(() => {
done();
});
});
});
2017-02-15 21:52:29 +00:00
describe('some flowtests', function () {
let flowTask1 = new taskbuffer.Task({
taskFunction: (x) => {
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('flowTask1');
console.log(x);
done.resolve(x);
return done.promise;
}
});
2016-08-03 12:51:43 +00:00
let flowTaskBuffered = new taskbuffer.Task({
taskFunction: (x) => {
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('flowTask1');
2016-08-03 12:51:43 +00:00
console.log(x);
done.resolve(x);
return done.promise;
},
buffered: true,
bufferMax: 1
});
let flowTask2 = new taskbuffer.Task({
taskFunction: (x) => {
let done = q.defer();
2017-02-15 21:52:29 +00:00
console.log('flowTask2');
console.log(x);
done.resolve(x);
return done.promise;
},
preTask: flowTask1
});
let flowTask3 = new taskbuffer.Taskchain({
taskArray: [flowTask1, flowTask2]
});
2017-02-15 21:52:29 +00:00
it('should let a value flow through a task', function (done) {
flowTask1.trigger(12).then((x) => {
2017-02-15 21:52:29 +00:00
smartchai_1.expect(x).to.equal(12);
done();
}).catch(done);
});
2017-02-15 21:52:29 +00:00
it('should let a values flow between tasks', function (done) {
flowTask2.trigger(12).then((x) => {
2017-02-15 21:52:29 +00:00
smartchai_1.expect(x).to.equal(12);
done();
}).catch(done);
});
2017-02-15 21:52:29 +00:00
it('expect let a values flow between tasks when buffered', function (done) {
2016-08-03 12:51:43 +00:00
flowTaskBuffered.trigger(12).then((x) => {
2017-02-15 21:52:29 +00:00
smartchai_1.expect(x).to.equal(12);
2016-08-03 12:51:43 +00:00
done();
}).catch(done);
});
2017-02-15 21:52:29 +00:00
it('should let a values flow between tasks in Taskchain', function (done) {
flowTask3.trigger(12).then((x) => {
2017-02-15 21:52:29 +00:00
smartchai_1.expect(x).to.equal(12);
done();
}).catch(done);
});
});
2016-02-12 03:49:31 +00:00
});
2017-02-15 21:52:29 +00:00
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHdCQUFxQjtBQUNyQiw0Q0FBNEM7QUFDNUMseUNBQWtDO0FBQ2xDLDRCQUEyQjtBQUUzQixtQ0FBbUM7QUFDbkMsSUFBSSxRQUF5QixDQUFBO0FBQzdCLElBQUksZ0JBQWdCLEdBQUc7SUFDckIsSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFBO0lBQ3BCLE9BQU8sQ0FBQyxHQUFHLENBQUMseUJBQXlCLENBQUMsQ0FBQTtJQUN0QyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDZCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUNyQixDQUFDLENBQUE7QUFFRCxJQUFJLHVCQUF1QixHQUFHO0lBQzVCLElBQUksSUFBSSxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUNwQixPQUFPLENBQUMsR0FBRyxDQUFDLHdCQUF3QixDQUFDLENBQUE7SUFDckMsVUFBVSxDQUFDO1FBQ1QsT0FBTyxDQUFDLEdBQUcsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFBO1FBQ25DLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQTtJQUNoQixDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUE7SUFDUixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUNyQixDQUFDLENBQUE7QUFFRCxJQUFJLFdBQVcsR0FBRyxJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUM7SUFDcEMsWUFBWSxFQUFFO1FBQ1osSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFBO1FBQ3BCLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQTtRQUMvQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7UUFDZCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtJQUNyQixDQUFDO0lBQ0QsT0FBTyxFQUFFLFFBQVE7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