赛普拉斯:页面不会在点击操作的第二个 'it' 块中加载
Cypress: Page doesn't load within the second 'it' block for the click action
如果我在单个 'it' 块中进行编码,那么对于相同的点击事件它工作正常,如下所示。
工作代码:
describe('Test Suite', () => {
it('Test case 1', () => {
//Test 1
//Test 2
})
})
不工作:
describe('Test Suite', () => {
it('Test case 1', () => {
//Test 1
})
it('Test case 2', () => {
//Test 2
})
})
下面是我的代码片段,第一个 'it' 块在登录方法执行后工作正常。其次,它会阻止单击正确的元素,但页面永远不会加载。
P.S. 如果我在单个 'it' 块下编写代码,页面加载和工作正常。
describe('Fund Manager Suite', () => {
//Checking Fund Manager page loading
before(() => {
cy.visit('xxxxxxxxxxxxx')
cy.login('xxxxx', 'xxxxx')
})
it('fund manager navigation works', () => {
cy.location('pathname').should('equal', '/xxxxx')
cy.get('#appSwitcher').click()
cy.get('#appSwitcher > .dropdown > .dropdown-menu > :nth-child(2) > a').click()
cy.location('pathname').should('equal', '/xxxxx')
cy.get('.k-grid-table').find('tr').should('have.length', 5)
})
it('fund detail works', () => {
cy.get('.product > :nth-child(2)').click()
cy.location('pathname').should('equal', '/xxxxx')
// Fund Detail - Search
cy.get('#s2id_autogen31').type('Rach')
cy.get('#select2-result-label-32').click()
cy.get('#searchSubmit').click()
cy.get('#DataTables_Table_0').find('tr').should('have.length', 10)
})
})
Execution Screen shot
Code snippet screen shot
您必须在 beforeEach()
中保留您的 cookie,以确保您在所有 it()
块中保持登录状态。您可以在 cypress docs.
中阅读更多内容
describe('Dashboard', () => {
before(() => {
// log in only once before any of the tests run.
// your app will likely set some sort of session cookie.
// you'll need to know the name of the cookie(s), which you can find
// in your Resources -> Cookies panel in the Chrome Dev Tools.
cy.login()
})
beforeEach(() => {
// before each test, we can automatically preserve the
// 'session_id' and 'remember_token' cookies. this means they
// will not be cleared before the NEXT test starts.
//
// the name of your cookies will likely be different
// this is an example
Cypress.Cookies.preserveOnce('session_id', 'remember_token')
})
it('displays stats', () => {
// ...
})
it('can do something', () => {
// ...
})
it('opens a modal', () => {
// ...
})
})
我见过这种行为,当第一个 it case
开始但没有完成站点中的一些 xhr 请求时 - 结果是 cypress 在第二个 it 案例开始时继续该过程。对于我发现的每个案例,最好的解决方案是将每个案例分开到不同的文件中
更新:
可以通过存储 session_id 来解决这个问题。
Cypress.Cookies.defaults({
preserve: "session_id"
})
如果我在单个 'it' 块中进行编码,那么对于相同的点击事件它工作正常,如下所示。
工作代码:
describe('Test Suite', () => {
it('Test case 1', () => {
//Test 1
//Test 2
})
})
不工作:
describe('Test Suite', () => {
it('Test case 1', () => {
//Test 1
})
it('Test case 2', () => {
//Test 2
})
})
下面是我的代码片段,第一个 'it' 块在登录方法执行后工作正常。其次,它会阻止单击正确的元素,但页面永远不会加载。
P.S. 如果我在单个 'it' 块下编写代码,页面加载和工作正常。
describe('Fund Manager Suite', () => {
//Checking Fund Manager page loading
before(() => {
cy.visit('xxxxxxxxxxxxx')
cy.login('xxxxx', 'xxxxx')
})
it('fund manager navigation works', () => {
cy.location('pathname').should('equal', '/xxxxx')
cy.get('#appSwitcher').click()
cy.get('#appSwitcher > .dropdown > .dropdown-menu > :nth-child(2) > a').click()
cy.location('pathname').should('equal', '/xxxxx')
cy.get('.k-grid-table').find('tr').should('have.length', 5)
})
it('fund detail works', () => {
cy.get('.product > :nth-child(2)').click()
cy.location('pathname').should('equal', '/xxxxx')
// Fund Detail - Search
cy.get('#s2id_autogen31').type('Rach')
cy.get('#select2-result-label-32').click()
cy.get('#searchSubmit').click()
cy.get('#DataTables_Table_0').find('tr').should('have.length', 10)
})
})
Execution Screen shot Code snippet screen shot
您必须在 beforeEach()
中保留您的 cookie,以确保您在所有 it()
块中保持登录状态。您可以在 cypress docs.
describe('Dashboard', () => {
before(() => {
// log in only once before any of the tests run.
// your app will likely set some sort of session cookie.
// you'll need to know the name of the cookie(s), which you can find
// in your Resources -> Cookies panel in the Chrome Dev Tools.
cy.login()
})
beforeEach(() => {
// before each test, we can automatically preserve the
// 'session_id' and 'remember_token' cookies. this means they
// will not be cleared before the NEXT test starts.
//
// the name of your cookies will likely be different
// this is an example
Cypress.Cookies.preserveOnce('session_id', 'remember_token')
})
it('displays stats', () => {
// ...
})
it('can do something', () => {
// ...
})
it('opens a modal', () => {
// ...
})
})
我见过这种行为,当第一个 it case
开始但没有完成站点中的一些 xhr 请求时 - 结果是 cypress 在第二个 it 案例开始时继续该过程。对于我发现的每个案例,最好的解决方案是将每个案例分开到不同的文件中
更新:
可以通过存储 session_id 来解决这个问题。
Cypress.Cookies.defaults({
preserve: "session_id"
})