我正在使用量角器和茉莉花来测试网站。我想知道当前的网址,以便验证测试。
我试过了
function waitForUrlToChangeTo(urlRegex) {
var currentUrl;
return browser.getCurrentUrl().then(function storeCurrentUrl(url) {
currentUrl = url;
}
).then(function waitForUrlToChangeTo() {
return browser.wait(function waitForUrlToChangeTo() {
return browser.getCurrentUrl().then(function compareCurrentUrl(url) {
return urlRegex.test(url);
});
});
}
);
}
我正在以这种方式使用这个功能
it('should log', function() {
//element(by.model('user.username')).sendKeys('asd');
//element(by.model('user.password')).sendKeys('asd');
element(by.linkText('Acceder')).click();
waitForUrlToChangeTo("http://localhost:9000/#/solicitudes");
});
答案 0 :(得分:41)
Alecxe your answer was very helpful.
But couldn't you just code:
expect(browser.getCurrentUrl()).toEqual('whateverbrowseryouarexpectingtobein');
And if this fails, then you know you're going to the wrong place.
答案 1 :(得分:40)
如果您只想查看当前网址,请使用browser.getCurrentUrl()
:
expect(browser.getCurrentUrl()).toEqual("expectedUrl");
但是,如果您需要等到URL匹配某个值,请参阅答案的下一部分。
以下是基于Expected Conditions的作者提供的示例的工作代码:
var urlChanged = function(url) {
return function () {
return browser.getCurrentUrl().then(function(actualUrl) {
return url != actualUrl;
});
};
};
用法:
element(by.linkText('Acceder')).click();
browser.wait(urlChanged("http://localhost:9000/#/solicitudes"), 5000);
答案 2 :(得分:6)
从Protractor 4.0.0起,您现在可以使用预期条件来了解您的网址何时更改。
const EC = protractor.ExpectedConditions;
browser.wait(EC.urlContains('my-url'), 5000);
我发现的asnwer来自this one,我没有真正的信用。但万一它有所帮助。