Skip to content

dorightdigital/JasmineQuery

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

JasmineQuery

How to use

You'll need to include the main JasmineQuery js file in your SpecRunner.html. Then, you'll get access to all the matchers you need to setup mock events manually (because you might not always want them). I'd suggest adding it to the beforeEach just like in the event examples.

See all examples

Why JasmineQuery?

JasmineQuery is the tool various teams we work with were missing from their projects. We'd often ask ourselves "surely there's a simpler way". After a few custom solutions in individual tests which quickly made the tests unreadable it was apparent that this problem needed solving. JasmineQuery is hoping to iteratively grow into everything you need to write readable, managable jQuery tests in Jasmine. See how we're doing so far by reading the examples for yourself. Tests should document behaviours so how better to document the behaviour of a testing helper than write some tests that show how it works!

Who wants to write:

expect($('.myThing').hasClass('active')).toBeTruthy();

When they could write:

expect($('.myThing')).toHaveClass('active');

Who wants to write:

expect($('.myThing').is(':visible')).toBeTruthy();

When they could write:

expect($('.myThing')).toBeVisible();

Who wants to write:

expect($('.myThing').length).toBe(1);

When they could write:

expect($('.myThing')).toExist();

Who wants to write:

expect($('.myThing').find('.active').length).not.toBe(0);

When they could write:

expect($('.myThing')).toContain('.active');

Who wants to write:

expect($('.myThing').text().indexOf('abc') > -1).toBe(true);

When they could write:

expect($('.myThing')).toContainText('abc');

Dev Approach & pull requests

Steward Digital work using some Core Code Quality Principles which should all be pretty familiar. We apply these principles to tools like JasmineQuery as well as full on projects. If there's a feature you think is missing then you might be the first person to need it, you've got 3 choices:

  1. Add it yourself, send a pull request
  2. Document how it should work with a broken test and send a pull request
  3. Email [email protected] to request the new feature

Feedback

It's always good to get feedback. Let us know how you find it at [email protected].

Todo

  • Add support for bubbling events (e.g. clicking a child element should fire the click handler on a parent with appropriate event.target
  • Add support for data param with 'on'
  • Add 'off' support
  • Add 'one' support
  • Support events with namespaces

About

Tools for testing jQuery widgets in Jasmine.

Resources

Stars

Watchers

Forks

Packages

No packages published