Grouch
Test runner for any front end project.
It runs unit test using jasmine
and does code coverage using istanbul
.
It also does Javascript lint using Eslint.
##Options
Options:
-h, --help Show help.
-v, --version Outputs the version number.
-s, --src path::String Source file location. - default: ./src/main
-t, --srcTest path::String Test file location - default: ./src/test
-m, --mock [path::String] Path of the mock files directory - default: []
-c, --config path::String Load configuration data from this file.
-i, --ignorePath [path::String] Supply a collection of ignore paths. - default: []
--coverage Code coverage should be done. - default: true
--lint Lint the Javascript code with eslint. - default: true
##Usage
The project should be used as CLI tool so that's why we require it to be installed globally.
The benefits for installing it at globally are:
- Don't have to install inside each project
- Is available as a executable on your path
- You can use it on any project without any installation. Its like a software on your machine.
To install it at global level, open cmd and run this command
npm install -g grouch
If already installed use the following command to update it
npm update -g grouch
Now in you cmd window, you should be able to say
grouch -h
and it should display help i.e. all the options available. it would look similar to what you see under the options header on the top.
If you want to test your code
grouch -s src/main/js -t test/js -m test/mock1 -m test/mock2 -i **/src/main/**.min.js
The above command would get all the source files from src/main/js
folder, get the test files from test/js
.
It will also load some mock files from test/mock1
and test/mock2
. Mocks would be loaded be fore your source files
test files when running the tests.
Important thing to note here is that from the source folder it will ignore all the files which have a .min.js
extension.
After running the top command, in side your project base you would see _SpecRunner.html
for your jasmine run,
eslintReport.html
for the Javascript lint for the srcFiles and you should see coverage
folder. Inside coverage folder,
you would see index.html
,which has your code coverage stats.
Now you can use _SpecRunner.html
to run your test in different browsers but in the future we would integrate karma
to
automatically run these test for you in different browsers.
All the boolean options can be turned off by using the prefix --no-
. Example --no-lint
, --no-coverage
.
Note: This project automatically loads jquery 1.11
version before your mocks
, src
and test
files.
If you project has jquery built into it then it will override the 1.11 version with your version.
##Contribution
Please feel free to log issues and even send pull request for the changes.
Make sure you log a issue before you send in a pull request and reference that issue in your pull request.
That way everyone knows what did you fix or add to the project.
##Future
Check out the Grouch Roadmap.