Testing is very important to the health of the Wiki Ed Dashboard as a whole. As part of a holistic testing strategy, the project utilizes the following testing stack:
- RSpec for unit tests (model and controller specs, and specs for plain old Ruby object)
- Capybara for end-to-end integration testing.
- Jest for testing front-end utilities and React.js components
The tests are run on Travis for continuous integration purposes. Upon a successful unit test run — excluding feature tests — on the production
branch, Travis will deploy the production
branch to the production environment.
Write tests for the applicable parts of your contribution wherever possible.
Running rspec
will run all model, controller, and integration tests (found in spec/features
), as well as any other specs in the spec
directory (such as classes in lib
and presenters
). Running rspec spec/features
will run just the integration tests. You can pass any directory to rspec
to run specs in just that directory, such as rspec spec/models
.
If there are deprecations warnings in the development build of the javascript assets,
this can cause feature specs to fail. Run yarn build
to get the production build,
which will not include the deprecation warnings.
Running yarn test
will run the entire client-side test suite. During development, you can use jest --watch
to run Jest in watch mode. This works similarly to guard, re-running relevant tests whenever the corresponding files change.
You can run the entire test suite, including a fresh compilation of assets, with yarn build && rspec && yarn test
.
All new code should be covered with appropriate tests. Much of the Javascript-dependent UI is covered by Poltergeist integration tests. Whenever possible, new Javascript functionality should be tested in isolation via Javascript tests instead (or additionally), as the integration tests tend to be both slower and more brittle.
JSCover is used to provide the test coverage for RSpec feature tests. When the full test suite is run, the report is generated and can be
accessed at http://localhost:3000/js_coverage/jscoverage.html which means to view the report you have to have the server running
by doing rails s
For report generation to work, the environment variable COVERAGE
must be set to 'true'
.
COVERAGE=true bundle exec rspec