tscoverage/ts/mod02/index.ts

121 lines
3.3 KiB
TypeScript
Raw Normal View History

2016-10-21 17:48:52 +02:00
/* ------------------------------------------
* This module tests the compiled TypeScript files
* -------------------------------------------- */
import plugins = require('./mod02.plugins')
import paths = require('../npmts.paths')
2016-10-02 20:35:13 +02:00
2017-01-18 00:58:09 +01:00
import * as q from 'smartq'
2016-10-02 20:35:13 +02:00
2016-10-21 17:48:52 +02:00
import { INpmtsConfig } from '../npmts.config'
2016-03-26 14:08:48 +01:00
2016-03-30 01:32:41 +02:00
/**
2016-09-25 20:22:10 +02:00
* runs mocha
* @returns INpmtsConfig
2016-03-30 01:32:41 +02:00
*/
2017-03-04 20:49:10 +00:00
let tap = function (configArg: INpmtsConfig) {
let done = q.defer()
2016-11-25 13:03:41 +01:00
2017-03-04 20:49:10 +00:00
/**
* the TabBuffer for npmts
*/
let npmtsTapBuffer = new plugins.tapbuffer.TabBuffer()
2016-11-25 13:03:41 +01:00
2017-03-04 20:49:10 +00:00
/**
* handle the testable files
*/
let testableFilesSmartstream = new plugins.smartstream.Smartstream([
plugins.gulp.src([ plugins.path.join(paths.cwd, './ts/**/*.ts') ]),
plugins.gulpSourcemaps.init(),
plugins.gulpTypeScript({
target: 'ES5',
emitDecoratorMetadata: true,
experimentalDecorators: true,
lib: [ 'DOM', 'ES5', 'ES2015.Promise', 'ES2015.Generator', 'ES2015.Iterable' ]
}),
plugins.gulpSourcemaps.write(),
plugins.gulpFunction.forEach(async file => {
file.path = file.path.replace(paths.tsDir, paths.distDir)
}),
npmtsTapBuffer.pipeTestableFiles(),
plugins.smartstream.cleanPipe()
])
/**
* handle the test files
*/
let testFilesSmartstream = new plugins.smartstream.Smartstream([
plugins.gulp.src([ plugins.path.join(paths.cwd, 'test/*.ts') ]),
2017-03-04 20:49:10 +00:00
plugins.gulpTypeScript({
target: 'ES5',
emitDecoratorMetadata: true,
experimentalDecorators: true,
lib: [ 'DOM', 'ES5', 'ES2015.Promise', 'ES2015.Generator', 'ES2015.Iterable' ]
}),
npmtsTapBuffer.pipeTestFiles(),
plugins.smartstream.cleanPipe()
])
// lets run the smartstream
Promise.all([
testableFilesSmartstream.run(),
testFilesSmartstream.run()
]).then(
async () => {
configArg.runData.coverageLcovInfo = await npmtsTapBuffer.runTests()
2017-03-04 20:49:10 +00:00
done.resolve(configArg)
}, (err) => {
plugins.beautylog.error('Tests failed!')
console.log(err)
if (configArg.watch) {
done.resolve(configArg)
} else {
process.exit(1)
}
})
return done.promise
2016-09-06 17:21:25 +02:00
}
2016-02-09 05:39:31 +01:00
let handleCoverageData = async (configArg: INpmtsConfig) => {
let coverageResult = await plugins.smartcov.get.percentageFromLcovString(
configArg.runData.coverageLcovInfo,
2
)
if (coverageResult >= configArg.coverageTreshold) {
2017-03-04 20:49:10 +00:00
plugins.beautylog.ok(
`${(coverageResult).toString()}% `
2017-03-04 20:49:10 +00:00
+ `coverage exceeds your treshold of `
+ `${configArg.coverageTreshold.toString()}%`
)
} else {
plugins.beautylog.warn(
`${(coverageResult).toString()}% `
2017-03-04 20:49:10 +00:00
+ `coverage fails your treshold of `
+ `${configArg.coverageTreshold.toString()}%`
)
plugins.beautylog.error('exiting due to coverage failure')
if (!configArg.watch) { process.exit(1) }
}
return configArg
2016-09-06 17:21:25 +02:00
}
2016-03-30 01:32:41 +02:00
2016-09-25 20:22:10 +02:00
export let run = function (configArg: INpmtsConfig) {
2017-03-04 20:49:10 +00:00
let done = q.defer<INpmtsConfig>()
let config = configArg
if (config.test === true) {
plugins.beautylog.ora.text('now starting tests')
plugins.beautylog.ora.end()
plugins.beautylog.log('ready for tapbuffer:')
2016-02-09 05:39:31 +01:00
2017-03-04 20:49:10 +00:00
tap(config)
.then(handleCoverageData)
.then(() => {
2016-09-06 17:21:25 +02:00
done.resolve(config)
2017-03-04 20:49:10 +00:00
}).catch(err => { console.log(err) })
} else {
plugins.beautylog.ora.end()
done.resolve(config)
}
return done.promise
2016-09-06 17:21:25 +02:00
}