Compare commits
13 Commits
Author | SHA1 | Date | |
---|---|---|---|
7e540bda87 | |||
b293dfe92d | |||
a753a5db2c | |||
27f79b4425 | |||
1ada5dd5a9 | |||
a41bfd442c | |||
2917b10ffb | |||
bfc5bbbbb7 | |||
cf507a4a17 | |||
73a57ed264 | |||
39b79b679c | |||
cc053ee396 | |||
df5371187b |
@ -1,6 +1,9 @@
|
||||
# npmts
|
||||
Write npm modules with TypeScript without hassle.
|
||||
|
||||
## Status
|
||||
[](https://coveralls.io/github/pushrocks/npmts?branch=master)
|
||||
|
||||
## How to use npmts
|
||||
|
||||
### Install
|
||||
|
4
index.d.ts
vendored
4
index.d.ts
vendored
@ -6,11 +6,9 @@ declare module NpmtsPlugins {
|
||||
gulp: any;
|
||||
g: {
|
||||
coveralls: any;
|
||||
if: any;
|
||||
insert: any;
|
||||
istanbul: any;
|
||||
mocha: any;
|
||||
sequence: any;
|
||||
typescript: any;
|
||||
};
|
||||
mergeStream: any;
|
||||
@ -45,11 +43,9 @@ declare var plugins: {
|
||||
gulp: any;
|
||||
g: {
|
||||
coveralls: any;
|
||||
if: any;
|
||||
insert: any;
|
||||
istanbul: any;
|
||||
mocha: any;
|
||||
sequence: any;
|
||||
typescript: any;
|
||||
};
|
||||
mergeStream: any;
|
||||
|
43
index.js
43
index.js
@ -10,11 +10,9 @@ var NpmtsPlugins;
|
||||
gulp: require("gulp"),
|
||||
g: {
|
||||
coveralls: require("gulp-coveralls"),
|
||||
if: require("gulp-if"),
|
||||
insert: require("gulp-insert"),
|
||||
istanbul: require("gulp-istanbul"),
|
||||
mocha: require("gulp-mocha"),
|
||||
sequence: require("gulp-sequence"),
|
||||
typescript: require("gulp-typescript")
|
||||
},
|
||||
mergeStream: require("merge2"),
|
||||
@ -78,7 +76,7 @@ var NpmtsOptions;
|
||||
var done = plugins.q.defer();
|
||||
var config = configArg;
|
||||
if (typeof config.coveralls === "undefined") {
|
||||
config.coveralls = true;
|
||||
config.coveralls = false;
|
||||
}
|
||||
if (config.mode == "default") {
|
||||
config.typings = [
|
||||
@ -86,6 +84,7 @@ var NpmtsOptions;
|
||||
];
|
||||
config.ts = (_a = {},
|
||||
_a["./ts/index.ts"] = "./index.js",
|
||||
_a["./ts/test.ts"] = "./test/test.js",
|
||||
_a
|
||||
);
|
||||
config.test = ["./index.js"];
|
||||
@ -182,7 +181,7 @@ var NpmtsCompile;
|
||||
moduleStream.on("queueDrain", function () {
|
||||
plugins.beautylog.success("custom TypeScript installed successfully");
|
||||
moduleStream.on("finish", function () {
|
||||
done.resolve();
|
||||
done.resolve(config);
|
||||
});
|
||||
moduleStream.end();
|
||||
});
|
||||
@ -196,27 +195,36 @@ var NpmtsTests;
|
||||
NpmtsTests.run = function (configArg) {
|
||||
var done = plugins.q.defer();
|
||||
var config = configArg;
|
||||
plugins.gulp.task('istanbul', function () {
|
||||
return plugins.gulp.src([plugins.path.join(paths.cwd, "index.js")])
|
||||
var istanbul = function () {
|
||||
var stream = plugins.gulp.src([plugins.path.join(paths.cwd, "index.js")])
|
||||
.pipe(plugins.g.istanbul())
|
||||
.pipe(plugins.g.istanbul.hookRequire());
|
||||
});
|
||||
plugins.gulp.task('mocha', function () {
|
||||
return plugins.gulp.src(["./test/test.js"])
|
||||
return stream;
|
||||
};
|
||||
var mocha = function () {
|
||||
var stream = plugins.gulp.src(["./test/test.js"])
|
||||
.pipe(plugins.g.mocha())
|
||||
.pipe(plugins.g.istanbul.writeReports())
|
||||
.pipe(plugins.g.istanbul.enforceThresholds({ thresholds: { global: 30 } }));
|
||||
return stream;
|
||||
};
|
||||
var coveralls = function () {
|
||||
var stream = plugins.gulp.src([plugins.path.join(paths.cwd, "./coverage/lcov.info")])
|
||||
.pipe(plugins.g.coveralls());
|
||||
return stream;
|
||||
};
|
||||
istanbul().on("finish", function () {
|
||||
mocha().on("finish", function () {
|
||||
if (process.env.TRAVIS && config.coveralls) {
|
||||
coveralls().on("finish", function () {
|
||||
done.resolve(config);
|
||||
});
|
||||
plugins.gulp.task("coveralls", function () {
|
||||
return plugins.gulp.src("./coverage/**/lcov.info")
|
||||
.pipe(plugins.g.if((process.env.TRAVIS && config.coveralls), plugins.g.coveralls()));
|
||||
});
|
||||
plugins.gulp.task("test", function () {
|
||||
plugins.g.sequence("istanbul", "mocha", "coveralls", function () {
|
||||
done.resolve();
|
||||
}
|
||||
else {
|
||||
done.resolve(config);
|
||||
}
|
||||
});
|
||||
});
|
||||
plugins.gulp.start.apply(plugins.gulp, ['test']);
|
||||
return done.promise;
|
||||
};
|
||||
})(NpmtsTests || (NpmtsTests = {}));
|
||||
@ -243,5 +251,6 @@ var NpmtsPromisechain;
|
||||
/// <reference path="./npmts.promisechain.ts" />
|
||||
console.log("**** starting NPMTS ****");
|
||||
var plugins = NpmtsPlugins.init();
|
||||
plugins.beautylog.figletSync("NPMTS");
|
||||
var paths = NpmtsPaths.init();
|
||||
var promisechain = NpmtsPromisechain.init();
|
||||
|
12
package.json
12
package.json
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "npmts",
|
||||
"version": "2.1.8",
|
||||
"version": "2.2.3",
|
||||
"description": "write npm modules with TypeScript",
|
||||
"main": "index.js",
|
||||
"typings": "./index.d.ts",
|
||||
@ -26,21 +26,19 @@
|
||||
},
|
||||
"homepage": "https://github.com/pushrocks/npmts#readme",
|
||||
"dependencies": {
|
||||
"beautylog": "2.0.7",
|
||||
"beautylog": "2.1.1",
|
||||
"fs-extra": "^0.26.5",
|
||||
"gulp": "3.9.0",
|
||||
"gulp": "3.9.1",
|
||||
"gulp-coveralls": "^0.1.4",
|
||||
"gulp-if": "^2.0.0",
|
||||
"gulp-insert": "0.5.0",
|
||||
"gulp-istanbul": "^0.10.3",
|
||||
"gulp-mocha": "^2.2.0",
|
||||
"gulp-sequence": "^0.4.4",
|
||||
"gulp-typescript": "2.10.0",
|
||||
"gulp-typescript": "2.11.0",
|
||||
"gulp-typings": "0.0.0",
|
||||
"merge2": "1.0.1",
|
||||
"q": "^1.4.1",
|
||||
"smartcli": "0.0.11",
|
||||
"smartfile": "0.0.11",
|
||||
"typings": "^0.6.6"
|
||||
"typings": "^0.6.8"
|
||||
}
|
||||
}
|
||||
|
@ -77,7 +77,7 @@
|
||||
</div><!-- /wrapper -->
|
||||
<div class='footer quiet pad2 space-top1 center small'>
|
||||
Code coverage
|
||||
generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Tue Feb 09 2016 15:59:46 GMT+0100 (CET)
|
||||
generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Thu Feb 11 2016 19:08:46 GMT+0100 (CET)
|
||||
</div>
|
||||
</div>
|
||||
<script src="../prettify.js"></script>
|
||||
|
@ -76,7 +76,7 @@ module.exports = testplugin;
|
||||
</div><!-- /wrapper -->
|
||||
<div class='footer quiet pad2 space-top1 center small'>
|
||||
Code coverage
|
||||
generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Tue Feb 09 2016 15:59:46 GMT+0100 (CET)
|
||||
generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Thu Feb 11 2016 19:08:46 GMT+0100 (CET)
|
||||
</div>
|
||||
</div>
|
||||
<script src="../prettify.js"></script>
|
||||
|
@ -77,7 +77,7 @@
|
||||
</div><!-- /wrapper -->
|
||||
<div class='footer quiet pad2 space-top1 center small'>
|
||||
Code coverage
|
||||
generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Tue Feb 09 2016 15:59:46 GMT+0100 (CET)
|
||||
generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Thu Feb 11 2016 19:08:46 GMT+0100 (CET)
|
||||
</div>
|
||||
</div>
|
||||
<script src="prettify.js"></script>
|
||||
|
2
test/assets/test/test.d.ts
vendored
Normal file
2
test/assets/test/test.d.ts
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
/// <reference path="ts/typings/main.d.ts" />
|
||||
declare var testplugin: any;
|
@ -1,3 +1,5 @@
|
||||
#!/usr/bin/env node
|
||||
|
||||
/// <reference path="./typings/main.d.ts" />
|
||||
console.log("**** starting test ****");
|
||||
var testplugin = require("../index.js");
|
||||
|
@ -7,7 +7,8 @@
|
||||
/// <reference path="./npmts.compile.ts" />
|
||||
/// <reference path="./npmts.tests.ts" />
|
||||
/// <reference path="./npmts.promisechain.ts" />
|
||||
console.log("**** starting NPMTS ****")
|
||||
console.log("**** starting NPMTS ****");
|
||||
var plugins = NpmtsPlugins.init();
|
||||
plugins.beautylog.figletSync("NPMTS");
|
||||
var paths = NpmtsPaths.init();
|
||||
var promisechain = NpmtsPromisechain.init();
|
||||
|
@ -83,7 +83,7 @@ module NpmtsCompile {
|
||||
moduleStream.on("queueDrain",function(){
|
||||
plugins.beautylog.success("custom TypeScript installed successfully");
|
||||
moduleStream.on("finish",function(){
|
||||
done.resolve();
|
||||
done.resolve(config);
|
||||
});
|
||||
moduleStream.end();
|
||||
});
|
||||
|
@ -4,14 +4,15 @@ module NpmtsOptions {
|
||||
var done = plugins.q.defer();
|
||||
var config = configArg;
|
||||
if (typeof config.coveralls === "undefined"){
|
||||
config.coveralls = true;
|
||||
config.coveralls = false;
|
||||
}
|
||||
if (config.mode == "default"){
|
||||
config.typings = [
|
||||
"./ts/"
|
||||
];
|
||||
config.ts = {
|
||||
["./ts/index.ts"]: "./index.js"
|
||||
["./ts/index.ts"]: "./index.js",
|
||||
["./ts/test.ts"]: "./test/test.js"
|
||||
};
|
||||
config.test = ["./index.js"];
|
||||
done.resolve(config);
|
||||
|
@ -7,11 +7,9 @@ module NpmtsPlugins {
|
||||
gulp: require("gulp"),
|
||||
g: {
|
||||
coveralls: require("gulp-coveralls"),
|
||||
if: require("gulp-if"),
|
||||
insert: require("gulp-insert"),
|
||||
istanbul: require("gulp-istanbul"),
|
||||
mocha: require("gulp-mocha"),
|
||||
sequence: require("gulp-sequence"),
|
||||
typescript: require("gulp-typescript")
|
||||
|
||||
},
|
||||
|
@ -3,37 +3,42 @@ module NpmtsTests {
|
||||
export var run = function(configArg) {
|
||||
var done = plugins.q.defer();
|
||||
var config = configArg;
|
||||
plugins.gulp.task('istanbul', function () {
|
||||
return plugins.gulp.src([plugins.path.join(paths.cwd,"index.js")])
|
||||
var istanbul = function () {
|
||||
var stream = plugins.gulp.src([plugins.path.join(paths.cwd,"index.js")])
|
||||
// Covering files
|
||||
.pipe(plugins.g.istanbul())
|
||||
// Force `require` to return covered files
|
||||
.pipe(plugins.g.istanbul.hookRequire());
|
||||
});
|
||||
return stream;
|
||||
};
|
||||
|
||||
plugins.gulp.task('mocha', function () {
|
||||
return plugins.gulp.src(["./test/test.js"])
|
||||
var mocha = function () {
|
||||
var stream = plugins.gulp.src(["./test/test.js"])
|
||||
.pipe(plugins.g.mocha())
|
||||
// Creating the reports after tests ran
|
||||
.pipe(plugins.g.istanbul.writeReports())
|
||||
// Enforce a coverage of at least 90%
|
||||
.pipe(plugins.g.istanbul.enforceThresholds({ thresholds: { global: 30 } }));
|
||||
});
|
||||
return stream;
|
||||
};
|
||||
|
||||
plugins.gulp.task("coveralls",function(){
|
||||
return plugins.gulp.src("./coverage/**/lcov.info")
|
||||
.pipe(plugins.g.if(
|
||||
(process.env.TRAVIS && config.coveralls),
|
||||
plugins.g.coveralls()
|
||||
));
|
||||
});
|
||||
var coveralls = function(){
|
||||
var stream = plugins.gulp.src([plugins.path.join(paths.cwd,"./coverage/lcov.info")])
|
||||
.pipe(plugins.g.coveralls());
|
||||
return stream;
|
||||
};
|
||||
|
||||
plugins.gulp.task("test",function(){
|
||||
plugins.g.sequence("istanbul","mocha","coveralls",function(){
|
||||
done.resolve();
|
||||
istanbul().on("finish",function(){
|
||||
mocha().on("finish",function(){
|
||||
if(process.env.TRAVIS && config.coveralls){
|
||||
coveralls().on("finish",function(){
|
||||
done.resolve(config);
|
||||
})
|
||||
} else {
|
||||
done.resolve(config);
|
||||
}
|
||||
})
|
||||
});
|
||||
plugins.gulp.start.apply(plugins.gulp, ['test']);
|
||||
return done.promise;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user