将夜表从1.3.2升级到1.3.4会特别破坏页面对象中的现有测试

问题描述 投票:0回答:1

我正在使用1.3.2版的守夜人。在我将夜表更新到最新版本1.3.4之前,所有测试都工作正常。测试在页面对象中特别中断。我已经检查了守夜人1.3.4的发行说明,它具有通过async/await - https://github.com/nightwatchjs/nightwatch/releases.

支持页面对象的新功能

我相信我收到的错误消息指出了用异步等待包装页面对象。我想知道如何使用async / await更新现有的页面对象。一个带有异步等待的e-g-page对象将对引用很有帮助。我在下面列出了带有页面对象和错误消息的示例测试,在将夜视表更新到最新版本之前,该测试工作正常。任何想法或帮助将不胜感激。

Test
 it('Verify Login', async (browser)=> {
     await this.loginTest.loginSuccess(browser.globals.Username,browser.globals.Password);
     this.homepage.expect.element('@profile').to.be.visible;
  });
Page-Object

module.exports = {

    url:function () {
        return this.api.launchUrl;
    },
    elements:{
        btnSignInRegister:'#SignInRegister',
        btnSelectBusiness:'#business',
        body:'body',
        txtUsernameInput:'#login-username',
        txtPasswordInput:'#login-password',
        signInBtn:'#SignIn',
        pageBody:'body',
        myAccountBtn:'#myAccount',
     },
    commands:[{
        clickSignInRegister(){
            return this
                .click('@btnSignInRegister')
        },
        waitForBody(){
            return this
                .waitForElementVisible('@pageBody')
        },
        loginSuccess(username,pwd){
            return this
                .navigate()
                 .waitForBody()
                .click('@btnSignInRegister')
                .waitForElementVisible('@btnSelectBusiness',5000)
                .click('@btnSelectBusiness')
                .setValue('@txtUsernameInput',username)
                .setValue('@txtPasswordInput',pwd)
                .click('@signInBtn')
                .waitForBody()
        },
        logoutSuccess(){
            return this
                .waitForElementVisible('@btnProfile',5000)
                .click('@btnProfile')
                .waitForElementVisible('@btnLogout',5000)
                .click('@btnLogout')
        }
    }]
}

问题解决了我用异步等待包装功能的问题

 async loginSuccess(username,pwd){
            await this.navigate()
            await this.waitForBody()
            await this.click('@btnSignInRegister')
            //await this.pause(7000);
            await this.waitForElementVisible('@btnSelectBusiness',5000)
            await this.click('@btnSelectBusiness')
            await this.waitForElementVisible('@txtUsernameInput',5000)
            await this.setValue('@txtUsernameInput',username)
            await this.setValue('@txtPasswordInput',pwd)
            await this.click('@signInBtn')
            await this.waitForBody()
        },
        async logoutSuccess(){
           await this.waitForElementVisible('@btnProfile',5000)
           await this.click('@btnProfile')
           await this.waitForElementVisible('@btnLogout',5000)
           await this.click('@btnLogout')
        },
javascript node.js async-await nightwatch.js nightwatch
1个回答
0
投票

我能够弄清楚这个问题。我已经通过将页面对象命令功能升级为await功能来解决了这个问题。请在主帖子中找到示例。

© www.soinside.com 2019 - 2024. All rights reserved.