jQuery chain testing with sinonJS
If you want to test something like this:
$('.selector').siblings('.siblings').toggleClass('hidden');
You can easily try this:
// Fake jQuery methods
var jQueryMethods = { toggleClass: empty, siblings: empty };
// First the methods that can be chained
sinon.stub(jQueryMethods, 'toggleClass').returns(jQueryMethods);
sinon.stub(jQueryMethods, 'siblings').returns(jQueryMethods);
// Then all jQuery function
sinon.stub(window, '$').returns(jQueryMethods);
And now you have full test-ready faked jQuery methods!
thanks for MS
Written by Mateusz Gachowski
Related protips
6 Responses
data:image/s3,"s3://crabby-images/74ad6/74ad6e8d3e5425c9493f86e8cbb97d7c10363e4c" alt=""
Well done mate, glad you posted it here!
over 1 year ago
·
data:image/s3,"s3://crabby-images/b0fa9/b0fa978f99350c193fd617f2c2eba561dbb536cd" alt=""
Thanks to YOU!
over 1 year ago
·
data:image/s3,"s3://crabby-images/dfc7c/dfc7c3f6f4dd99e559806b8064275d58e05cc086" alt=""
Very helpful!
But one thing: You shouldn't use "toggleClass", will you? Apart from it - .removeClass
over 1 year ago
·
data:image/s3,"s3://crabby-images/b0fa9/b0fa978f99350c193fd617f2c2eba561dbb536cd" alt=""
I'm glad that it was helpful.
Just fixed! Thank you!
over 1 year ago
·
data:image/s3,"s3://crabby-images/68283/68283cda414ccd29985b6e01104df0552aba5f08" alt=""
Thanks for this! Saved me a big headache when I switched my Express response calls from the deprecated res.json(status, body) calls to the new res.status(status).json(body) format. Cheers!
over 1 year ago
·
data:image/s3,"s3://crabby-images/b0fa9/b0fa978f99350c193fd617f2c2eba561dbb536cd" alt=""
Happy to help :)
over 1 year ago
·
Have a fresh tip? Share with Coderwall community!
Post
Post a tip
Best
#Tdd
Authors
Sponsored by #native_company# — Learn More
#native_title#
#native_desc#