在我的应用程序中有一个建议列表,单击该列表会打开一个带有动态地址的新窗口:
$window.open(_shopURL, '_blank');
现在,我试图对Windows.open事件进行存根,如https://github.com/cypress-io/cypress-example-recipes/blob/master/examples/stubbing-spying__window/cypress/integration/window-stubbing.spec.js
Cypress.on('window:before:load', (win) => {
win.open = cy.stub().as('windowOpen')
})
describe('Shop integration', () => {
beforeEach(function () {
cy.visitHome(countryCode, resellerId)
})
it('can stub the window open event', function () {
cy.get(`.recommendations-list .recommendations-cover:nth-of-type(1)`)
.click()
cy.get('@windowOpen').should('be.calledWith', 'page1.html')
})
但是它总是打开新标签,并且日志错误: Cypress: stub open window
有人知道为什么它不起作用吗? 干杯!
答案 0 :(得分:0)
我要为每个要测试的页面使用页面对象。因此,在我的父页面对象(该对象被其他所有PO继承)中,我在打开网址时执行以下操作:
public navigateTo(url: string, defaultTimeout: number = 5000) {
return cy.visit(url, {
onBeforeLoad: (win: any) => {
cy.stub(win, 'open');
},
timeout: defaultTimeOut
});
}
这可以防止窗口打开新页面。
答案 1 :(得分:0)
下面的代码将帮助您存根 window.open 并进一步断言该函数已被触发:
it('opens the about page', () => {
cy.visit('/')
cy.window().then(win => {
cy.stub(win, 'open').as('Open')
})
cy.get('.your-selector').click()
cy.get('@Open').should('have.been.calledOnceWithExactly', yourUrl)
})
您也可以像您一样在 cy.on 钩子中存根 window.open,这有助于您每次在页面重新加载后生成新的窗口对象。但是,如果您想在现有选项卡中实际打开新的 Url 而不是新的,您可以使用下面的代码通过传递 "_self" 参数来覆盖旧的 "_blank" :
cy.window().then(win => {
cy.stub(win, 'open').callsFake((url) => {
return win.open.wrappedMethod.call(win, url, '_self');
}).as('Open');
});
callsFake 函数 动态撤回原来放在 window.open(url, "_blank") 中的 url,也可以手动修改 .call(win, url, ' _self'); 使用静态的,因此无论您单击哪个链接或按钮,触发 window.open,它们都会打开相同的 url。