在量角器中,我搜索一个工作正常的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
}
};
答案 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秒。您可以根据按钮看起来可以点击的最长时间来更新它。这就是我处理测试非角度网页的方法。我希望这对你有用