In Node.js
In the browser
Getting Started in the browser
Guides
Check these QUnit tutorials and examples, to make the most of your unit tests!
- QUnit.module: How to group related tests.
- QUnit.test: Define tests, How to wait for async code.
- Fixture feature: Keeping your DOM tests atomic.
- Step API: Testing asynchronous callbacks or event listeners.
- Assertions: Partial object comparison, expected exceptions, and much more.
- Browser: Productivity tricks, Browser automation, What can the toolbar do?
- CLI: Productivity tricks, Code coverage.
- Reporter API: Event emitter, Create your own reporter.
- Theme API: Create your own theme.
Compatibility
QUnit supports the following browsers and runtime environments:
| QUnit 1 | QUnit 2 | QUnit 3 | QUnit 3 (ESM) | |
|---|---|---|---|---|
| Internet Explorer | IE 6-11 | IE 9-11 | — | |
| Edge | 1+ | 15+[?] | 16+ | |
| Firefox | 3.6+ | 45+ | 60+ | |
| Safari | 4.0+ | 9.1+ | 10.1+ | |
| Chrome | 1+ | 58+ | 61+ | |
| Chrome Mobile | — | 49+ (Android 4.4+) | 61+ (Android 7+) | |
| Opera | 11+ | 36+ | 48+ | |
| Android Browser | 2.3 - 5.0 | 4.3 - 5.0 | — | |
| iOS (Mobile Safari) | 4.0+ | 7.0+ | 10.3+ | |
| PhantomJS | 1.x | — | ||
| Node.js | — | 10+ | 18+ | |
| SpiderMonkey | — | 68+[?] | ||
You can download QUnit 1.x and QUnit 2.x from the release archives.
Support
To report a bug, request a new feature, or ask a question open an issue on GitHub.
You can also find support on StackOverflow. Use the “qunit” hashtag on StackOverflow to search existing questions or ask your own question.
Chat
If you need help, or want to participate in sharing and discussing ideas, join us in the chat room on Matrix at #qunitjs_qunit:gitter.im:
- Gitter web client, browse the room as guest.
- Element web client, join and log in (with GitHub, GitLab, Google, or Apple ID), or sign up.
- matrix.to link, join with the Element native app or other Matrix client.
Social media
Follow us:
Hashtags:
Linting
The eslint-plugin-qunit package has a variety of rules available for enforcing best testing practices as well as detecting broken tests.
Download
These are the official release channels for QUnit releases:
- 
    Download: You can save the qunit-2.24.1.jsandqunit-2.24.1.cssfiles directly from the jQuery CDN. For older versions, browse the release archives.Or download them via the terminal, and save them in your Git repository. curl -o qunit.css 'https://code.jquery.com/qunit/qunit-2.24.1.css' curl -o qunit.js 'https://code.jquery.com/qunit/qunit-2.24.1.js'
- 
    npm Registry: If your development workflow uses Node.js, you can install the qunit package from the npm Registry, using the npmCLI:npm install --save-dev qunitOr, if using Yarn: yarn add --dev qunitYou can then reference these in your HTML: <link rel="stylesheet" href="./node_modules/qunit/qunit/qunit.css"> <script src="./node_modules/qunit/qunit/qunit.js"></script>If your project uses an npm alternative that locates packages elsewhere, you may need to generate the HTML dynamically and use require.resolve()to locatequnit/qunit/qunit.jsandqunit/qunit/qunit.css. Alternatively, use one of the Integrations such as karma-qunit which can do this for you.
- 
    Bower: QUnit 1.x and QUnit 2.x releases were published to Bower, and remain available there under the qunitpackage.For QUnit 3.0 and later, either download and commit the JS and CSS file directly in your project (e.g. using the curl command above), or install the qunitpackage from npm as a dev dependency.
Further reading
- Read QUnit documentation offline, via DevDocs.
- Introduction to JavaScript Unit Testing, Jörn Zaefferer (2012).