QUnit
| This article relies largely or entirely upon a single source. (February 2015) |
| This article relies too much on references to primary sources. (February 2015) |
| Stable release | 1.17.1 / 20 January 2015 |
|---|---|
| Written in | JavaScript |
| Type | Test automation framework |
| License | MIT |
| Website | qunitjs |
QUnit is a JavaScript unit testing framework. While heavily used by the jQuery Project for testing jQuery, jQuery UI and jQuery Mobile, it is a generic framework to test any JavaScript code. It supports server-side (e.g. node.js) and client-side environments.
QUnit's assertion methods follow the CommonJS unit testing specification, which itself was influenced to some degree by QUnit.
History[edit]
QUnit was originally developed by John Resig as part of jQuery. In 2008 it was extracted from the jQuery unit test source code to form its own project and became known as "QUnit". This allowed others to start using it for writing their unit tests. While the initial version of QUnit used jQuery for interaction with the DOM, a rewrite in 2009 made QUnit completely standalone.
Usage and examples[edit]
QUnit.module(string)- Defines a module, a grouping of one or more tests.QUnit.test(string, function)- Defines a test.
QUnit uses a set of assertion method to provide semantic meaning in unit tests:[1]
assert.ok(boolean, string)- Asserts that the provided value casts to boolean true.assert.equal(value1, value2, message)- Compares two values, using the double-equal operator.assert.deepEqual(value1, value2, message)- Compares two values based on their content, not just their identity.assert.strictEqual(value1, value2, message)- Strictly compares two values, using the triple-equal operator.
A basic example would be as follows:[2]
QUnit.test('a basic test example', function (assert) { var obj = {}; assert.ok(true, 'Boolean true'); // passes assert.ok(1, 'Number one'); // passes assert.ok(false, 'Boolean false'); // fails obj.start = 'Hello'; obj.end = 'Ciao'; assert.equal(obj.start, 'Hello', 'Opening greet'); // passes assert.equal(obj.end, 'Goodbye', 'Closing greet'); // fails });
See also[edit]
References[edit]
- ^ "Assert methods". QUnit API Documentation. Retrieved 2014-06-02.
- ^ "Cookbook: Example test". QUnit API Documentation. Retrieved 2014-06-02.