等待页面加载 - Cypress

Eni*_*Eni 9 javascript testing automated-tests pageload cypress

我遇到问题,因为页面未完全加载。我尝试了该cy.wait(1000)方法,我认为这不是一个好的解决方案,但仍然不起作用,页面未完全加载。

这是我正在尝试测试的网站https://www.24mx.ie/。代码在文件中homePage.js

class HomePage {
  static loadHomePage() {
    cy.visit(Cypress.env('url') + '.ie/');
    cy.wait(1000)      
  }

  static acceptCookies() {
    cy.get('div.m-button.m-button--navigation.m-button--xs.qa-consent-agree-btn.ng-tns-c95-8').click();
  }
}

export default HomePage
Run Code Online (Sandbox Code Playgroud)

文件 homePage.spec.js 中的代码

import HomePage from '../pageObjects/homePage'

describe('Home Page Test', function () {
    it('Home Page TC', function () {
        HomePage.loadHomePage();
    })

    it('Accepting Cookies TC', function () {
        HomePage.acceptCookies();
    })

})
Run Code Online (Sandbox Code Playgroud)

这是测试的打印屏幕:

在此输入图像描述

Mik*_*kel 15

您应该执行 acy.get().should()让 Cypress 等待页面上出现某些内容。

如果页面正忙于执行 API 请求,您可以执行cy.intercept()一个或多个 API 调用,然后等待它们。这将为您在等待元素出现之前赢得一些时间。您可以查看 Chrome 调试工具中的网络选项卡,了解页面正在发出哪些 API 请求。我会选择一个需要一些时间加载的,然后等待。

这是“等待”页面加载的更好方法,而不是执行cy.wait()

  • 这应该是公认的答案。比使用 cy.wait() 更好 (2认同)

Ala*_*Das 9

为了确保页面已成功加载,您可以断言任何元素可见。由于页面加载后您单击接受 cookie 按钮,我建议断言与可见相同,例如:

class HomePage {
  static loadHomePage() {
    cy.visit(Cypress.env('url') + '.ie/');
    cy.get('[class*=qa-consent-agree-btn]', {
      timeout: 5000
    }).should('be.visible') //Make sure Cookie Accept button is visible with timeout of 5 seconds. You can increase timeout as required.     
    }

    static acceptCookies() {
      cy.get('[class*=qa-consent-agree-btn]').click();
    }
  }

  export default HomePage
Run Code Online (Sandbox Code Playgroud)