forked from stryker-mutator/stryker-js
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'origin/#72-clean-up-code-create-pr-info…
…rm-nico-to-review' into #72-clean-up-code-create-pr-inform-nico-to-review
- Loading branch information
Showing
39 changed files
with
18,246 additions
and
0 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
{ | ||
"version": "0.2.0", | ||
"configurations": [ | ||
{ | ||
"type": "node-terminal", | ||
"name": "❌avier stryker debug", | ||
"request": "launch", | ||
"command": "cd ../ && npm run clean && npm run build && cd ${workspaceFolder} && yarn run test:mutation --logLevel debug", | ||
"cwd": "${workspaceFolder}", | ||
"skipFiles": [ | ||
"<node_internals>/**" | ||
], | ||
"outFiles": [ | ||
"${workspaceFolder}/../packages/*/dist/**/*.js", | ||
] | ||
}, | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
[data:image/s3,"s3://crabby-images/1d55b/1d55be5f1d808489e74305a3b4a379828859386b" alt="Code coverage badge"](https://stryker-mutator.io/robobar-example/reports/coverage/lcov-report/index.html) | ||
[data:image/s3,"s3://crabby-images/010bd/010bdbc0dea598413df26d504cdaa5ad935cafe4" alt="Mutation testing badge"](https://dashboard.stryker-mutator.io/reports/github.com/stryker-mutator/robobar-example/master) | ||
|
||
# Welcome to the RoboBar | ||
|
||
> An introduction to mutation testing | ||
_How code coverage of 100% could mean less than 60% is tested._ | ||
|
||
## TL;DR | ||
|
||
No time to run the example yourself? Don't worry, we did it for you. Open it right in your browser: | ||
|
||
- [The RoboBar website](https://stryker-mutator.io/robobar-example/) | ||
- [Coverage report](https://stryker-mutator.io/robobar-example/reports/coverage/lcov-report/index.html) | ||
- [Mutation report](https://dashboard.stryker-mutator.io/reports/github.com/stryker-mutator/robobar-example/master) | ||
|
||
## What is this? | ||
|
||
The RoboBar is a small application to demo mutation testing. It actually has a fair amount of unit tests. When we wrote this application, we didn't even try our best to write bad tests. We just focussed on code coverage and didn't practice Test Driven Development. It turns out it's really easy to write bad tests or forget a few important test cases. The RoboBar even has a fairly large bug. Finding it is pretty easy using the mutation report. Why don't you give it a try? 😁 | ||
|
||
**Note:** The RoboBar is developed using [native web components](https://developer.mozilla.org/en-US/docs/Web/Web_Components) without a frontend framework. This is done on purpose to keep this example as accessible as possible, as well as to keep the maintenance burden low. | ||
|
||
## Try it yourself | ||
|
||
1. Install [git](https://git-scm.com) | ||
1. Install [nodejs](https://nodejs.org/) | ||
1. Open command prompt and clone this repository: | ||
```shell | ||
git clone https://github.com/stryker-mutator/robobar-example | ||
``` | ||
1. Change directory into the robobar and install the dependencies. | ||
```shell | ||
cd robobar-example | ||
npm install | ||
``` | ||
1. Run tests with npm. This will generate a code coverage report. | ||
```shell | ||
npm test | ||
``` | ||
1. Review the 100% code coverage score. Open up the code coverage report located in the `reports/coverage/lcov-report` directory. | ||
1. Run mutation testing with [Stryker](https://stryker-mutator.io) | ||
```shell | ||
npm run test:mutation | ||
``` | ||
1. Review the less than 60% mutation score. Open up the mutation report located in the `reports/mutation` directory. | ||
1. Run the website with `npm start`. Can you find the bug? | ||
|
||
## Try to install stryker yourself. | ||
|
||
If you want to install stryker yourself, step back in history using git: | ||
|
||
```shell | ||
git checkout pre-stryker | ||
npm install | ||
``` | ||
|
||
After that you can install stryker for yourself: | ||
|
||
```shell | ||
npm i -D @stryker-mutator/core | ||
npx stryker init | ||
``` | ||
|
||
Choose the following options in the questionnaire: | ||
|
||
- **Are you using one of these frameworks?** `None/other` | ||
- **Which test runner do you want to use?** `jest` | ||
- **Reporters**: `html`, `clear-text`, `progress` | ||
- **Which package manager do you want to use?**: `npm` | ||
- **What file type do you want for your config file?**: `json` | ||
|
||
After the plugins are installed, open the `stryker.conf.json` file and make the following change: | ||
|
||
```diff | ||
{ | ||
"$schema": "./node_modules/@stryker-mutator/core/schema/stryker-schema.json", | ||
"_comment": "This config was generated using 'stryker init'. Please take a look at: https://stryker-mutator.io/docs/stryker-js/configuration/ for more information", | ||
"packageManager": "npm", | ||
"reporters": [ | ||
"html", | ||
"clear-text", | ||
"progress", | ||
"dashboard" | ||
], | ||
"testRunner": "jest", | ||
- "coverageAnalysis": "perTest" | ||
+ "coverageAnalysis": "perTest", | ||
+ "testRunnerNodeArgs": ["--experimental-vm-modules"], | ||
+ "jest": { | ||
+ "configFile": "jest.config.cjs" | ||
+ } | ||
} | ||
``` | ||
|
||
(this is needed because we're using [jest with ECMAScript modules](https://jestjs.io/docs/ecmascript-modules)) | ||
|
||
After the plugins are installed, try it out: | ||
|
||
```shell | ||
npx stryker run | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
[ | ||
{ "name": "Roba Cola", "price": 2.3, "isAlcoholic": false }, | ||
{ "name": "Robo Beer", "price": 3.5, "isAlcoholic": true }, | ||
{ "name": "Rob(w)ine", "price": 5.0, "isAlcoholic": true } | ||
] |
Oops, something went wrong.