2016-08-01 11:17:15 +00:00
|
|
|
import "typings-test";
|
2016-05-05 17:30:24 +00:00
|
|
|
import taskbuffer = require("../dist/index");
|
2016-08-02 09:09:42 +00:00
|
|
|
import should = require("should");
|
2016-08-01 11:17:15 +00:00
|
|
|
import q = require("q")
|
2016-05-06 00:05:45 +00:00
|
|
|
|
2016-05-15 01:16:50 +00:00
|
|
|
// setup some testData to work with
|
2016-08-01 14:10:00 +00:00
|
|
|
let testTask: taskbuffer.Task;
|
|
|
|
let testTaskFunction = function () {
|
2016-08-01 11:17:15 +00:00
|
|
|
let done = q.defer();
|
2016-05-06 00:05:45 +00:00
|
|
|
console.log("main function executed!")
|
|
|
|
done.resolve();
|
|
|
|
return done.promise;
|
2016-08-01 14:10:00 +00: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-05-06 00:05:45 +00:00
|
|
|
let testPreTask = new taskbuffer.Task({
|
2016-08-01 14:10:00 +00:00
|
|
|
taskFunction: function () {
|
2016-08-01 11:17:15 +00:00
|
|
|
let done = q.defer();
|
2016-05-06 00:05:45 +00:00
|
|
|
console.log("preTask executed");
|
2016-08-01 11:17:15 +00:00
|
|
|
done.resolve();
|
|
|
|
return done.promise;
|
2016-05-06 00:05:45 +00:00
|
|
|
},
|
2016-08-01 14:10:00 +00:00
|
|
|
preTask: testTask
|
2016-05-06 00:05:45 +00:00
|
|
|
});
|
|
|
|
|
2016-08-01 14:10:00 +00: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
|
|
|
|
describe("taskbuffer", function () {
|
|
|
|
describe(".Task", function () {
|
|
|
|
it("new Task() should return a new task", function () {
|
|
|
|
testTask = new taskbuffer.Task({ taskFunction: testTaskFunction, preTask: testPreTask });
|
2016-05-04 00:49:43 +00:00
|
|
|
});
|
2016-08-01 14:10:00 +00:00
|
|
|
it("testTask should be and instance of Task", function () {
|
2016-05-05 17:30:24 +00:00
|
|
|
testTask.should.be.instanceof(taskbuffer.Task);
|
2016-05-04 00:49:43 +00:00
|
|
|
});
|
2016-08-01 14:10:00 +00:00
|
|
|
it("testTask.idle is true", function () {
|
|
|
|
if (!testTask.idle) {
|
2016-05-04 00:49:43 +00:00
|
|
|
throw new Error("testTask.idle is not true");
|
|
|
|
}
|
2016-08-01 14:10:00 +00:00
|
|
|
|
2016-05-04 00:49:43 +00:00
|
|
|
});
|
2016-08-01 14:10:00 +00:00
|
|
|
it("testTask.running is type boolean and initially false", function () {
|
2016-05-04 00:49:43 +00:00
|
|
|
testTask.running.should.be.type("boolean");
|
|
|
|
testTask.running.should.be.false();
|
|
|
|
});
|
2016-08-01 14:10:00 +00:00
|
|
|
it("testTask.trigger() should return Promise", function () {
|
2016-05-06 00:05:45 +00:00
|
|
|
testTask.trigger().should.be.Promise();
|
|
|
|
});
|
2016-08-01 14:10:00 +00:00
|
|
|
it("testTask.trigger() returned Promise should be fullfilled", function (done) {
|
2016-05-06 00:05:45 +00:00
|
|
|
testTask.trigger()
|
|
|
|
.then(done);
|
2016-05-13 03:14:29 +00:00
|
|
|
});
|
2016-08-01 14:10:00 +00:00
|
|
|
it("should run a task without pre and afterTask", function (done) {
|
|
|
|
let localTestTask = new taskbuffer.Task({ taskFunction: testTaskFunction });
|
2016-05-15 01:16:50 +00:00
|
|
|
localTestTask.trigger().then(done);
|
|
|
|
});
|
2016-08-01 14:10:00 +00: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 01:16:50 +00:00
|
|
|
});
|
2016-08-01 14:10:00 +00:00
|
|
|
describe("Taskchain", function () {
|
2016-05-15 01:16:50 +00:00
|
|
|
let testTaskchain;
|
|
|
|
let testTaskArray = [
|
|
|
|
new taskbuffer.Task({
|
2016-08-01 14:10:00 +00:00
|
|
|
name: "task1",
|
|
|
|
taskFunction: function () {
|
2016-08-01 11:17:15 +00:00
|
|
|
let done = q.defer();
|
2016-08-01 14:10:00 +00:00
|
|
|
setTimeout(done.resolve, 2000);
|
2016-05-15 01:16:50 +00:00
|
|
|
return done.promise;
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
new taskbuffer.Task({
|
2016-08-01 14:10:00 +00:00
|
|
|
name: "task2",
|
|
|
|
taskFunction: function () {
|
2016-08-01 11:17:15 +00:00
|
|
|
let done = q.defer();
|
2016-08-01 14:10:00 +00:00
|
|
|
setTimeout(done.resolve, 2000);
|
2016-05-15 01:16:50 +00:00
|
|
|
return done.promise;
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
];
|
2016-08-01 14:10:00 +00:00
|
|
|
it("should 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({
|
2016-08-01 14:10:00 +00:00
|
|
|
name: "Taskchain1",
|
|
|
|
taskArray: testTaskArray
|
2016-05-15 01:16:50 +00:00
|
|
|
});
|
|
|
|
testTaskchain.trigger().then(done);
|
|
|
|
});
|
2016-02-12 03:49:31 +00:00
|
|
|
});
|
2016-08-01 14:10:00 +00:00
|
|
|
describe("taskparallel", function () {
|
|
|
|
it("should run in Parallel", function (done) {
|
2016-08-01 11:17:15 +00:00
|
|
|
this.timeout("7000");
|
|
|
|
let testTaskparallel = new taskbuffer.Taskparallel({
|
2016-08-01 14:10:00 +00:00
|
|
|
taskArray: [task1, task2, task3]
|
2016-08-01 11:17:15 +00:00
|
|
|
});
|
|
|
|
testTaskparallel.trigger().then(() => {
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
})
|
2016-08-02 09:09:42 +00:00
|
|
|
});
|
|
|
|
describe("some flowtests",function(){
|
|
|
|
let flowTask1 = new taskbuffer.Task({
|
|
|
|
taskFunction: (x:number) => {
|
|
|
|
let done = q.defer();
|
|
|
|
console.log("flowTask1");
|
|
|
|
console.log(x);
|
|
|
|
done.resolve(x);
|
|
|
|
return done.promise;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
let flowTask2 = new taskbuffer.Task({
|
|
|
|
taskFunction: (x:number) => {
|
|
|
|
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);
|
|
|
|
});
|
|
|
|
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-08-01 11:17:15 +00:00
|
|
|
})
|
2016-02-12 03:49:31 +00:00
|
|
|
});
|