/** * Copyright (c) Microsoft Corporation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { test, expect } from './fixtures.js'; test('browser_console_messages', async ({ client, server }) => { server.setContent('/', ` `, 'text/html'); await client.callTool({ name: 'browser_navigate', arguments: { url: server.PREFIX, }, }); const resource = await client.callTool({ name: 'browser_console_messages', }); expect(resource).toHaveTextContent([ '### Result', `[LOG] Hello, world! @ ${server.PREFIX}:4`, `[ERROR] Error @ ${server.PREFIX}:5`, ].join('\n')); }); test('browser_console_messages (page error)', async ({ client, server }) => { server.setContent('/', ` `, 'text/html'); await client.callTool({ name: 'browser_navigate', arguments: { url: server.PREFIX, }, }); const resource = await client.callTool({ name: 'browser_console_messages', }); expect(resource).toHaveTextContent(/Error: Error in script/); expect(resource).toHaveTextContent(new RegExp(server.PREFIX)); }); test('recent console messages', async ({ client, server }) => { server.setContent('/', ` `, 'text/html'); await client.callTool({ name: 'browser_navigate', arguments: { url: server.PREFIX, }, }); const response = await client.callTool({ name: 'browser_click', arguments: { element: 'Click me', ref: 'e2', }, }); expect(response).toContainTextContent(` ### New console messages - [LOG] Hello, world! @`); });