量角器测试脚本的执行速度比页面加载速度快

时间:2017-06-23 10:05:57

标签: javascript angularjs selenium selenium-webdriver protractor

我正在自动化具有登录功能的角度js网站。我只想点击登录链接并输入用户名和密码。但不知何故,我的脚本执行速度比页面加载快。请告诉我如何处理这个问题: 我的登录页面对象是:

'use strict'
// Normal Login 
require('../page-objects/loginPage.js');
var customerPortalHome = function () {

    this.clickSignIn = function () {
        browser.sleep(5000);
        element(by.linkText('Sign In')).click();
        browser.waitForAngular();
        browser.sleep(2000);
        return require('./loginPage.js');

    }

}


module.exports = new customerPortalHome();

我的测试规格是;

var co = require('co');
var UI = require('./ui.js');
var ui = new UI();
var CustomerPage = require('../page-objects/customerPortalHome.js')

describe(" Smoke Test Login to the application", function () {

        it("test", co.wrap(function* () {
            var EC = protractor.ExpectedConditions;
             browser.get(ui.createStartLink());
            expect(browser.getTitle()).toContain("Portal");
            // Verify if user is able to Login into the application
            var loginPage =  CustomerPage.clickSignIn();
            loginPage.switchToFrame('account-sdk');
            var reportPage = loginPage.clickLogin('$$$$$@gmail.com', '$$$$$');
            expect(browser.getCurrentUrl()).toContain('reports');
            reportPage.clickSignOut();
            expect(browser.getCurrentUrl()).toContain("?signout");
            browser.sleep(800);
        }));

    }); 

每当我执行测试时,浏览器会打开一秒钟然后关闭。

我的Onprepare方法如下所示:

beforeLaunch: function () {
        return new Promise(function (resolve) {
            reporter.beforeLaunch(resolve);
        });
    },
    onPrepare: function () {
        browser.manage().timeouts().implicitlyWait(5000);

        afterEach(co.wrap(function* () {
            var remote = require('protractor/node_modules/selenium-webdriver/remote');
            browser.driver.setFileDetector(new remote.FileDetector());



        }));

3 个答案:

答案 0 :(得分:1)

使用浏览器睡眠绝不是一个好主意,最好的办法是等待一个元素并使用then函数来执行此操作。

element(by.xpath("xpath")).click().then(function(){
      var list = element(by.id('id'));
      var until = protractor.ExpectedConditions;
      browser.wait(until.presenceOf(list), 80000, 'Message: took too long');
    });

答案 1 :(得分:0)

browser.wait(protractor.ExpectedConditions.visibilityOf($$('.desk-sidebar > li').get(num-1)), 60000);

通常,我会使用此等待。

答案 2 :(得分:0)

你是否使用了ignoreSynchronisation而没有在页面对象帮助器中的某处放置false?

注意,当有很多重定向时,登录有时会破坏waitForAngular。我最终使用脏睡眠来等待记录时加载页面(没有找到其他解决方案,ignoreSync,EC更改url并等待元素不能正常工作)。

你也应该分享你得到的错误。