赛普拉斯 - 在一个测试中创建动态电子邮件,如何将其传播到所有其他单独的测试?

Cypress - create a dynamic email in one test, how to propagate it to all other seperate tests?

我正在用 cypress 创建一些集成测试。

我目前已完成注册流程。 - 这是一个文件测试。

registration.spec.js

现在,我想 运行 进行 login.spec.js 测试。如何使用在 registration.spec.js 中创建的动态电子邮件并让该电子邮件现在在 "login.spec.js" 中使用?

registration.spec.js
----> create a dynamic email address
----> do some tests
----> end registration test
login.spec.js
---> login with email/pw I created in the registration.spec.js file?

这是如何实现的。 cypress 中是否有 injectGlobal 类型的交易?

另外,如果我 运行 login.spec.js 作为独立的,有没有办法使用 "supplied" 凭据或通过全局参数从 运行宁所有的测试?这有意义吗?

我想运行所有测试...

registration.spec.js (create dynamic email/pw)
login.spec.js (use dynamic values from registration process)

or 

login.spec.js (standalone, use supplied credentials)

是的,Cypress 支持在 UI 中创建和重用操作和状态的能力,例如在测试前注册和登录。

但是Cypress、到cy.request()允许您比用户更强大地控制浏览器的状态,使您的测试更简单更快更可靠

查看下面的示例,其中 cy.request 用于 create/read 服务器上的状态。

commands/index.js中:

Cypress.Commands.add('login', (user) => {
    cy.request('POST', `${apiUrl}/users/login`, user)
})

Cypress.Commands.add("register", (user) => {
    cy.request('POST', `${apiUrl}/users/register`, user)
})

Cypress.Commands.add('getUser', (username) => {
    return cy.request('GET', `${apiUrl}/users/${username}`)
})

register.spec.js中:

it ('can register', () => {
    const user = {
      name: 'jake',
      email: 'jake@jake.com',
      password: '12345'
    }

    cy.visit('/register')
    cy.get('input[name="name"]').type(user.name)
    cy.get('input[name="email"]').type(user.email)
    cy.get('input[name="password"]').type(user.password)
    cy.get('input[name="password-confirm"]').type(user.password)
    cy.get('input[type="submit"]').click()

    // ensure register page sends you /home after register
    cy.url().should('contain', '/home')

    // expect user from server to match user from test
    cy.getUser(user.name)
    .then((dbUser) => expect(dbUser).to.deep.eql(user))
})

login.spec.js中:

it('can log in', () => {
    const user = {
        name: 'jane',
        email: 'jane@jane.com',
        password: '12345'
    }

    // register w/out UI
    cy.register(user)

    cy.visit('/login')
    cy.get('input[name="name"]').type(user.name)
    cy.get('input[name="password"]').type(user.password)
    cy.get('input[type="submit"]').click()

    // ensure the login page sends you home after login
    cy.url().should('contain', '/home')
})

userSettings.spec.js中:

it('can change email', () => {
    const user = {
        name: 'jane',
        email: 'jane@jane.com',
        password: '12345'
    }

    // register and login w/o UI
    cy.register(user)
    cy.login(user)

    cy.visit('/settings')
    cy.get('input[name="email"]').type('UpdatedEmail@jane.com')
    cy.get('input[type="submit"]').click()

    cy.getUser(user.name)
    .then((dbUser) => expect(dbUser.email).to.eql('UpdatedEmail@jane.com'))
})