Skip to content

Commit

Permalink
fix: improve code coverage plugin (#4252)
Browse files Browse the repository at this point in the history
  • Loading branch information
kobenguyent authored Mar 15, 2024
1 parent 3ff6ac0 commit 6e552c1
Show file tree
Hide file tree
Showing 8 changed files with 320 additions and 156 deletions.
18 changes: 3 additions & 15 deletions docs/playwright.md
Original file line number Diff line number Diff line change
Expand Up @@ -540,25 +540,13 @@ Code coverage can be captured, by enabling the `coverage` plugin in `codecept.co

Once all the tests are completed, `codecept` will create and store coverage in `output/coverage` folder, as shown below.

![](https://user-images.githubusercontent.com/16587779/131362352-30ee9c51-705f-4098-b665-53035ea9275f.png)

Then you need to [convert code coverage from Playwright's format into Istanbul format](https://github.com/codeceptjs/CodeceptJS/wiki/Converting-Playwright-to-Istanbul-Coverage).

Once the istanbul compatible coverage is generated, use [`nyc`](https://www.npmjs.com/package/nyc) to generate your coverage report in your desired format.

```
npx nyc report --reporter html -t coverage
```

The above command will generate will generate coverage in an interactive html format. It should generate `html` files in the directory where your code coverage is present, something like shown below.

![](https://user-images.githubusercontent.com/16587779/131858419-cbc7df7d-0851-47b9-b086-b5e3b9165674.png)
![](https://private-user-images.githubusercontent.com/7845001/313117208-f7165429-426a-44c5-af27-df5536ef492d.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTA0OTEyNTIsIm5iZiI6MTcxMDQ5MDk1MiwicGF0aCI6Ii83ODQ1MDAxLzMxMzExNzIwOC1mNzE2NTQyOS00MjZhLTQ0YzUtYWYyNy1kZjU1MzZlZjQ5MmQucG5nP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDMxNSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDAzMTVUMDgyMjMyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9NjRmNTFmOWUyYzJjYWE3ZWE0MDA0MGI3ODY5NzY5MDRlYjQyNTMxODRjZGU1ZWM5ZDdjNDJiNGRmZGUxM2FlOCZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ._gfEYZn2AK0NVA0bt-sFmzMoMKlyBVpxd7m4590Ux1M)

Open `index.html` in your browser to view the full interactive coverage report.

![](https://user-images.githubusercontent.com/16587779/131858993-87d1aafc-8ef1-4a82-867d-e64a13e36106.png)
![](https://private-user-images.githubusercontent.com/7845001/313117882-cb77beea-c478-49ea-8677-b025d5614545.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTA0OTEzOTAsIm5iZiI6MTcxMDQ5MTA5MCwicGF0aCI6Ii83ODQ1MDAxLzMxMzExNzg4Mi1jYjc3YmVlYS1jNDc4LTQ5ZWEtODY3Ny1iMDI1ZDU2MTQ1NDUucG5nP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDMxNSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDAzMTVUMDgyNDUwWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9YmY0YTkxOTM0ZjUyNjZmMzk0NmM4MjU5MGFjZTZlZDc0Njc3OTZkNTNjMjc5YzQxODI3OWUyODJkNTU2NGViZSZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.LATp5aqrvm-8Nn4tRGSuMrOjJQ4L-NIJEwsB3BbB5po)

![](https://user-images.githubusercontent.com/16587779/131859006-c6f17d18-c603-44a5-9d59-0670177276cf.png)
![](https://private-user-images.githubusercontent.com/7845001/313117886-92a11844-0a2b-4bcb-8c73-aef5cf518dbf.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTA0OTEzOTAsIm5iZiI6MTcxMDQ5MTA5MCwicGF0aCI6Ii83ODQ1MDAxLzMxMzExNzg4Ni05MmExMTg0NC0wYTJiLTRiY2ItOGM3My1hZWY1Y2Y1MThkYmYucG5nP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDMxNSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDAzMTVUMDgyNDUwWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9MTQ4ODUyMTVlM2MwODRhMzE0Yjg2YWQxYTRiNmYzOWJkYWU2ZWIyNDA2YWMyYjIxYTMyNTZkYjg5NGU3Zjk4OCZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.gxyQ9RgAAtFcCUIqqjzponc53ZRn9sG0hN4cBeQovMg)

## Extending Helper

Expand Down
92 changes: 50 additions & 42 deletions docs/plugins.md
Original file line number Diff line number Diff line change
Expand Up @@ -392,23 +392,29 @@ Dumps code coverage from Playwright/Puppeteer after every test.
```js
plugins: {
coverage: {
enabled: true
enabled: true,
debug: true,
name: 'CodeceptJS Coverage Report',
outputDir: 'output/coverage'
}
}
```

Possible config options:
Possible config options, More could be found at [monocart-coverage-reports][1]

- `coverageDir`: directory to dump coverage files
- `uniqueFileName`: generate a unique filename by adding uuid
- `debug`: debug info. By default, false.
- `name`: coverage report name.
- `outputDir`: path to coverage report.
- `sourceFilter`: filter the source files.
- `sourcePath`: option to resolve a custom path.

### Parameters

- `config`

## customLocator

Creates a [custom locator][1] by using special attributes in HTML.
Creates a [custom locator][2] by using special attributes in HTML.

If you have a convention to use `data-test-id` or `data-qa` attributes to mark active elements for e2e tests,
you can enable this plugin to simplify matching elements with these attributes:
Expand Down Expand Up @@ -582,9 +588,9 @@ This method works with WebDriver, Playwright, Puppeteer, Appium helpers.
Function parameter `el` represents a matched element.
Depending on a helper API of `el` can be different. Refer to API of corresponding browser testing engine for a complete API list:
- [Playwright ElementHandle][2]
- [Puppeteer][3]
- [webdriverio element][4]
- [Playwright ElementHandle][3]
- [Puppeteer][4]
- [webdriverio element][5]
#### Configuration
Expand All @@ -598,11 +604,11 @@ const eachElement = codeceptjs.container.plugins('eachElement');
### Parameters
- `purpose` **[string][5]**
- `purpose` **[string][6]**
- `locator` **CodeceptJS.LocatorOrString**
- `fn` **[Function][6]**
- `fn` **[Function][7]**
Returns **([Promise][7]<any> | [undefined][8])**
Returns **([Promise][8]<any> | [undefined][9])**
## fakerTransform
Expand Down Expand Up @@ -680,7 +686,7 @@ Steps to heal:
## pauseOnFail
Automatically launches [interactive pause][9] when a test fails.
Automatically launches [interactive pause][10] when a test fails.
Useful for debugging flaky tests on local environment.
Add this plugin to config file:
Expand Down Expand Up @@ -863,14 +869,14 @@ Possible config options:
## selenoid
[Selenoid][10] plugin automatically starts browsers and video recording.
[Selenoid][11] plugin automatically starts browsers and video recording.
Works with WebDriver helper.
### Prerequisite
This plugin **requires Docker** to be installed.
> If you have issues starting Selenoid with this plugin consider using the official [Configuration Manager][11] tool from Selenoid
> If you have issues starting Selenoid with this plugin consider using the official [Configuration Manager][12] tool from Selenoid
### Usage
Expand Down Expand Up @@ -899,7 +905,7 @@ plugins: {
}
```
When `autoCreate` is enabled it will pull the [latest Selenoid from DockerHub][12] and start Selenoid automatically.
When `autoCreate` is enabled it will pull the [latest Selenoid from DockerHub][13] and start Selenoid automatically.
It will also create `browsers.json` file required by Selenoid.
In automatic mode the latest version of browser will be used for tests. It is recommended to specify exact version of each browser inside `browsers.json` file.
Expand All @@ -911,10 +917,10 @@ In automatic mode the latest version of browser will be used for tests. It is re
While this plugin can create containers for you for better control it is recommended to create and launch containers manually.
This is especially useful for Continous Integration server as you can configure scaling for Selenoid containers.
> Use [Selenoid Configuration Manager][11] to create and start containers semi-automatically.
> Use [Selenoid Configuration Manager][12] to create and start containers semi-automatically.
1. Create `browsers.json` file in the same directory `codecept.conf.js` is located
[Refer to Selenoid documentation][13] to know more about browsers.json.
[Refer to Selenoid documentation][14] to know more about browsers.json.
_Sample browsers.json_
Expand All @@ -939,7 +945,7 @@ _Sample browsers.json_
2. Create Selenoid container
Run the following command to create a container. To know more [refer here][14]
Run the following command to create a container. To know more [refer here][15]
```bash
docker create \
Expand Down Expand Up @@ -972,15 +978,15 @@ When `allure` plugin is enabled a video is attached to report automatically.
| enableVideo | Enable video recording and use `video` folder of output (default: false) |
| enableLog | Enable log recording and use `logs` folder of output (default: false) |
| deletePassed | Delete video and logs of passed tests (default : true) |
| additionalParams | example: `additionalParams: '--env TEST=test'` [Refer here][15] to know more |
| additionalParams | example: `additionalParams: '--env TEST=test'` [Refer here][16] to know more |
### Parameters
- `config`
## stepByStepReport
![step-by-step-report][16]
![step-by-step-report][17]
Generates step by step report for a test.
After each step in a test a screenshot is created. After test executed screenshots are combined into slideshow.
Expand Down Expand Up @@ -1161,7 +1167,7 @@ This plugin allows to run webdriverio services like:
- browserstack
- appium
A complete list of all available services can be found on [webdriverio website][17].
A complete list of all available services can be found on [webdriverio website][18].
#### Setup
Expand All @@ -1173,7 +1179,7 @@ See examples below:
#### Selenium Standalone Service
Install `@wdio/selenium-standalone-service` package, as [described here][18].
Install `@wdio/selenium-standalone-service` package, as [described here][19].
It is important to make sure it is compatible with current webdriverio version.
Enable `wdio` plugin in plugins list and add `selenium-standalone` service:
Expand All @@ -1190,7 +1196,7 @@ plugins: {
#### Sauce Service
Install `@wdio/sauce-service` package, as [described here][19].
Install `@wdio/sauce-service` package, as [described here][20].
It is important to make sure it is compatible with current webdriverio version.
Enable `wdio` plugin in plugins list and add `sauce` service:
Expand Down Expand Up @@ -1220,40 +1226,42 @@ In the same manner additional services from webdriverio can be installed, enable
- `config`
[1]: https://codecept.io/locators#custom-locators
[1]: https://github.com/cenfun/monocart-coverage-reports?tab=readme-ov-file#default-options
[2]: https://codecept.io/locators#custom-locators
[2]: https://playwright.dev/docs/api/class-elementhandle
[3]: https://playwright.dev/docs/api/class-elementhandle
[3]: https://pptr.dev/#?product=Puppeteer&show=api-class-elementhandle
[4]: https://pptr.dev/#?product=Puppeteer&show=api-class-elementhandle
[4]: https://webdriver.io/docs/api
[5]: https://webdriver.io/docs/api
[5]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String
[6]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String
[6]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function
[7]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function
[7]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise
[8]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise
[8]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined
[9]: https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined
[9]: /basics/#pause
[10]: /basics/#pause
[10]: https://aerokube.com/selenoid/
[11]: https://aerokube.com/selenoid/
[11]: https://aerokube.com/cm/latest/
[12]: https://aerokube.com/cm/latest/
[12]: https://hub.docker.com/u/selenoid
[13]: https://hub.docker.com/u/selenoid
[13]: https://aerokube.com/selenoid/latest/#_prepare_configuration
[14]: https://aerokube.com/selenoid/latest/#_prepare_configuration
[14]: https://aerokube.com/selenoid/latest/#_option_2_start_selenoid_container
[15]: https://aerokube.com/selenoid/latest/#_option_2_start_selenoid_container
[15]: https://docs.docker.com/engine/reference/commandline/create/
[16]: https://docs.docker.com/engine/reference/commandline/create/
[16]: https://codecept.io/img/codeceptjs-slideshow.gif
[17]: https://codecept.io/img/codeceptjs-slideshow.gif
[17]: https://webdriver.io
[18]: https://webdriver.io
[18]: https://webdriver.io/docs/selenium-standalone-service.html
[19]: https://webdriver.io/docs/selenium-standalone-service.html
[19]: https://webdriver.io/docs/sauce-service.html
[20]: https://webdriver.io/docs/sauce-service.html
24 changes: 24 additions & 0 deletions docs/puppeteer.md
Original file line number Diff line number Diff line change
Expand Up @@ -288,6 +288,30 @@ I.usePuppeteerTo('emulate offline mode', async (Puppeteer) => {
});
```

## Capturing Code Coverage

Code coverage can be captured, by enabling the `coverage` plugin in `codecept.config.js`.

```js
{
plugins: {
coverage: {
enabled: true
}
}
}
```

Once all the tests are completed, `codecept` will create and store coverage in `output/coverage` folder, as shown below.

![](https://private-user-images.githubusercontent.com/7845001/313117208-f7165429-426a-44c5-af27-df5536ef492d.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTA0OTEyNTIsIm5iZiI6MTcxMDQ5MDk1MiwicGF0aCI6Ii83ODQ1MDAxLzMxMzExNzIwOC1mNzE2NTQyOS00MjZhLTQ0YzUtYWYyNy1kZjU1MzZlZjQ5MmQucG5nP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDMxNSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDAzMTVUMDgyMjMyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9NjRmNTFmOWUyYzJjYWE3ZWE0MDA0MGI3ODY5NzY5MDRlYjQyNTMxODRjZGU1ZWM5ZDdjNDJiNGRmZGUxM2FlOCZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ._gfEYZn2AK0NVA0bt-sFmzMoMKlyBVpxd7m4590Ux1M)

Open `index.html` in your browser to view the full interactive coverage report.

![](https://private-user-images.githubusercontent.com/7845001/313117882-cb77beea-c478-49ea-8677-b025d5614545.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTA0OTEzOTAsIm5iZiI6MTcxMDQ5MTA5MCwicGF0aCI6Ii83ODQ1MDAxLzMxMzExNzg4Mi1jYjc3YmVlYS1jNDc4LTQ5ZWEtODY3Ny1iMDI1ZDU2MTQ1NDUucG5nP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDMxNSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDAzMTVUMDgyNDUwWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9YmY0YTkxOTM0ZjUyNjZmMzk0NmM4MjU5MGFjZTZlZDc0Njc3OTZkNTNjMjc5YzQxODI3OWUyODJkNTU2NGViZSZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.LATp5aqrvm-8Nn4tRGSuMrOjJQ4L-NIJEwsB3BbB5po)

![](https://private-user-images.githubusercontent.com/7845001/313117886-92a11844-0a2b-4bcb-8c73-aef5cf518dbf.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTA0OTEzOTAsIm5iZiI6MTcxMDQ5MTA5MCwicGF0aCI6Ii83ODQ1MDAxLzMxMzExNzg4Ni05MmExMTg0NC0wYTJiLTRiY2ItOGM3My1hZWY1Y2Y1MThkYmYucG5nP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDMxNSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDAzMTVUMDgyNDUwWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9MTQ4ODUyMTVlM2MwODRhMzE0Yjg2YWQxYTRiNmYzOWJkYWU2ZWIyNDA2YWMyYjIxYTMyNTZkYjg5NGU3Zjk4OCZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.gxyQ9RgAAtFcCUIqqjzponc53ZRn9sG0hN4cBeQovMg)


## Extending Helper

Expand Down
Loading

0 comments on commit 6e552c1

Please sign in to comment.