2020-08-05 01:57:25 +03:00
|
|
|
/**
|
|
|
|
* Copyright 2017 Google Inc. All rights reserved.
|
|
|
|
* Modifications 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.
|
|
|
|
*/
|
|
|
|
|
2022-03-26 02:05:50 +03:00
|
|
|
import { playwrightTest as it, expect } from '../config/browserTest';
|
2021-04-03 07:07:45 +03:00
|
|
|
|
|
|
|
it.describe('launch server', () => {
|
2021-09-27 19:58:08 +03:00
|
|
|
it.skip(({ mode }) => mode !== 'default');
|
2020-08-05 01:57:25 +03:00
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should work', async ({ browserType }) => {
|
|
|
|
const browserServer = await browserType.launchServer();
|
2020-08-28 23:53:47 +03:00
|
|
|
expect(browserServer.wsEndpoint()).not.toBe(null);
|
|
|
|
await browserServer.close();
|
|
|
|
});
|
2020-08-05 01:57:25 +03:00
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should work with port', async ({ browserType }, testInfo) => {
|
2021-04-03 07:07:45 +03:00
|
|
|
const port = 8800 + testInfo.workerIndex;
|
2021-10-28 05:00:06 +03:00
|
|
|
const browserServer = await browserType.launchServer({ port });
|
2021-04-03 07:07:45 +03:00
|
|
|
expect(browserServer.wsEndpoint()).toContain(String(port));
|
2020-09-15 00:43:39 +03:00
|
|
|
await browserServer.close();
|
|
|
|
});
|
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should work with wsPath', async ({ browserType }) => {
|
2021-08-22 19:04:47 +03:00
|
|
|
const wsPath = '/unguessable-token';
|
2021-10-28 05:00:06 +03:00
|
|
|
const browserServer = await browserType.launchServer({ wsPath });
|
2021-08-22 19:04:47 +03:00
|
|
|
expect(browserServer.wsEndpoint()).toMatch(/:\d+\/unguessable-token$/);
|
|
|
|
await browserServer.close();
|
|
|
|
});
|
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should work when wsPath is missing leading slash', async ({ browserType }) => {
|
2021-08-22 19:04:47 +03:00
|
|
|
const wsPath = 'unguessable-token';
|
2021-10-28 05:00:06 +03:00
|
|
|
const browserServer = await browserType.launchServer({ wsPath });
|
2021-08-22 19:04:47 +03:00
|
|
|
expect(browserServer.wsEndpoint()).toMatch(/:\d+\/unguessable-token$/);
|
|
|
|
await browserServer.close();
|
|
|
|
});
|
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should default to random wsPath', async ({ browserType }) => {
|
|
|
|
const browserServer = await browserType.launchServer();
|
2021-08-22 19:04:47 +03:00
|
|
|
expect(browserServer.wsEndpoint()).toMatch(/:\d+\/[a-f\d]{32}$/);
|
|
|
|
await browserServer.close();
|
|
|
|
});
|
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should provide an error when ws endpoint is incorrect', async ({ browserType }) => {
|
|
|
|
const browserServer = await browserType.launchServer();
|
2021-01-12 02:53:45 +03:00
|
|
|
const error = await browserType.connect({ wsEndpoint: browserServer.wsEndpoint() + '-foo' }).catch(e => e);
|
|
|
|
await browserServer.close();
|
2021-09-01 01:56:55 +03:00
|
|
|
expect(error.message).toContain('Unexpected server response: 400');
|
2021-01-12 02:53:45 +03:00
|
|
|
});
|
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should fire "close" event during kill', async ({ browserType }) => {
|
2020-08-28 23:53:47 +03:00
|
|
|
const order = [];
|
2021-10-28 05:00:06 +03:00
|
|
|
const browserServer = await browserType.launchServer();
|
2021-04-29 21:11:32 +03:00
|
|
|
const closedPromise = new Promise<void>(f => browserServer.on('close', () => {
|
2020-08-28 23:53:47 +03:00
|
|
|
order.push('closed');
|
|
|
|
f();
|
|
|
|
}));
|
|
|
|
await Promise.all([
|
|
|
|
browserServer.kill().then(() => order.push('killed')),
|
|
|
|
closedPromise,
|
|
|
|
]);
|
|
|
|
expect(order).toEqual(['closed', 'killed']);
|
|
|
|
});
|
2020-08-05 01:57:25 +03:00
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should return child_process instance', async ({ browserType }) => {
|
|
|
|
const browserServer = await browserType.launchServer();
|
2020-08-28 23:53:47 +03:00
|
|
|
expect(browserServer.process().pid).toBeGreaterThan(0);
|
|
|
|
await browserServer.close();
|
|
|
|
});
|
2020-08-05 01:57:25 +03:00
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should fire close event', async ({ browserType }) => {
|
|
|
|
const browserServer = await browserType.launchServer();
|
2020-08-28 23:53:47 +03:00
|
|
|
const [result] = await Promise.all([
|
2020-09-09 13:06:52 +03:00
|
|
|
// @ts-expect-error The signal parameter is not documented.
|
|
|
|
new Promise(f => browserServer.on('close', (exitCode, signal) => f({ exitCode, signal }))),
|
2020-08-28 23:53:47 +03:00
|
|
|
browserServer.close(),
|
|
|
|
]);
|
|
|
|
expect(result['exitCode']).toBe(0);
|
|
|
|
expect(result['signal']).toBe(null);
|
|
|
|
});
|
2020-11-12 02:12:10 +03:00
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
it('should log protocol', async ({ browserType }) => {
|
2020-11-12 02:12:10 +03:00
|
|
|
const logs: string[] = [];
|
|
|
|
const logger = {
|
|
|
|
isEnabled(name: string) {
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
log(name: string, severity: string, message: string) {
|
|
|
|
logs.push(`${name}:${severity}:${message}`);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-10-28 05:00:06 +03:00
|
|
|
const browserServer = await browserType.launchServer({ logger });
|
2020-11-12 02:12:10 +03:00
|
|
|
await browserServer.close();
|
|
|
|
|
|
|
|
expect(logs.some(log => log.startsWith('protocol:verbose:SEND ►'))).toBe(true);
|
|
|
|
expect(logs.some(log => log.startsWith('protocol:verbose:◀ RECV'))).toBe(true);
|
|
|
|
});
|
2020-08-05 01:57:25 +03:00
|
|
|
});
|