我认为Done会让事情同步运行,这意味着在点击链接后,点击回拨会在点击后发生,显然不是因为这不起作用。
browser.ignoreSynchronization = true;
var firstURL = "https://www.google.com/?gws_rd=ssl";
describe("test", function () {
browser.get("http://www.google.com");
it("Should be on google url", function () {
expect(browser.getCurrentUrl()).toBe(firstURL);
});
it("Should be able to type in text and click", function (done) {
var ele = element.all(by.name("q")).first();
ele.sendKeys("Protractor API");
ele.click().then(function () {
expect(true).toBe(true);
done();
});
});
it("Should be on new page", function (done) {
browser.driver.getCurrentUrl().then(function (url) {
debugger;
done();
});
});
});
代码底部的getCurrentUrl()返回第一页的URL。当我在浏览器中看到它从测试中发生变化时,如何获取当前URL?
答案 0 :(得分:3)
您认为更改网址后click
承诺会得到解决,但由于您正在测试非角度网页并关闭同步,因此会立即解决。
你应该等待网址改变自己:
var urlChanged = function(expectedUrl) {
return function() {
return browser.getCurrentUrl().then(function(url) {
return url.indexOf(expectedUrl) > -1;
});
};
};
然后在测试中:
ele.click().then(function () {
browser.wait(urlChanged('google'), 5000);
done();
});