Files
playwright-mcp/tests/vscode.spec.ts

120 lines
3.1 KiB
TypeScript

/**
* 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_connect(vscode) works', async ({ startClient, playwright, browserName }) => {
const { client } = await startClient({
args: ['--vscode'],
});
const server = await playwright[browserName].launchServer();
expect(await client.callTool({
name: 'browser_connect',
arguments: {
connectionString: server.wsEndpoint(),
lib: import.meta.resolve('playwright'),
}
})).toHaveResponse({
result: 'Successfully connected.'
});
expect(await client.callTool({
name: 'browser_navigate',
arguments: {
url: 'data:text/html,foo'
}
})).toHaveResponse({
pageState: expect.stringContaining('foo'),
});
await server.close();
expect(await client.callTool({
name: 'browser_snapshot',
arguments: {}
}), 'it actually used the server').toHaveResponse({
isError: true,
result: expect.stringContaining('ECONNREFUSED')
});
});
test('browser_connect(debugController) works', async ({ startClient }) => {
test.skip(!globalThis.WebSocket, 'WebSocket is not supported in this environment');
const { client } = await startClient({
args: ['--vscode'],
});
expect(await client.callTool({
name: 'browser_connect',
arguments: {
debugController: true,
}
})).toHaveResponse({
result: 'No open browsers.'
});
expect(await client.callTool({
name: 'browser_navigate',
arguments: {
url: 'data:text/html,foo'
}
})).toHaveResponse({
pageState: expect.stringContaining('foo'),
});
const response = await client.callTool({
name: 'browser_connect',
arguments: {
debugController: true,
}
});
expect(response.content?.[0].text).toMatch(/Version: \d+\.\d+\.\d+/);
const url = new URL(response.content?.[0].text.match(/URL: (.*)/)?.[1]);
const messages: unknown[] = [];
const socket = new WebSocket(url);
socket.onmessage = event => {
messages.push(JSON.parse(event.data));
};
await new Promise((resolve, reject) => {
socket.onopen = resolve;
socket.onerror = reject;
});
socket.send(JSON.stringify({
id: '1',
guid: 'DebugController',
method: 'setReportStateChanged',
params: {
enabled: true,
},
metadata: {},
}));
expect(await client.callTool({
name: 'browser_navigate',
arguments: {
url: 'data:text/html,bar'
}
})).toHaveResponse({
pageState: expect.stringContaining('bar'),
});
await expect.poll(() => messages).toContainEqual(expect.objectContaining({ method: 'stateChanged' }));
});