diff --git a/.travis.yml b/.travis.yml index 87f8cd9..d01fc04 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,3 +1,6 @@ language: node_js node_js: - - "0.10" \ No newline at end of file + - "0.10" + - "0.12" + - "4" + - "5" \ No newline at end of file diff --git a/changelog.md b/changelog.md index c7f88b1..50a5cdf 100644 --- a/changelog.md +++ b/changelog.md @@ -1,5 +1,8 @@ #Changelog +###1.3.3 +- Added support for creating custom dir where the parent dir(s) may not exist yet. See [#40](https://github.com/adamgruber/mochawesome/issues/40) + ###1.3.2 - Removed `allHooks` array since it was not being used and could lead to an issue where node runs out of memory while rendering the template. See [#33](https://github.com/adamgruber/mochawesome/issues/33) diff --git a/gulpfile.js b/gulpfile.js index 78d638f..968c4a8 100644 --- a/gulpfile.js +++ b/gulpfile.js @@ -11,7 +11,8 @@ var gulp = require('gulp'), wrap = require('gulp-wrap'), declare = require('gulp-declare'), watch = require('gulp-watch'), - mocha = require('gulp-spawn-mocha'), + mocha = require('gulp-mocha'), + spawnmocha = require('gulp-spawn-mocha'), config = require('./lib/config')(); var mochaOpts = { @@ -29,8 +30,9 @@ var watchFiles = [ ]; var testPaths = { - basic: ['./test/test.js'], - mem: ['./test/mem-test.js'], + basic: ['./test/basic/test.js'], + mem: ['./test/basic/mem-test.js'], + recursive: ['./test/basic'], fiveby: [ './test/fiveby/*.js', './test/fiveby/**/*.js' @@ -156,7 +158,7 @@ gulp.task('watch', function () { // Test Tasks gulp.task('fiveby', function () { return gulp.src(testPaths.fiveby) - .pipe(mocha(mochaOpts)) + .pipe(spawnmocha(mochaOpts)) .on('error', console.warn.bind(console)); }); @@ -172,8 +174,20 @@ gulp.task('mem-test', function () { .on('error', console.warn.bind(console)); }); +gulp.task('test-recursive', function () { + mochaOpts.recursive = true; + return gulp.src(testPaths.recursive) + .pipe(mocha(mochaOpts)) + .on('error', console.warn.bind(console)); +}); + gulp.task('testOpts', function () { - mochaOpts.reporterOptions = 'reportDir=customDir,reportName=customName,reportTitle=customTitle,inlineAssets=true'; + mochaOpts.reporterOptions = { + reportDir: 'customDir', + reportName: 'customName', + reportTitle: 'customTitle', + inlineAssets: true + }; return gulp.src(testPaths.basic) .pipe(mocha(mochaOpts)) .on('error', console.warn.bind(console)); diff --git a/lib/reportGenerator.js b/lib/reportGenerator.js index 42811e2..ed59ab3 100644 --- a/lib/reportGenerator.js +++ b/lib/reportGenerator.js @@ -2,7 +2,8 @@ var async = require('async'), fs = require('fs'), ncp = require('ncp'), _ = require('lodash'), - chalk = require('chalk'); + chalk = require('chalk'), + mkdirp = require('mkdirp'); exports.generateReport = generateReport; exports.saveToFile = saveToFile; @@ -47,9 +48,7 @@ function createDirs (config, inline, callback) { dirs = dirs.concat([config.reportJsDir, config.reportFontsDir, config.reportCssDir]); } dirs.forEach(function(dir) { - if (!fs.existsSync(dir)) { - fs.mkdirSync(dir); - } + mkdirp.sync(dir); }); callback(null, 'done'); } diff --git a/package.json b/package.json index be55b4d..d36f0d0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "mochawesome", - "version": "1.3.2", + "version": "1.3.3", "description": "A Gorgeous HTML/CSS Reporter for Mocha.js", "scripts": { "test": "gulp build" @@ -26,6 +26,7 @@ "highlight.js": "^8.5.0", "json-stringify-safe": "^5.0.0", "lodash": "^3.1.0", + "mkdirp": "^0.5.1", "mocha": "*", "moment": "^2.9.0", "ncp": "^1.0.1", @@ -41,6 +42,7 @@ "gulp-handlebars": "^4.0.0", "gulp-jshint": "^1.9.0", "gulp-less": "^3.0.3", + "gulp-mocha": "^2.2.0", "gulp-plumber": "^0.6.6", "gulp-spawn-mocha": "^0.5.2", "gulp-uglify": "^1.1.0", diff --git a/test/mem-test.js b/test/basic/mem-test.js similarity index 100% rename from test/mem-test.js rename to test/basic/mem-test.js diff --git a/test/basic/subfolder/test.js b/test/basic/subfolder/test.js new file mode 100644 index 0000000..3b4eb4d --- /dev/null +++ b/test/basic/subfolder/test.js @@ -0,0 +1,14 @@ +var should = require('should'); + +describe('Subfolder Test Suite', function () { + describe('Test Suite - Basic', function () { + it('passing test', function (done) { + true.should.be.ok; + done(); + }); + it('failing test', function (done) { + false.should.be.ok; + done(); + }); + }); +}); \ No newline at end of file diff --git a/test/test.js b/test/basic/test.js similarity index 100% rename from test/test.js rename to test/basic/test.js