2012-04-19 10 views
5

Escribí el siguiente código, intento probar si se justifica y se muestra un diálogo de jquery.¿Cómo se puede mostrar el cuadro de diálogo de prueba de jquery?

var jqueryMock = sinon.mock(jQuery); 
var dialogExpectation = jqueryMock.expects("dialog"); 
dialogExpectation.once(); 

//call my function, in which create a jquery dialog. 

equals(dialogExpectation.verify(), true, "Dialog is displayed"); 
jqueryMock.restore(); 

Sin embargo, me muestra el error: murió en la prueba # 1: Se ha intentado envolver diálogo de propiedad no definida como la función - { "mensaje": "Se ha intentado envolver diálogo de propiedad no definida como la función", "nombre" : "TypeError"}

el código jQuery es muy simple:

displayMessage: function (message, title, hashId) { 

//some logic to build the message, title and hashId. 

$(messageDiv).dialog({ 
      height: 240, 
      width: 375, 
      modal: true, 
      title: title, 
      resizable: false, 
      buttons: [{ 
       text: localizedErrorMessages['OkText'], 
       click: function() { 
        $(this).dialog("close"); 
       } 
      }]    
     }); // end of dialog    
    } // end of displayMessage 

Alguien sabe cómo se burlan de la ventana de diálogo jQuery y escribir pruebas unitarias en este escenario?

+0

¿Para qué marco de prueba es esto? – streetlight

Respuesta

3

Necesitas burlarse jQuery.fn así:

var jQueryMock = sinon.mock(jQuery.fn); 
0

He creado un jsFiddle para demostrar la respuesta de trabajo.

function displayMessage(message, title, hashId) { 

    $("#message").dialog(); 
} 

test("dialog was called", function() { 

    var jQueryMock = sinon.mock($.fn); // jQuery.fn and $.fn are interchangeable 
    var dialogExpectation = jQueryMock.expects("dialog"); 
    dialogExpectation.once(); 

    //call my function, in which create a jquery dialog. 
    displayMessage("new message", "title", 1); 

    equal(dialogExpectation.verify(), true, "Dialog was not displayed"); 
    jQueryMock.restore(); 
}); 

// This demonstrates a failing test - since the method actuall calls "dialog". 
// It also demonstrates a more compact approach to creating the mock 
test("toggle was called", function() { 

    var mock = sinon.mock(jQuery.fn).expects("toggle").once(); 
    displayMessage("new message", "title", 1); 

    equal(mock.verify(), true, "Toggle was never called"); 
}); 
Cuestiones relacionadas