playwright-mcp/tests/core.spec.ts

240 lines
5.8 KiB
TypeScript
Raw Normal View History

2025-03-21 10:58:58 -07:00
/**
* 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';
2025-03-21 10:58:58 -07:00
test('browser_navigate', async ({ client, server }) => {
2025-03-27 16:50:43 -07:00
expect(await client.callTool({
name: 'browser_navigate',
arguments: { url: server.HELLO_WORLD },
2025-03-27 16:50:43 -07:00
})).toHaveTextContent(`
- Ran Playwright code:
\`\`\`js
// Navigate to ${server.HELLO_WORLD}
await page.goto('${server.HELLO_WORLD}');
\`\`\`
- Page URL: ${server.HELLO_WORLD}
2025-03-21 10:58:58 -07:00
- Page Title: Title
- Page Snapshot
\`\`\`yaml
2025-05-09 18:01:17 -07:00
- generic [ref=e1]: Hello, world!
2025-03-21 10:58:58 -07:00
\`\`\`
2025-03-27 23:47:15 +01:00
`
2025-03-27 16:50:43 -07:00
);
2025-03-21 10:58:58 -07:00
});
test('browser_click', async ({ client, server }) => {
server.setContent('/', `
<title>Title</title>
<button>Submit</button>
`, 'text/html');
2025-03-27 16:50:43 -07:00
await client.callTool({
name: 'browser_navigate',
arguments: { url: server.PREFIX },
2025-03-27 16:50:43 -07:00
});
2025-03-21 10:58:58 -07:00
2025-03-27 16:50:43 -07:00
expect(await client.callTool({
name: 'browser_click',
arguments: {
element: 'Submit button',
2025-05-09 18:01:17 -07:00
ref: 'e2',
2025-03-27 16:50:43 -07:00
},
})).toHaveTextContent(`
- Ran Playwright code:
\`\`\`js
// Click Submit button
await page.getByRole('button', { name: 'Submit' }).click();
\`\`\`
2025-03-21 10:58:58 -07:00
- Page URL: ${server.PREFIX}
2025-03-21 10:58:58 -07:00
- Page Title: Title
- Page Snapshot
\`\`\`yaml
2025-05-09 18:01:17 -07:00
- button "Submit" [ref=e2]
2025-03-21 10:58:58 -07:00
\`\`\`
2025-03-27 16:50:43 -07:00
`);
2025-03-21 10:58:58 -07:00
});
test('browser_select_option', async ({ client, server }) => {
server.setContent('/', `
<title>Title</title>
<select>
<option value="foo">Foo</option>
<option value="bar">Bar</option>
</select>
`, 'text/html');
2025-03-27 16:50:43 -07:00
await client.callTool({
name: 'browser_navigate',
arguments: { url: server.PREFIX },
2025-03-27 16:50:43 -07:00
});
2025-03-27 16:50:43 -07:00
expect(await client.callTool({
name: 'browser_select_option',
arguments: {
element: 'Select',
2025-05-09 18:01:17 -07:00
ref: 'e2',
2025-03-27 16:50:43 -07:00
values: ['bar'],
},
})).toHaveTextContent(`
- Ran Playwright code:
\`\`\`js
// Select options [bar] in Select
await page.getByRole('combobox').selectOption(['bar']);
\`\`\`
- Page URL: ${server.PREFIX}
- Page Title: Title
- Page Snapshot
\`\`\`yaml
2025-05-09 18:01:17 -07:00
- combobox [ref=e2]:
- option "Foo"
- option "Bar" [selected]
\`\`\`
2025-03-27 16:50:43 -07:00
`);
});
test('browser_select_option (multiple)', async ({ client, server }) => {
server.setContent('/', `
<title>Title</title>
<select multiple>
<option value="foo">Foo</option>
<option value="bar">Bar</option>
<option value="baz">Baz</option>
</select>
`, 'text/html');
2025-03-27 16:50:43 -07:00
await client.callTool({
name: 'browser_navigate',
arguments: { url: server.PREFIX },
2025-03-27 16:50:43 -07:00
});
2025-03-27 16:50:43 -07:00
expect(await client.callTool({
name: 'browser_select_option',
arguments: {
element: 'Select',
2025-05-09 18:01:17 -07:00
ref: 'e2',
2025-03-27 16:50:43 -07:00
values: ['bar', 'baz'],
},
})).toHaveTextContent(`
- Ran Playwright code:
\`\`\`js
// Select options [bar, baz] in Select
await page.getByRole('listbox').selectOption(['bar', 'baz']);
\`\`\`
- Page URL: ${server.PREFIX}
- Page Title: Title
- Page Snapshot
\`\`\`yaml
2025-05-09 18:01:17 -07:00
- listbox [ref=e2]:
- option "Foo" [ref=e3]
- option "Bar" [selected] [ref=e4]
- option "Baz" [selected] [ref=e5]
\`\`\`
2025-03-27 16:50:43 -07:00
`);
});
test('browser_type', async ({ client, server }) => {
server.setContent('/', `
<!DOCTYPE html>
<html>
<input type='keypress' onkeypress="console.log('Key pressed:', event.key, ', Text:', event.target.value)"></input>
</html>
`, 'text/html');
await client.callTool({
name: 'browser_navigate',
arguments: {
url: server.PREFIX,
},
});
await client.callTool({
name: 'browser_type',
arguments: {
element: 'textbox',
2025-05-09 18:01:17 -07:00
ref: 'e2',
text: 'Hi!',
submit: true,
},
});
expect(await client.callTool({
name: 'browser_console_messages',
})).toHaveTextContent('[LOG] Key pressed: Enter , Text: Hi!');
});
test('browser_type (slowly)', async ({ client, server }) => {
server.setContent('/', `
<input type='text' onkeydown="console.log('Key pressed:', event.key, 'Text:', event.target.value)"></input>
`, 'text/html');
await client.callTool({
name: 'browser_navigate',
arguments: {
url: server.PREFIX,
},
});
await client.callTool({
name: 'browser_type',
arguments: {
element: 'textbox',
2025-05-09 18:01:17 -07:00
ref: 'e2',
text: 'Hi!',
submit: true,
slowly: true,
},
});
expect(await client.callTool({
name: 'browser_console_messages',
})).toHaveTextContent([
'[LOG] Key pressed: H Text: ',
'[LOG] Key pressed: i Text: H',
'[LOG] Key pressed: ! Text: Hi',
'[LOG] Key pressed: Enter Text: Hi!',
].join('\n'));
});
2025-04-15 01:09:48 +02:00
test('browser_resize', async ({ client, server }) => {
server.setContent('/', `
<title>Resize Test</title>
<body>
<div id="size">Waiting for resize...</div>
<script>new ResizeObserver(() => { document.getElementById("size").textContent = \`Window size: \${window.innerWidth}x\${window.innerHeight}\`; }).observe(document.body);
</script>
</body>
`, 'text/html');
2025-04-15 01:09:48 +02:00
await client.callTool({
name: 'browser_navigate',
arguments: { url: server.PREFIX },
2025-04-15 01:09:48 +02:00
});
const response = await client.callTool({
name: 'browser_resize',
arguments: {
width: 390,
height: 780,
},
});
expect(response).toContainTextContent(`- Ran Playwright code:
\`\`\`js
// Resize browser window to 390x780
await page.setViewportSize({ width: 390, height: 780 });
\`\`\``);
await expect.poll(() => client.callTool({ name: 'browser_snapshot' })).toContainTextContent('Window size: 390x780');
2025-04-15 01:09:48 +02:00
});