2016-03-12 09:21:16 +00:00
|
|
|
"use strict";
|
2017-01-15 19:01:10 +00:00
|
|
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
|
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
|
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
|
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
|
|
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
|
|
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
|
|
});
|
|
|
|
};
|
2017-02-27 21:19:14 +00:00
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
2016-10-21 15:48:52 +00:00
|
|
|
/* ------------------------------------------
|
|
|
|
* This module tests the compiled TypeScript files
|
|
|
|
* -------------------------------------------- */
|
2017-11-28 16:33:55 +00:00
|
|
|
const plugins = require("./mod.plugins");
|
2016-10-21 15:48:52 +00:00
|
|
|
const paths = require("../npmts.paths");
|
2017-01-17 23:58:09 +00:00
|
|
|
const q = require("smartq");
|
2017-10-05 12:58:49 +00:00
|
|
|
let testTypeScriptConfig = {
|
|
|
|
target: 'ES5',
|
|
|
|
emitDecoratorMetadata: true,
|
|
|
|
experimentalDecorators: true,
|
2018-04-08 23:03:39 +00:00
|
|
|
lib: ['DOM', 'ESNext']
|
2017-10-05 12:58:49 +00:00
|
|
|
};
|
2016-03-29 23:32:41 +00:00
|
|
|
/**
|
2016-09-25 18:22:10 +00:00
|
|
|
* runs mocha
|
|
|
|
* @returns INpmtsConfig
|
2016-03-29 23:32:41 +00:00
|
|
|
*/
|
2017-03-04 20:49:10 +00:00
|
|
|
let tap = function (configArg) {
|
2016-10-02 18:35:13 +00:00
|
|
|
let done = q.defer();
|
2017-03-04 20:49:10 +00:00
|
|
|
/**
|
|
|
|
* the TabBuffer for npmts
|
|
|
|
*/
|
|
|
|
let npmtsTapBuffer = new plugins.tapbuffer.TabBuffer();
|
2017-06-17 08:47:07 +00:00
|
|
|
npmtsTapBuffer.setConfig(configArg.testConfig);
|
2017-03-04 20:49:10 +00:00
|
|
|
/**
|
|
|
|
* handle the testable files
|
|
|
|
*/
|
|
|
|
let testableFilesSmartstream = new plugins.smartstream.Smartstream([
|
2017-05-01 20:43:32 +00:00
|
|
|
plugins.smartgulp.src([plugins.path.join(paths.cwd, './ts/**/*.ts')]),
|
2016-11-24 23:36:44 +00:00
|
|
|
plugins.gulpSourcemaps.init(),
|
2017-10-05 12:58:49 +00:00
|
|
|
plugins.gulpTypeScript(testTypeScriptConfig),
|
2017-05-13 08:21:55 +00:00
|
|
|
plugins.gulpSourcemaps.write(),
|
2017-03-04 20:49:10 +00:00
|
|
|
npmtsTapBuffer.pipeTestableFiles(),
|
|
|
|
plugins.smartstream.cleanPipe()
|
2016-11-24 23:36:44 +00:00
|
|
|
]);
|
2017-03-04 20:49:10 +00:00
|
|
|
/**
|
|
|
|
* handle the test files
|
|
|
|
*/
|
|
|
|
let testFilesSmartstream = new plugins.smartstream.Smartstream([
|
2017-05-01 20:43:32 +00:00
|
|
|
plugins.smartgulp.src([plugins.path.join(paths.cwd, 'test/*.ts')]),
|
2017-05-13 08:21:55 +00:00
|
|
|
plugins.gulpSourcemaps.init(),
|
2017-10-05 12:58:49 +00:00
|
|
|
plugins.gulpTypeScript(testTypeScriptConfig),
|
2017-05-13 08:21:55 +00:00
|
|
|
plugins.gulpSourcemaps.write(),
|
2017-03-04 20:49:10 +00:00
|
|
|
npmtsTapBuffer.pipeTestFiles(),
|
|
|
|
plugins.smartstream.cleanPipe()
|
2016-11-24 23:36:44 +00:00
|
|
|
]);
|
2017-03-04 20:49:10 +00:00
|
|
|
// lets run the smartstream
|
2018-04-08 23:03:39 +00:00
|
|
|
Promise.all([testableFilesSmartstream.run(), testFilesSmartstream.run()]).then(() => __awaiter(this, void 0, void 0, function* () {
|
2017-03-31 17:18:18 +00:00
|
|
|
configArg.runData.coverageLcovInfo = yield npmtsTapBuffer.runTests();
|
2017-03-04 20:49:10 +00:00
|
|
|
done.resolve(configArg);
|
2018-04-08 23:03:39 +00:00
|
|
|
}), err => {
|
2017-03-04 20:49:10 +00:00
|
|
|
plugins.beautylog.error('Tests failed!');
|
2016-11-24 23:36:44 +00:00
|
|
|
console.log(err);
|
2017-03-04 20:49:10 +00:00
|
|
|
if (configArg.watch) {
|
|
|
|
done.resolve(configArg);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
process.exit(1);
|
|
|
|
}
|
2016-07-15 16:18:11 +00:00
|
|
|
});
|
2016-03-29 23:32:41 +00:00
|
|
|
return done.promise;
|
|
|
|
};
|
2017-03-31 17:18:18 +00:00
|
|
|
let handleCoverageData = (configArg) => __awaiter(this, void 0, void 0, function* () {
|
2017-05-04 22:01:21 +00:00
|
|
|
let coverageResult = 0; // the coverage in percent
|
|
|
|
if (configArg.runData.coverageLcovInfo) {
|
|
|
|
coverageResult = yield plugins.smartcov.get.percentageFromLcovString(configArg.runData.coverageLcovInfo, 2);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
plugins.beautylog.warn('Hey... Did your tests import and use your module that you are trying to test?');
|
|
|
|
}
|
2017-03-31 17:18:18 +00:00
|
|
|
if (coverageResult >= configArg.coverageTreshold) {
|
2018-04-08 23:03:39 +00:00
|
|
|
plugins.beautylog.ok(`${coverageResult.toString()}% ` +
|
|
|
|
`coverage exceeds your treshold of ` +
|
|
|
|
`${configArg.coverageTreshold.toString()}%`);
|
2017-03-04 20:49:10 +00:00
|
|
|
}
|
|
|
|
else {
|
2018-04-08 23:03:39 +00:00
|
|
|
plugins.beautylog.warn(`${coverageResult.toString()}% ` +
|
|
|
|
`coverage fails your treshold of ` +
|
|
|
|
`${configArg.coverageTreshold.toString()}%`);
|
2017-03-04 20:49:10 +00:00
|
|
|
plugins.beautylog.error('exiting due to coverage failure');
|
|
|
|
if (!configArg.watch) {
|
|
|
|
process.exit(1);
|
2016-03-29 23:32:41 +00:00
|
|
|
}
|
2017-03-04 20:49:10 +00:00
|
|
|
}
|
2017-03-31 17:18:18 +00:00
|
|
|
return configArg;
|
|
|
|
});
|
2018-05-03 10:35:41 +00:00
|
|
|
/**
|
|
|
|
* run this module
|
|
|
|
* @param configArg some config for how to run this module
|
|
|
|
*/
|
2016-02-19 23:53:23 +00:00
|
|
|
exports.run = function (configArg) {
|
2016-10-02 18:35:13 +00:00
|
|
|
let done = q.defer();
|
2016-09-22 21:23:16 +00:00
|
|
|
let config = configArg;
|
2016-08-19 07:46:36 +00:00
|
|
|
if (config.test === true) {
|
2017-01-21 22:23:00 +00:00
|
|
|
plugins.beautylog.ora.text('now starting tests');
|
2017-03-04 20:49:10 +00:00
|
|
|
plugins.beautylog.ora.end();
|
|
|
|
plugins.beautylog.log('ready for tapbuffer:');
|
2017-07-27 23:21:37 +00:00
|
|
|
if (configArg.testConfig.coverage) {
|
2017-06-16 14:08:36 +00:00
|
|
|
tap(config)
|
|
|
|
.then(handleCoverageData)
|
|
|
|
.then(() => {
|
|
|
|
done.resolve(config);
|
2018-04-08 23:03:39 +00:00
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
console.log(err);
|
|
|
|
});
|
2017-06-16 14:08:36 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
tap(config)
|
|
|
|
.then(() => {
|
|
|
|
done.resolve(config);
|
2018-04-08 23:03:39 +00:00
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
console.log(err);
|
|
|
|
});
|
2017-06-16 14:08:36 +00:00
|
|
|
}
|
2016-06-16 01:02:33 +00:00
|
|
|
}
|
|
|
|
else {
|
2017-01-21 22:23:00 +00:00
|
|
|
plugins.beautylog.ora.end();
|
2016-06-16 01:02:33 +00:00
|
|
|
done.resolve(config);
|
|
|
|
}
|
2016-02-19 23:53:23 +00:00
|
|
|
return done.promise;
|
|
|
|
};
|