I have got few node packages which works in node.js environment and also in browser. Now I have got two seperate tests (for each environment). What is the best way to run these tests with just npm test
command? Also I want to add these packages to travis.
I'm using mocha
and mocha-phantomjs
.
Node test command
node ./node_modules/mocha/bin/mocha ./test/node/index.js --reporter spec
Browser test command
node ./node_modules/mocha-phantomjs/bin/mocha-phantomjs ./test/browser/index.html
What I tried:
npm test
script seperated with semicolon
npm test
script and create custom script for browser tests. Than add these two commands (npm test
and npm run-script test-browser
) into travis.yml as array.
npm test
script and add browser tests to npm posttest
command. Travis.yml will than have got just one script and users will also have to run one script (everyone is happy).
I like the following:
"scripts": {
"test": "npm run test-node && npm run test-browser",
"test-node": "mocha -R spec ./test/node/index.js",
"test-browser": "mocha-phantomjs ./test/browser/index.html"}
The &&
only runs the second if the first passes, and you can run either separately if you want. Note that npm always uses the relative mocha (inside node_modules), not the global one, so there's no harm in just calling mocha
and mocha-phantomjs
directly. You can be even more efficient with mocha's -b
option for bail, which will quit as soon as it encounters an error.