Hoppa till huvudinnehåll

Webbläsarloggar

När du kör tester kan webbläsaren logga viktig information som du är intresserad av eller vill göra påståenden mot.

När du använder WebDriver Bidi, som är standardsättet hur WebdriverIO automatiserar webbläsaren, kan du prenumerera på händelser från webbläsaren. För logghändelser vill du lyssna på log.entryAdded', t.ex.:

await browser.sessionSubscribe({ events: ['log.entryAdded'] })

/**
* returns: {"type":"console","method":"log","realm":null,"args":[{"type":"string","value":"Hello Bidi"}],"level":"info","text":"Hello Bidi","timestamp":1657282076037}
*/
browser.on('log.entryAdded', (entryAdded) => console.log('received %s', entryAdded))

I ett test kan du helt enkelt skicka logghändelser till en array och påstå att arrayen när din åtgärd är klar, t.ex.:

import type { local } from 'webdriver'

describe('should log when doing a certain action', () => {
const logs: string[] = []

function logEvents (event: local.LogEntry) {
logs.push(event.text) // add log message to the array
}

before(async () => {
await browser.sessionSubscribe({ events: ['log.entryAdded'] })
browser.on('log.entryAdded', logEvents)
})

it('should trigger the console event', () => {
// trigger the browser send a message to the console
...

// assert if log was captured
expect(logs).toContain('Hello Bidi')
})

// clean up listener afterwards
after(() => {
browser.off('log.entryAdded', logEvents)
})
})

Observera att du kan använda denna metod för att hämta felmeddelanden och verifiera om din applikation har stött på några fel.

Welcome! How can I help?

WebdriverIO AI Copilot