From fb60a4a9867eb1fc18cf310de2bbb8f21e262e6b Mon Sep 17 00:00:00 2001 From: Johann-S Date: Tue, 6 Mar 2018 06:35:28 +0100 Subject: [PATCH] Add a bit of documentation on how to run the code coverage (#25783) --- js/tests/README.md | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/js/tests/README.md b/js/tests/README.md index 88c35be40258..23c5ff39df54 100644 --- a/js/tests/README.md +++ b/js/tests/README.md @@ -27,16 +27,20 @@ To run the unit test suite via a real web browser, open `index.html` in the brow * Each test should begin with [`assert.expect`](https://api.qunitjs.com/assert/expect/) to ensure that the expected assertions are run. * Each test should follow the project's [JavaScript Code Guidelines](https://github.com/twbs/bootstrap/blob/master/CONTRIBUTING.md#js) +## Code coverage + +Currently we're aiming for at least 80% test coverage for our code. To ensure your changes meet or exceed this limit, run `npm run js-compile && npm run js-test` and open the file in `js/coverage/lcov-report/index.html` to see the code coverage for each plugin. See more details when you select a plugin and ensure your change is fully covered by unit tests. + ### Example tests -```javascript +```js // Synchronous test QUnit.test('should describe the unit being tested', function (assert) { assert.expect(1) - var templateHTML = '
' - + '×' - + '

Template necessary for the test.

' - + '
' + var templateHTML = '
' + + '×' + + '

Template necessary for the test.

' + + '
' var $alert = $(templateHTML).appendTo('#qunit-fixture').bootstrapAlert() $alert.find('.close').trigger('click')