gpt4 book ai didi

javascript - 如何使用 Jasmine 测试 HTML DOM click()?

转载 作者:行者123 更新时间:2023-11-28 21:09:01 25 4
gpt4 key购买 nike

我是 Jasmine 测试的新手,我遇到了一个小问题。我有这样的功能:

"redirectPage.js"

function clickThis(){
document.getElementById("link").click();
}

如何测试此函数在我的测试中是否已被调用/触发?

这是我目前的测试:

describe('Test redirectPage', function() {
beforeEach(function() {
loadFixtures("redirectPageFixture.html");
});

it(" checks if the clickThis() method is triggered", function(){
var spyEvent = spyOnEvent("#link", "click");
("#link").trigger("click");
expect(spyEvent).toHaveBeenTriggered();
});
});

但是这样做会给我这个错误:

TypeError: "#link".click is not a function

如何修复此测试?非常感谢任何帮助!

更新:

这是我的装置:

<html>
<head>
<link rel="stylesheet" href="http://netdna.bootstrapcdn.com/bootstrap/3.1.1/css/bootstrap.min.css">
<link rel="stylesheet" href="http://netdna.bootstrapcdn.com/bootstrap/3.1.1/css/bootstrap-theme.min.css">
<script src="http://code.jquery.com/jquery.min.js" defer>
<link rel="stylesheet" href="css/navbar.css">
<link rel="stylesheet" href="css/searchControl.css">
<script type="text/javascript" src="src/main/resources/assets/js/redirectPage.js" defer>
<script src="http://netdna.bootstrapcdn.com/bootstrap/3.1.1/js/bootstrap.min.js"></script>
</head>
<body onload="setTimeout('clickThis();',3000);>
<p><a id=link href = "www.google.com">click here</a></p>
</body>
</html>

最佳答案

我终于明白我做错了什么了。我在我的对象上创建了 spy ,但实际上并没有调用我需要的函数。如果有人感兴趣,这是我现在的测试用例:

it(" checks if the clickThis() method is triggered", function(){
var spyEvent = spyOnEvent("#link", "click");
clickThis();
expect(spyEvent).toHaveBeenTriggered();
});

感谢大家的投入! :)

关于javascript - 如何使用 Jasmine 测试 HTML DOM click()?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42547957/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com