fix Cypress component debug hook registration

This commit is contained in:
Jonathan Baldie 2026-05-02 09:47:06 +01:00
parent 1fd5c205a9
commit 74755e51d8
2 changed files with 42 additions and 38 deletions

View file

@ -5,7 +5,6 @@ module.exports = defineConfig({
env: { env: {
ABS_CYPRESS_DEBUG_BROWSER: false ABS_CYPRESS_DEBUG_BROWSER: false
}, },
e2e: {
setupNodeEvents(on, config) { setupNodeEvents(on, config) {
on('task', { on('task', {
absCypressDebug(payload) { absCypressDebug(payload) {
@ -34,7 +33,8 @@ module.exports = defineConfig({
}) })
return config return config
} },
e2e: {
}, },
component: { component: {
devServer: { devServer: {

View file

@ -49,20 +49,24 @@ const forwardBrowserDebug = (type, message, details) => {
}, { log: false }) }, { log: false })
} }
window.addEventListener('error', (event) => { if (!window.__absCypressDebugListenersRegistered) {
window.addEventListener('error', (event) => {
forwardBrowserDebug('window-error', event.message || 'Unhandled window error', event.error) forwardBrowserDebug('window-error', event.message || 'Unhandled window error', event.error)
}) })
window.addEventListener('unhandledrejection', (event) => { window.addEventListener('unhandledrejection', (event) => {
const reason = event.reason const reason = event.reason
const message = reason?.message || 'Unhandled promise rejection' const message = reason?.message || 'Unhandled promise rejection'
forwardBrowserDebug('unhandledrejection', message, reason) forwardBrowserDebug('unhandledrejection', message, reason)
}) })
Cypress.on('fail', (error, runnable) => { Cypress.on('fail', (error, runnable) => {
forwardBrowserDebug('cypress-fail', `${runnable?.fullTitle?.() || 'Unknown test'} failed`, error) forwardBrowserDebug('cypress-fail', `${runnable?.fullTitle?.() || 'Unknown test'} failed`, error)
throw error throw error
}) })
window.__absCypressDebugListenersRegistered = true
}
//Cypress.Commands.add('mount', mount) //Cypress.Commands.add('mount', mount)
Cypress.Commands.add('mount', (component, options = {}) => { Cypress.Commands.add('mount', (component, options = {}) => {