Skip to content

Latest commit

 

History

History
84 lines (61 loc) · 5.05 KB

README.md

File metadata and controls

84 lines (61 loc) · 5.05 KB

Example Testing Application

This project is designed to provide an introduction to unit testing to developers new to testing. Features and content have been chosen in order to provide basic but solid examples of components/services/classses/guards/resolvers/pipes/etc to test.

The application uses the excellent Star Wars API to fetch a list of Star Wars characters and display them to the user. Each character card also contains a list of all movies they featured in, with a link to a page with more detail on eaxch movie.

Development server

Run ng serve for a dev server. Navigate to http://localhost:4200/. The app will automatically reload if you change any of the source files.

Running unit tests

Run ng test to execute the unit tests via Karma. By default code coverage reports will be generated in /coverage as well as outputting an overview in the CLI.

Test coverage is globally set to 90% minumum on all branches, functions, statements, and lines. Tests will fail if these minimum thresholds are not met. These settings can be adjusted in the karma.conf.js file under the coverageIstanbulReporter section. You can find more coverage options here.

The test coverage report is updated every time the tests are run - you can find the full detailed report by opening /coverage/example-testing-application/index.html in your browser.

A typical development workflow would be to run ng serve in one terminal pane/window and ng test in another. Incremental recompiles are very quick allowing the developer to quickly see test suite status as well as the development build of the application while making changes.

Pre-push git hook

The project uses Husky to configure a pre-push git hook which runs all tests in the project. If any tests fail or if code coverage does not meet the minimum threshold, the pre-push hook will abort any git push command.

You are able to force your changes through by passing the --no-verify flag to git push, however, it is strongly recommended not to do this, for the following reasons:

  • Code coverage should meet agreed upon minimum thresholds.
  • If tests are broken, this is a good indication that the project is broken as well. Either the project should be fixed so that the tests do not break, or if the tests are broken, then they should be fixed.
  • Skipping tests in this way might allow you to push now, but the test suite remains broken for everyone, meaning that tests will now fail on every attempt to push, and will have to be skipped by everyone for every push, or someone else will have to fix the tests in order to continue working on the project.

Useful testing resources

General testing resources

Documentation links

Angular testing overviews

Deeper dives into more specific testing approaches and features