chai-jquery is an extension to the chai assertion library that provides a set of jQuery-specific assertions.
Include chai-jquery.js
in your test file, after chai.js
(version 1.0.0-rc1 or later):
<script src="chai-jquery.js"></script>
Use the assertions with chai's expect
or should
assertions.
Assert that the first element of the selection has the given attribute, using .attr()
.
Optionally, assert a particular value as well. The return value is available for chaining.
$('#header').should.have.attr('foo');
expect($('body')).to.have.attr('foo', 'bar');
expect($('body')).to.have.attr('foo').match(/bar/);
Assert that the first element of the selection has the given property, using .prop()
.
Optionally, assert a particular value as well. The return value is available for chaining.
$('#header').should.have.prop('disabled');
expect($('body')).to.have.prop('disabled', false);
expect($('body')).to.have.prop('value').match(/bar/);
Assert that the first element of the selection has the given CSS property, using .css()
.
Optionally, assert a particular value as well. The return value is available for chaining.
$('#header').should.have.css('background');
expect($('body')).to.have.css('background-color', '#ffffff');
expect($('body')).to.have.css('font-family').match(/sans-serif/);
Assert that the first element of the selection has the given data value, using .data()
.
Optionally, assert a particular value as well. The return value is available for chaining.
$('#header').should.have.data('foo');
expect($('body')).to.have.data('foo', 'bar');
expect($('body')).to.have.data('foo').match(/bar/);
Assert that the first element of the selection has the given class, using .hasClass()
.
$('#header').should.have.class('foo');
expect($('body')).to.have.class('foo');
Assert that the first element of the selection has the given id, using .attr('id')
.
$('.header').should.have.id('#main');
expect($('body')).to.have.id('foo');
Assert that the html of the first element of the selection is equal to the given html, using .html()
.
$('.name').should.have.html('<em>John Doe</em>');
expect($('#title')).to.have.html('Chai Tea');
Assert that the text of the first element of the selection is equal to the given text, using .text()
.
$('.name').should.have.text('John Doe');
expect($('#title')).to.have.text('Chai Tea');
Assert that the first element of the selection has the given value, using .val()
.
$('.name').should.have.value('John Doe');
expect($('.year')).to.have.value('2012');
Assert that at least one element of the selection is visible, using .is(':visible')
.
$('.name').should.be.visible;
expect($('.year')).to.be.visible;
hidden
Assert that at least one element of the selection is hidden, using .is(':hidden')
.
$('.name').should.be.hidden;
expect($('.year')).to.be.hidden;
Assert that at least one element of the selection is selected, using .is(':selected')
.
$('option').should.be.selected;
expect($('option')).not.to.be.selected;
Assert that at least one element of the selection is checked, using .is(':checked')
.
$('.checked').should.be.checked;
expect($('input')).not.to.be.checked;
Assert that at least one element of the selection is enabled, using .is(':enabled')
.
$('.enabled').should.be.enabled;
expect($('enabled')).to.be.enabled;
Assert that at least one element of the selection is disabled, using .is(':disabled')
.
$('.disabled').should.be.disabled;
expect($('input')).not.to.be.disabled;
Assert that at least one element of the selection is empty, using .is(':empty')
.
If the object asserted against is not a jQuery object, the original implementation will be called.
$('.empty').should.be.empty;
expect($('body')).not.to.be.empty;
Assert that the selection is not empty. Note that this overrides the built-in chai assertion. If the object asserted against is not a jQuery object, the original implementation will be called.
$('#exists').should.exist;
expect($('#nonexistent')).not.to.exist;
Assert that the selection matches a given selector, using .is()
. Note that the
built-in behavior of the match
function and be
property is preserved -- if the object asserted against is
not a jQuery object, or if be
is not called as a function, the original implementation will be called. Otherwise,
match
and be
are synonyms -- use whichever one reads better.
$('input').should.match('#foo');
expect($('#empty')).to.be(':empty');
Assert that the selection contains the given text, using :contains()
.
If the object asserted against is not a jQuery object, or if contain
is not called as a function, the original
implementation will be called.
$('body').should.contain('text');
expect($('#content')).to.contain('text');
Assert that the selection contains at least one element which has a descendant matching the given selector,
using .has()
. If the object asserted against is not a jQuery object, or if have
is not called as a function, the original implementation will be called.
$('body').should.have('h1');
expect($('#content')).to.have('div');
Note that this assertion has the unfortunate side effect of causing assertions such as
expect(selection).to.have.length(2)
to fail. The technical cause is that the have
property must be a function,
and functions have a built-in length
property that cannot be modified. As as workaround, write the assertion
as expect(selection).to.be.of.length(2)
instead.
To run the test suite, run npm install
(requires
Node.js to be installed on your system), and open
test/index.html
in your web browser.
Copyright (c) 2012 John Firebaugh
MIT License (see the LICENSE file)