2015-02-28 22:54:58 -05:00
## How does Bootstrap's test suite work?
2019-10-09 01:27:43 +03: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-02-28 22:54:58 -05:00
* `visual/` contains "visual" tests which are run interactively in real browsers and require manual verification by humans.
2018-04-01 10:35:51 +03:00
To run the unit test suite via [Karma ](https://karma-runner.github.io/ ), run `npm run js-test` .
2019-03-13 16:23:50 +02:00
To run the unit test suite via [Karma ](https://karma-runner.github.io/ ) and debug, run `npm run js-debug` .
2015-02-28 22:54:58 -05:00
## How do I add a new unit test?
2019-10-09 01:27:43 +03: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 16:23:50 +02: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-02-28 22:54:58 -05:00
3. Write the necessary unit test(s) for the new or revised functionality.
2017-04-20 20:33:51 +10:00
4. Run `npm run js-test` to see the results of your newly-added test(s).
2015-02-28 22:54:58 -05: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?
* Each test should have a unique name clearly stating what unit is being tested.
2019-03-13 16:23:50 +02:00
* Each test should be in the corresponding `describe` .
2015-02-28 22:54:58 -05:00
* Each test should test only one unit per test, although one test can include several assertions. Create multiple tests for multiple units of functionality.
2019-03-13 16:23:50 +02:00
* Each test should use [`expect` ](https://jasmine.github.io/api/edge/matchers.html ) to ensure something is expected.
2015-02-28 22:54:58 -05:00
* Each test should follow the project's [JavaScript Code Guidelines ](https://github.com/twbs/bootstrap/blob/master/CONTRIBUTING.md#js )
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-02-28 22:54:58 -05:00
### Example tests
2018-03-06 06:35:28 +01:00
```js
2015-02-28 22:54:58 -05:00
// Synchronous test
2019-07-28 15:24:46 +02:00
describe('getInstance', () => {
2019-03-13 16:23:50 +02: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 16:23:50 +02: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 16:23:50 +02:00
})
2015-02-28 22:54:58 -05:00
})
// Asynchronous test
2019-03-13 16:23:50 +02:00
it('should show a tooltip without the animation', done => {
fixtureEl.innerHTML = '< a href = "#" rel = "tooltip" title = "Another tooltip" / > '
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-02-28 22:54:58 -05:00
})
```