function myObject(jsSelector) {
return $(jsSelector).thirdpartycall({
propertya: valuea,
propertyb: valueb
});
};
so if we want to test myObject, we are now stuck with the unfortunate jquery call inside. not to worry, sinon.js to the rescue. first i need to create a fake return object from that javascript call:
var fakeResult = {
propertya,
propertyb,
thirdpartycall: function (values) {
this.propertya = values.propertya;
this.propertyb = values.propertyb;
return true;
}
};
what i do next is to stub jquery, and on using the selector it returns our fake object... yep how cool is that !
make sure when you write your test you wrap it like so (i had some fun with other tests failing after this as I had stubbed jquery permanently !!!)
it("should do something....", sinon.test(function () {
}));
then add the code:
it("should do something....", sinon.test(function () {
$ = this.stub();
$.withArgs('#myselector').returns(fakeResult);
}));
myObject('#myselector');
we then check fakeResult and the properties have been set.
Super awesome.