2015-03-01 04:54:58 +01:00
## How does Bootstrap's test suite work?
2019-10-09 00:27:43 +02:00
Bootstrap uses [Jasmine ](https://jasmine.github.io/ ). Each plugin has a file dedicated to its tests in `tests/unit/<plugin-name>.spec.js` .
2015-03-01 04:54:58 +01:00
2020-05-14 07:33:49 +02:00
- `visual/` contains "visual" tests which are run interactively in real browsers and require manual verification by humans.
2015-03-01 04:54:58 +01:00
2018-04-01 09:35:51 +02:00
To run the unit test suite via [Karma ](https://karma-runner.github.io/ ), run `npm run js-test` .
2019-03-13 15:23:50 +01:00
To run the unit test suite via [Karma ](https://karma-runner.github.io/ ) and debug, run `npm run js-debug` .
2015-03-01 04:54:58 +01:00
## How do I add a new unit test?
2019-10-09 00:27:43 +02:00
1. Locate and open the file dedicated to the plugin which you need to add tests to (`tests/unit/< plugin-name > .spec.js`).
2019-03-13 15:23:50 +01:00
2. Review the [Jasmine API Documentation ](https://jasmine.github.io/pages/docs_home.html ) and use the existing tests as references for how to structure your new tests.
2015-03-01 04:54:58 +01:00
3. Write the necessary unit test(s) for the new or revised functionality.
2017-04-20 12:33:51 +02:00
4. Run `npm run js-test` to see the results of your newly-added test(s).
2015-03-01 04:54:58 +01:00
**Note:** Your new unit tests should fail before your changes are applied to the plugin, and should pass after your changes are applied to the plugin.
## What should a unit test look like?
2020-05-14 07:33:49 +02:00
- Each test should have a unique name clearly stating what unit is being tested.
- Each test should be in the corresponding `describe` .
- Each test should test only one unit per test, although one test can include several assertions. Create multiple tests for multiple units of functionality.
- Each test should use [`expect` ](https://jasmine.github.io/api/edge/matchers.html ) to ensure something is expected.
2020-06-16 20:41:47 +02:00
- Each test should follow the project's [JavaScript Code Guidelines ](https://github.com/twbs/bootstrap/blob/main/.github/CONTRIBUTING.md#js )
2015-03-01 04:54:58 +01:00
2018-03-06 06:35:28 +01:00
## Code coverage
2019-10-02 11:43:54 +02:00
Currently we're aiming for at least 90% test coverage for our code. To ensure your changes meet or exceed this limit, run `npm run js-test-karma` 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.
2018-03-06 06:35:28 +01:00
2015-03-01 04:54:58 +01:00
### Example tests
2018-03-06 06:35:28 +01:00
```js
2015-03-01 04:54:58 +01:00
// Synchronous test
2019-07-28 15:24:46 +02:00
describe('getInstance', () => {
2019-03-13 15:23:50 +01:00
it('should return null if there is no instance', () => {
// Make assertion
2019-07-28 15:24:46 +02:00
expect(Tab.getInstance(fixtureEl)).toEqual(null)
2019-03-13 15:23:50 +01:00
})
it('should return this instance', () => {
fixtureEl.innerHTML = '< div > < / div > '
const divEl = fixtureEl.querySelector('div')
const tab = new Tab(divEl)
// Make assertion
2019-07-28 15:24:46 +02:00
expect(Tab.getInstance(divEl)).toEqual(tab)
2019-03-13 15:23:50 +01:00
})
2015-03-01 04:54:58 +01:00
})
// Asynchronous test
2019-03-13 15:23:50 +01:00
it('should show a tooltip without the animation', done => {
2020-05-06 08:20:08 +02:00
fixtureEl.innerHTML = '< a href = "#" rel = "tooltip" title = "Another tooltip" > < / a > '
2019-03-13 15:23:50 +01:00
const tooltipEl = fixtureEl.querySelector('a')
const tooltip = new Tooltip(tooltipEl, {
animation: false
})
tooltipEl.addEventListener('shown.bs.tooltip', () => {
const tip = document.querySelector('.tooltip')
expect(tip).toBeDefined()
expect(tip.classList.contains('fade')).toEqual(false)
done()
})
tooltip.show()
2015-03-01 04:54:58 +01:00
})
```