0

您可以将常规RequiredValidator 用于文本框,但不能用于标签,因此我添加了自定义验证器并使用JQuery 函数对其进行验证。一切正常,但我希望能够对其进行单元测试。

为了测试这个功能,我需要做些什么改变:

function LabelRequired_Validate(sender, args) {
    if (sender == $("#ctl00_cphMain_Agent2_Agent_Agent_LabelValidator1")[0]) {
        if ($("#ctl00_cphMain_Agent2_Agent_Agent_ValueLabel")[0].innerText.length > 0) {
            args.IsValid = true;
        } else {
            args.IsValid = false;
        }
    } else {
        args.IsValid = true;
    }
}

使用此 QUnit 测试(或类似测试):

test("Servicing_Topup_Branch_label_is_valid", function() {
    var span = $("span[id$=ValueLabel]");
    $(span).text(10 + " characters long");

    var args = { IsValid: true, Value: "" };
    LabelRequired_Validate($(span), args)

    ok(args.IsValid == true, "Validation Passed!");
});

这是我的自定义验证器:

<asp:CustomValidator ID="LabelValidator1" runat="server" ErrorMessage="<%$Resources:Main,RequiredFieldWarning %>"
        Display="Dynamic" ClientValidationFunction="LabelRequired_Validate" EnableViewState="False"
        class="alertMsg">
    </asp:CustomValidator>
4

1 回答 1

0

对目标和测试功能进行了一些更改。这是它的工作原理。

到目标:

function LabelRequired_Validate(sender, args) {
    if (sender == $("span[id$=LabelValidator1]")[0]) {
        if ($("span[id$=ValueLabel]")[0].innerText.length > 0) {
            args.IsValid = true;
        } else {
            args.IsValid = false;
        }
    } else {
        args.IsValid = true;
    }
} 

并进行测试:

test("Servicing_Topup_Branch_label_required_is_valid", function() {
    expect(2);

    var span1 = $("span[id$=LabelValidator1]");
    var span2 = $("span[id$=ValueLabel]");

    $(span2).text(18 + " characters long");
    var args = { IsValid: true, Value: "" };
    LabelRequired_Validate(span1[0], args)

    ok(args.IsValid == true, "Not empty label returns Valid - Passed!");


    $(span2).text("");
    args = { IsValid: true, Value: "" };
    LabelRequired_Validate(span1[0], args)

    ok(args.IsValid == false, "Empty label returns NotValid - Passed!");

});
于 2012-08-09T14:35:15.260 回答