tscoverage/dist/npmts.tests.js

77 lines
2.9 KiB
JavaScript
Raw Normal View History

2016-03-12 10:21:16 +01:00
"use strict";
2016-02-20 00:53:23 +01:00
/// <reference path="./typings/main.d.ts" />
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-26 14:08:48 +01:00
exports.publishCoverage = function (configArg) {
var done = plugins.Q.defer();
2016-04-04 16:57:09 +02:00
plugins.beautylog.log("now uploading coverage data to codecov.io");
2016-03-26 14:08:48 +01:00
var stream = plugins.gulp.src([plugins.path.join(paths.cwd, "./coverage/lcov.info")])
2016-04-02 19:09:11 +02:00
.pipe(plugins.g.codecov())
2016-03-26 17:35:55 +01:00
.pipe(plugins.g.gFunction(function () {
2016-04-04 16:57:09 +02:00
plugins.beautylog.ok("Coverage data has been uploaded to codecov.io!");
2016-03-26 14:08:48 +01:00
done.resolve(configArg);
2016-03-26 17:35:55 +01:00
}, "atEnd"));
2016-03-26 14:08:48 +01:00
return done.promise;
};
2016-03-30 01:32:41 +02:00
/**
*
* @returns {*}
*/
var istanbul = function (configArg) {
var done = plugins.Q.defer();
var stream = plugins.gulp.src([plugins.path.join(paths.cwd, "dist/*.js")])
.pipe(plugins.g.istanbul()) // Covering files
.pipe(plugins.g.istanbul.hookRequire()) // Force `require` to return covered files
.pipe(plugins.g.gFunction(function () {
done.resolve(configArg);
}, "atEnd"));
return done.promise;
};
/**
*
* @returns {*}
*/
var mocha = function (configArg) {
var done = plugins.Q.defer();
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-05-17 02:32:40 +02:00
npmts_promisechain_1.npmtsOra.text("now starting tests");
plugins.beautylog.log("-------------------------------------------------------\n" +
"*************************** TESTS: ***************************\n" +
2016-03-27 12:32:55 +02:00
"--------------------------------------------------------------");
2016-03-30 01:32:41 +02:00
istanbul(config)
.then(mocha)
.then(coverage)
.then(done.resolve);
2016-02-20 00:53:23 +01:00
return done.promise;
};