"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"]}