量角器找不到来自非角度位置的角度

时间:2015-06-09 20:45:36

标签: javascript angularjs protractor

在量角器中,我搜索一个工作正常的LinkText登录。我被重定向到登录站点(非角度)并输入用户名和密码。单击提交按钮我回到了第一个站点。现在登录按钮是一个Logout按钮。但是量角器看不到有角度的部位我只能找到带有硒指示的按钮。

spec.js文件:

it ('should have a login Button to click', function() {
    loginPage.clickLoginButton();
});

it('should be on idm to login', function() {
    var url = browser.driver.getCurrentUrl();
    expect( url ).toEqual('http://localhost/webapp/login');
});

it('should have access with the given user', function() {
    var idmPage = require('./idmPage.js');
    idmPage.setUsername('bla');
    idmPage.setPassword('secret');
    idmPage.clickSubmitButton();
});

pageobject.js:

var IdmPage = function() {
var userField =  browser.driver.findElement(by.id('id_login'));
var passwordField = browser.driver.findElement(by.id('id_password'));
var submitButton = browser.driver.findElement(by.id('authentication-button'));

this.setUsername = function(username) {
    userField.sendKeys(username);
};
this.setPassword = function(password) {
    passwordField.sendKeys(password);
};

this.clickSubmitButton = function() {
    submitButton.click();
}; };  module.exports = new IdmPage();

conf.js

'use strict';

var baseDir ='test / e2e'; exports.config = {

// The adress of a runnung selenium server.
seleniumAddress: 'http://localhost:4444/wd/hub',

//Capabilities to be passed to the webdirver instance.
capabilities: {
    browserName: 'chrome'
},

//Spec patterns are relative to the current working directly when protractor is called

suites: {
    login: baseDir + '/login/**/*_spec.js',
    content: [baseDir + '/content/*_spec.js']
},

//Options to be passed to Jasmine-node
jasmineNodeOpts: {
    onComplete: null,
    isVerbose: true,
    showColors: true,
    includeStackTrace: false,
    defaultTimeoutInterval: 11000
}

};

1 个答案:

答案 0 :(得分:1)

在非角度页面和角度页面之间切换时,您可能需要确保量角器实际上正在等待输入加载。您是否在点击提交按钮后尝试使用browser.sleep()browser.wait()?在测试非角度页面时,您应该设置browser.ignoreSynchronization = true;What is browser.ignoreSynchronization in protractor?

<强>更新

browser.ignoreSynchronization = true;
this.clickLogoutButton = function(){
    browser.wait(function(){
        return loginButton.isPresent();
    }, 10000).then(function(){
        loginButton.click();
    });
}

这样,您的测试将在测试超时之前等待最多10秒。您可以根据按钮看起来可以点击的最长时间来更新它。这就是我处理测试非角度网页的方法。我希望这对你有用