2016-03-12 10:21:16 +01:00
|
|
|
"use strict";
|
2016-05-25 05:23:48 +02:00
|
|
|
require("typings-global");
|
2016-02-20 00:53:23 +01:00
|
|
|
var plugins = require("./npmts.plugins");
|
|
|
|
var paths = require("./npmts.paths");
|
2016-05-17 02:32:40 +02:00
|
|
|
var npmts_promisechain_1 = require("./npmts.promisechain");
|
2016-03-30 01:32:41 +02:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
var istanbul = function (configArg) {
|
2016-05-21 19:41:18 +02:00
|
|
|
npmts_promisechain_1.npmtsOra.text("Instrumentalizing transpiled JS...");
|
2016-03-30 01:32:41 +02:00
|
|
|
var done = plugins.Q.defer();
|
|
|
|
var stream = plugins.gulp.src([plugins.path.join(paths.cwd, "dist/*.js")])
|
2016-07-08 04:00:52 +02:00
|
|
|
.pipe(plugins.g.sourcemaps.init())
|
2016-03-30 01:32:41 +02:00
|
|
|
.pipe(plugins.g.istanbul()) // Covering files
|
2016-07-08 04:00:52 +02:00
|
|
|
.pipe(plugins.g.sourcemaps.write())
|
2016-03-30 01:32:41 +02:00
|
|
|
.pipe(plugins.g.istanbul.hookRequire()) // Force `require` to return covered files
|
|
|
|
.pipe(plugins.g.gFunction(function () {
|
2016-05-21 19:41:18 +02:00
|
|
|
plugins.beautylog.ok("JS has been instrumentalized to get test code coverage!");
|
2016-03-30 01:32:41 +02:00
|
|
|
done.resolve(configArg);
|
|
|
|
}, "atEnd"));
|
|
|
|
return done.promise;
|
|
|
|
};
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
var mocha = function (configArg) {
|
|
|
|
var done = plugins.Q.defer();
|
2016-05-21 19:41:18 +02:00
|
|
|
npmts_promisechain_1.npmtsOra.end(); // end npmtsOra for tests.
|
2016-03-30 01:32:41 +02:00
|
|
|
var stream = plugins.gulp.src(["./test/test.js"])
|
|
|
|
.pipe(plugins.g.mocha())
|
|
|
|
.pipe(plugins.g.istanbul.writeReports()) // Creating the reports after tests ran
|
|
|
|
.pipe(plugins.g.gFunction(function () {
|
|
|
|
plugins.beautylog.ok("Tests have passed!");
|
|
|
|
done.resolve(configArg);
|
|
|
|
}, "atEnd"));
|
|
|
|
return done.promise;
|
|
|
|
};
|
|
|
|
var coverage = function (configArg) {
|
|
|
|
var done = plugins.Q.defer();
|
|
|
|
plugins.smartcov.get.percentage(plugins.path.join(paths.coverageDir, "lcov.info"))
|
|
|
|
.then(function (percentageArg) {
|
|
|
|
if (percentageArg >= configArg.coverageTreshold) {
|
2016-03-30 15:26:53 +02:00
|
|
|
plugins.beautylog.ok("your coverage of " + percentageArg.toString().blue + "% ".blue + "exceeds your treshold of " +
|
|
|
|
configArg.coverageTreshold.toString().blue + "%".blue);
|
2016-03-30 01:32:41 +02:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
plugins.beautylog.warn("your coverage of " + percentageArg + "% " + "fails your treshold of " +
|
|
|
|
configArg.coverageTreshold + "%");
|
|
|
|
plugins.beautylog.error("exiting due to coverage failure");
|
|
|
|
process.exit(1);
|
|
|
|
}
|
|
|
|
done.resolve(configArg);
|
|
|
|
});
|
|
|
|
return done.promise;
|
|
|
|
};
|
2016-02-20 00:53:23 +01:00
|
|
|
exports.run = function (configArg) {
|
2016-02-22 22:22:39 +01:00
|
|
|
var done = plugins.Q.defer();
|
2016-02-20 00:53:23 +01:00
|
|
|
var config = configArg;
|
2016-06-16 03:24:01 +02:00
|
|
|
if (config.notest != true) {
|
2016-06-16 03:02:33 +02:00
|
|
|
npmts_promisechain_1.npmtsOra.text("now starting tests");
|
|
|
|
plugins.beautylog.log("-------------------------------------------------------\n" +
|
|
|
|
"*************************** TESTS: ***************************\n" +
|
|
|
|
"--------------------------------------------------------------");
|
|
|
|
istanbul(config)
|
|
|
|
.then(mocha)
|
|
|
|
.then(coverage)
|
|
|
|
.then(function () {
|
|
|
|
done.resolve(config);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
2016-06-16 03:24:01 +02:00
|
|
|
npmts_promisechain_1.npmtsOra.end();
|
2016-06-16 03:02:33 +02:00
|
|
|
done.resolve(config);
|
|
|
|
}
|
2016-02-20 00:53:23 +01:00
|
|
|
return done.promise;
|
|
|
|
};
|