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
|
|
|
|
2017-07-28 17:16:14 +02:00
|
|
|
// interfaces
|
2016-10-21 17:48:52 +02:00
|
|
|
import { INpmtsConfig } from '../npmts.config'
|
2017-07-28 17:16:14 +02:00
|
|
|
import { Smartfile } from 'smartfile'
|
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-06-17 10:47:07 +02: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 22:43:32 +02:00
|
|
|
plugins.smartgulp.src([ plugins.path.join(paths.cwd, './ts/**/*.ts') ]),
|
2017-03-04 20:49:10 +00:00
|
|
|
plugins.gulpSourcemaps.init(),
|
|
|
|
plugins.gulpTypeScript({
|
|
|
|
target: 'ES5',
|
|
|
|
emitDecoratorMetadata: true,
|
|
|
|
experimentalDecorators: true,
|
|
|
|
lib: [ 'DOM', 'ES5', 'ES2015.Promise', 'ES2015.Generator', 'ES2015.Iterable' ]
|
|
|
|
}),
|
2017-05-13 10:21:55 +02:00
|
|
|
plugins.gulpSourcemaps.write(),
|
2017-03-04 20:49:10 +00:00
|
|
|
npmtsTapBuffer.pipeTestableFiles(),
|
|
|
|
plugins.smartstream.cleanPipe()
|
|
|
|
])
|
|
|
|
|
|
|
|
/**
|
|
|
|
* handle the test files
|
|
|
|
*/
|
|
|
|
let testFilesSmartstream = new plugins.smartstream.Smartstream([
|
2017-05-01 22:43:32 +02:00
|
|
|
plugins.smartgulp.src([ plugins.path.join(paths.cwd, 'test/*.ts') ]),
|
2017-05-13 10:21:55 +02:00
|
|
|
plugins.gulpSourcemaps.init(),
|
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' ]
|
|
|
|
}),
|
2017-05-13 10:21:55 +02:00
|
|
|
plugins.gulpSourcemaps.write(),
|
2017-03-04 20:49:10 +00:00
|
|
|
npmtsTapBuffer.pipeTestFiles(),
|
|
|
|
plugins.smartstream.cleanPipe()
|
|
|
|
])
|
|
|
|
|
|
|
|
// lets run the smartstream
|
|
|
|
Promise.all([
|
|
|
|
testableFilesSmartstream.run(),
|
|
|
|
testFilesSmartstream.run()
|
|
|
|
]).then(
|
|
|
|
async () => {
|
2017-03-31 19:18:18 +02:00
|
|
|
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
|
|
|
|
2017-03-31 19:18:18 +02:00
|
|
|
let handleCoverageData = async (configArg: INpmtsConfig) => {
|
2017-05-05 00:01:21 +02:00
|
|
|
let coverageResult: number = 0 // the coverage in percent
|
|
|
|
if (configArg.runData.coverageLcovInfo) {
|
|
|
|
coverageResult = await 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 19:18:18 +02:00
|
|
|
if (coverageResult >= configArg.coverageTreshold) {
|
2017-03-04 20:49:10 +00:00
|
|
|
plugins.beautylog.ok(
|
2017-03-31 19:18:18 +02:00
|
|
|
`${(coverageResult).toString()}% `
|
2017-03-04 20:49:10 +00:00
|
|
|
+ `coverage exceeds your treshold of `
|
|
|
|
+ `${configArg.coverageTreshold.toString()}%`
|
|
|
|
)
|
|
|
|
} else {
|
|
|
|
plugins.beautylog.warn(
|
2017-03-31 19:18:18 +02:00
|
|
|
`${(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) }
|
|
|
|
}
|
2017-03-31 19:18:18 +02:00
|
|
|
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:')
|
2017-07-28 01:21:37 +02:00
|
|
|
if (configArg.testConfig.coverage) {
|
2017-06-16 16:08:36 +02:00
|
|
|
tap(config)
|
|
|
|
.then(handleCoverageData)
|
|
|
|
.then(() => {
|
|
|
|
done.resolve(config)
|
|
|
|
}).catch(err => { console.log(err) })
|
|
|
|
} else {
|
|
|
|
tap(config)
|
|
|
|
.then(() => {
|
|
|
|
done.resolve(config)
|
|
|
|
}).catch(err => { console.log(err) })
|
|
|
|
}
|
2016-02-09 05:39:31 +01:00
|
|
|
|
2017-03-04 20:49:10 +00:00
|
|
|
} else {
|
|
|
|
plugins.beautylog.ora.end()
|
|
|
|
done.resolve(config)
|
|
|
|
}
|
|
|
|
return done.promise
|
2016-09-06 17:21:25 +02:00
|
|
|
}
|