Simple enough question:
I want us sinon.js to test a piece of javascript to ensure that it calls the $.ajax
method while doing two things:
- I don't want to actually hit the server
- I want to mock up a response from the server
so here's the JS:
$.ajax
url: "/tickets/id.json"
dataType: 'json'
.done (data) =>
HandlebarsTemplates["tickets/popup_title"] data
and here's my test:
describe 'PopupDisplayer', ->
beforeEach ->
loadFixtures 'popup_displayer'
new PopupDisplayer
@title_stub = sinon.stub( HandlebarsTemplates, "tickets/popup_title")
@jquery_stub = sinon.stub(jQuery, 'ajax').yieldsTo('done', {})
//This triggers the ajax call
$('.popupable .title').mouseenter()
afterEach ->
HandlebarsTemplates['tickets/popup_title'].restore()
HandlebarsTemplates['tickets/popup_content'].restore()
jQuery.ajax.restore()
@server.restore()
it 'renders the title with the data returned from the server', ->
expect(@title_stub).toHaveBeenCalledWith( {})
This test failed though with the following exception:
TypeError: ajax expected to yield to 'done', but no object with such a property was passed. Received [[object Object]]
So I guess I'm wondering if I can mock up an jQuery request to get a response that can successfully respond to the .done
call apparently I don't understand the defferedObject()
well enough.