Ian*_*rds 12 angularjs angularjs-e2e protractor
我正在尝试针对我的本地服务器运行e2e测试并测试生成的url(在单击导航按钮之后)是正确的结果.但是,生成的url始终为false.
我的代码如下所示:
HTML:
//http://localhost/#/current_Page
<html>
<head><title></title></head>
<body>
//should change the current url to
//http://localhost/#/new_page
<button class="button" ng-click="change_page()">Change Page</button>
</html>
Run Code Online (Sandbox Code Playgroud)
测试代码:
var protractor = require('protractor');
require('protractor/jasminewd');
describe('Tests', function() {
var ptor;
describe('Test 1', function() {
var ptor = protractor.getInstance();
ptor.get('#/current_page');
it('change page and current url', function() {
ptor.findElement(protractor.By.className('.button').click().then(function() {
expect(ptor.currentUrl()).toContain('#/new_page');
});
});
}, 30000);
});
Run Code Online (Sandbox Code Playgroud)
问题是单击按钮后的当前URL仍为#/ current_url,并且未更改为预期结果#/ new_page.
有谁知道我哪里出错了?
Ian*_*rds 10
在搜索到这个问题的答案后,我自己想出来了
当前的网址不会失败,我不等待承诺返回角度.下面修改后的代码显示了我出错的地方
var protractor = require('protractor');
require('protractor/jasminewd');
describe('Tests', function() {
var ptor;
describe('Test 1', function() {
var ptor = protractor.getInstance();
ptor.get('#/current_page');
it('change page and current url', function() {
ptor.findElement(protractor.By.className('.button').click().then(function() {
ptor.waitForAngular();
expect(ptor.currentUrl()).toContain('#/new_page');
});
});
}, 30000);
});
Run Code Online (Sandbox Code Playgroud)
然后,等待angular路由到新页面并更新任何绑定,然后继续检查预期的结果,这是我现在期望的结果.
请注意,这并未解决与意外getCurrentUrl()结果相关的所有问题.如果使用driver.findElement(),您可能需要参考JulieMR 对此问题的回答
我希望这有助于有人坚持这个问题.