如何使用量角器获取当前网址?

时间:2015-04-01 18:09:28

标签: javascript angularjs url testing protractor

我正在使用量角器和茉莉花来测试网站。我想知道当前的网址,以便验证测试。

我试过了

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");
});

3 个答案:

答案 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,我没有真正的信用。但万一它有所帮助。

Protractor- Generic wait for URL to change