mirror of
https://github.com/microsoft/playwright-mcp.git
synced 2025-07-26 16:42:27 +08:00
chore: sse test (#59)
This commit is contained in:
parent
f547f6dd21
commit
1b18e31ffe
@ -14,6 +14,8 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import { spawn } from 'node:child_process';
|
||||||
|
import path from 'node:path';
|
||||||
import { test, expect } from './fixtures';
|
import { test, expect } from './fixtures';
|
||||||
|
|
||||||
test('test tool list', async ({ server, visionServer }) => {
|
test('test tool list', async ({ server, visionServer }) => {
|
||||||
@ -450,3 +452,26 @@ test('stitched aria frames', async ({ server }) => {
|
|||||||
},
|
},
|
||||||
}));
|
}));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('sse transport', async () => {
|
||||||
|
const cp = spawn('node', [path.join(__dirname, '../cli.js'), '--port', '0'], { stdio: 'pipe' });
|
||||||
|
try {
|
||||||
|
let stdout = '';
|
||||||
|
const url = await new Promise<string>(resolve => cp.stdout?.on('data', data => {
|
||||||
|
stdout += data.toString();
|
||||||
|
const match = stdout.match(/Listening on (http:\/\/.*)/);
|
||||||
|
if (match)
|
||||||
|
resolve(match[1]);
|
||||||
|
}));
|
||||||
|
|
||||||
|
// need dynamic import b/c of some ESM nonsense
|
||||||
|
const { SSEClientTransport } = await import('@modelcontextprotocol/sdk/client/sse.js');
|
||||||
|
const { Client } = await import('@modelcontextprotocol/sdk/client/index.js');
|
||||||
|
const transport = new SSEClientTransport(new URL(url));
|
||||||
|
const client = new Client({ name: 'test', version: '1.0.0' });
|
||||||
|
await client.connect(transport);
|
||||||
|
await client.ping();
|
||||||
|
} finally {
|
||||||
|
cp.kill();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user