gulp-function/test/test.js
2016-06-04 01:14:25 +02:00

104 lines
13 KiB
JavaScript

"use strict";
require("typings-test");
var gulp = require("gulp");
var gulpFunction = require("../dist/index.js");
var beautylog = require("beautylog");
var Q = require("q");
var myFunction = function () {
var done = Q.defer();
beautylog.log("Function executed");
done.resolve();
return done.promise;
};
var myFunction2 = function () {
var done = Q.defer();
beautylog.ok("Function2 executed");
done.resolve();
return done.promise;
};
var myFunction3 = function () {
var done = Q.defer();
beautylog.success("Function3 executed");
done.resolve();
return done.promise;
};
var beforeFunction = function () {
var done = Q.defer();
beautylog.success("beforeFunction executed");
done.resolve();
return done.promise;
};
var middleFunctionRun = false;
var middleFunction = function () {
var done = Q.defer();
beautylog.success("middleFunction executed");
setTimeout(function () {
beautylog.log("timeout fired");
middleFunctionRun = true;
done.resolve();
}, 500);
return done.promise;
};
var afterFunction = function () {
var done = Q.defer();
beautylog.success("afterFunction executed");
done.resolve();
return done.promise;
};
var timeoutFunction = function () {
var done = Q.defer();
setTimeout(function () {
beautylog.log("largeTimeout fired");
done.resolve();
}, 2000);
return done.promise;
};
describe("gulpFunction", function () {
it("should run through smoothly with " + "'forEach'".blue, function (done) {
gulp.src('./test/*.md')
.pipe(gulpFunction(myFunction, 'forEach'))
.pipe(gulp.dest("./test/result/"));
gulp.src('./test/*.md')
.pipe(gulpFunction([myFunction2, myFunction3], 'forEach'))
.pipe(gulp.dest("./test/result/"))
.pipe(gulpFunction(done, "atEnd"));
});
it("should run through smoothly with " + "'atEnd'".blue, function (done) {
gulp.src('./test/*.md')
.pipe(gulpFunction(myFunction, 'atEnd'))
.pipe(gulp.dest("./test/result/"));
gulp.src('./test/*.md')
.pipe(gulpFunction([myFunction2, myFunction3], 'atEnd'))
.pipe(gulp.dest("./test/result/"))
.pipe(gulpFunction(done, "atEnd"));
});
it("should run through smoothly once with " + "'atFirst'".blue, function (done) {
gulp.src('./test/*.md')
.pipe(gulpFunction([myFunction2, myFunction3], 'forFirst'))
.pipe(gulp.dest("./test/result/"))
.pipe(gulpFunction(done, "atEnd"));
});
it("should run in order", function (done) {
this.timeout(5000);
var stream = gulp.src('./test/*.md')
.pipe(gulpFunction([beforeFunction, middleFunction, middleFunction], 'atEnd'))
.pipe(gulpFunction(function () {
beautylog.log("stream progressed");
var done2 = Q.defer();
done2.resolve();
return done2.promise;
}, "forEach"))
.pipe(gulpFunction(function () {
beautylog.log("nextStep");
}))
.pipe(gulpFunction(afterFunction, "atEnd"))
.pipe(gulpFunction(timeoutFunction, "atEnd"));
stream.on("finish", function () {
beautylog.info("stream finished");
done();
});
});
});
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test.ts"],"names":[],"mappings":"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","file":"test.js","sourcesContent":["import \"typings-test\"\r\nvar gulp = require(\"gulp\");\r\nvar gulpFunction = require(\"../dist/index.js\");\r\nvar beautylog = require(\"beautylog\");\r\nvar Q = require(\"q\");\r\n\r\nvar myFunction = function () {\r\n    var done = Q.defer()\r\n    beautylog.log(\"Function executed\");\r\n    done.resolve();\r\n    return done.promise;\r\n};\r\nvar myFunction2 = function () {\r\n    var done = Q.defer();\r\n    beautylog.ok(\"Function2 executed\");\r\n    done.resolve();\r\n    return done.promise;\r\n};\r\nvar myFunction3 = function () {\r\n    var done = Q.defer();\r\n    beautylog.success(\"Function3 executed\");\r\n    done.resolve();\r\n    return done.promise;\r\n};\r\n\r\nvar beforeFunction = function () {\r\n    var done = Q.defer();\r\n    beautylog.success(\"beforeFunction executed\");\r\n    done.resolve();\r\n    return done.promise;\r\n};\r\n\r\nvar middleFunctionRun = false;\r\n\r\nvar middleFunction = function () {\r\n    var done = Q.defer();\r\n    beautylog.success(\"middleFunction executed\");\r\n    setTimeout(function(){\r\n        beautylog.log(\"timeout fired\");\r\n        middleFunctionRun = true;\r\n        done.resolve();\r\n    }, 500);\r\n    return done.promise;\r\n};\r\n\r\nvar afterFunction = function () {\r\n    var done = Q.defer();\r\n    beautylog.success(\"afterFunction executed\");\r\n    done.resolve();\r\n    return done.promise;\r\n};\r\n\r\nlet timeoutFunction = function(){\r\n    var done = Q.defer();\r\n    setTimeout(function(){\r\n        beautylog.log(\"largeTimeout fired\");\r\n        done.resolve();\r\n    },2000);\r\n    return done.promise;\r\n};\r\n\r\n\r\n\r\ndescribe(\"gulpFunction\",function(){\r\n    it(\"should run through smoothly with \" + \"'forEach'\".blue,function(done){\r\n        gulp.src('./test/*.md')\r\n            .pipe(gulpFunction(myFunction,'forEach'))\r\n            .pipe(gulp.dest(\"./test/result/\"));\r\n\r\n        gulp.src('./test/*.md')\r\n            .pipe(gulpFunction([myFunction2,myFunction3],'forEach'))\r\n            .pipe(gulp.dest(\"./test/result/\"))\r\n            .pipe(gulpFunction(done,\"atEnd\"));\r\n\r\n    });\r\n\r\n    it(\"should run through smoothly with \" + \"'atEnd'\".blue,function(done){\r\n        gulp.src('./test/*.md')\r\n            .pipe(gulpFunction(myFunction,'atEnd'))\r\n            .pipe(gulp.dest(\"./test/result/\"));\r\n\r\n        gulp.src('./test/*.md')\r\n            .pipe(gulpFunction([myFunction2,myFunction3],'atEnd'))\r\n            .pipe(gulp.dest(\"./test/result/\"))\r\n            .pipe(gulpFunction(done,\"atEnd\"));\r\n    });\r\n\r\n    it(\"should run through smoothly once with \" + \"'atFirst'\".blue,function(done){\r\n\r\n        gulp.src('./test/*.md')\r\n            .pipe(gulpFunction([myFunction2,myFunction3],'forFirst'))\r\n            .pipe(gulp.dest(\"./test/result/\"))\r\n            .pipe(gulpFunction(done,\"atEnd\"));\r\n    });\r\n\r\n    it(\"should run in order\",function(done){\r\n        this.timeout(5000);\r\n        let stream = gulp.src('./test/*.md')\r\n            .pipe(gulpFunction([beforeFunction,middleFunction,middleFunction],'atEnd'))\r\n            .pipe(gulpFunction(function(){\r\n                beautylog.log(\"stream progressed\");\r\n                var done2 = Q.defer();\r\n                done2.resolve();\r\n                return done2.promise;\r\n            },\"forEach\"))\r\n            .pipe(gulpFunction(function(){\r\n                beautylog.log(\"nextStep\");\r\n            }))\r\n            .pipe(gulpFunction(afterFunction,\"atEnd\"))\r\n            .pipe(gulpFunction(timeoutFunction,\"atEnd\"));\r\n\r\n        stream.on(\"finish\",function(){\r\n            beautylog.info(\"stream finished\");\r\n            done();\r\n        });\r\n    });\r\n});\r\n\r\n"]}