2012-09-11 21 views
2

我开始使用QUnit。我有现有的逻辑是有条件的复选框状态。设置用于qunit测试的复选框

function CheckEmailRequirementSatisfied() { 
if (isEdit == "false") { 
    if ($("#EmailId").val() != "" || $("#IsOtherEmail").is(":checked")) { 
     $("#EmailRequirementSatisfied").val("1"); 
    } else { 
     $("#EmailRequirementSatisfied").val(""); 
    } 
} 
} 

我有以下模块安装和测试。

module("CheckEmailRequirementSatisfied", { 
setup: function() { 
    $("#qunit-fixture").append('<input id="EmailId" /> '); 
    $("#qunit-fixture").append('<input id="EmailRequirementSatisfied" /> '); 
    $("#qunit-fixture").append('<input type="checkbox" name="IsOtherEmail" /> '); 
} 
}); 

test("IsOtherEmail true", function() { 
isEdit = "false"; 
$("#EmailId").val(""); 
$("#EmailRequirementSatisfied").val("test value"); 
/* 
    document.getElementById('IsOtherEmail').checked=true; 
    $("#IsOtherEmail").prop("checked", true); 
    $("#IsOtherEmail").attr("checked", "checked"); 
    $("#IsOtherEmail").val(true); 
*/ 
CheckEmailRequirementSatisfied(); 

ok($("#EmailRequirementSatisfied").val() == "1", "Requirements should be set to 1"); 
}); 

我已经尝试了测试的注释块中的所有选项来设置我的复选框。但它一直没有说,它没有被检查。

使用https://ajax.googleapis.com/ajax/libs/jquery/1.8.1/jquery.min.jshttp://code.jquery.com/qunit/qunit-1.10.0.js

有什么想法?

谢谢。

回答

0

难道不应该行:

$("#qunit-fixture").append('<input type="checkbox" id="IsOtherEmail" /> '); 

即 '身份证',而不是 '名'?

+0

这样做。我看了看,看起来像100次,并没有看到。 谢谢。 – JoshuaMayHome