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