"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const path_1 = __importDefault(require("path")); const url_1 = require("url"); const chrome_remote_interface_1 = __importDefault(require("chrome-remote-interface")); const child_process_1 = require("child_process"); const endpoint_utils_1 = require("endpoint-utils"); const io_1 = require("./io"); const test_structure_1 = require("../serialization/test-structure"); const prepare_options_1 = __importDefault(require("../serialization/prepare-options")); const test_run_tracker_1 = __importDefault(require("../../api/test-run-tracker")); const test_controller_1 = __importDefault(require("../../api/test-controller")); const proxy_1 = require("../utils/ipc/proxy"); const transport_1 = require("../utils/ipc/transport"); const async_event_emitter_1 = __importDefault(require("../../utils/async-event-emitter")); const error_list_1 = __importDefault(require("../../errors/error-list")); const debug_action_1 = __importDefault(require("../../utils/debug-action")); const observation_1 = require("../../test-run/commands/observation"); const method_should_not_be_called_error_1 = __importDefault(require("../utils/method-should-not-be-called-error")); const test_run_1 = require("../../errors/test-run"); const handle_errors_1 = require("../../utils/handle-errors"); const node_arguments_filter_1 = require("../../cli/node-arguments-filter"); const SERVICE_PATH = require.resolve('./service-loader'); const INTERNAL_FILES_URL = (0, url_1.pathToFileURL)(path_1.default.join(__dirname, '../../')); const INSPECT_RE = new RegExp(`^(${node_arguments_filter_1.V8_DEBUG_FLAGS.join('|')})`); const INSPECT_PORT_RE = new RegExp(`^(${node_arguments_filter_1.V8_DEBUG_FLAGS.join('|')})=(.+:)?(\\d+)$`); const INITIAL_DEBUGGER_BREAK_ON_START = 'Break on start'; const errorTypeConstructors = new Map([ [test_run_1.UnhandledPromiseRejectionError.name, test_run_1.UnhandledPromiseRejectionError], [test_run_1.UncaughtExceptionError.name, test_run_1.UncaughtExceptionError], ]); class CompilerHost extends async_event_emitter_1.default { constructor({ developmentMode, v8Flags }) { super(); this.runtime = Promise.resolve(void 0); this.developmentMode = developmentMode; this.v8Flags = v8Flags; this.initialized = false; } _setupRoutes(proxy) { proxy.register([ this.executeCommand, this.ready, this.onRequestHookEvent, this.setMock, this.setConfigureResponseEventOptions, this.setHeaderOnConfigureResponseEvent, this.removeHeaderOnConfigureResponseEvent, this.executeRequestFilterRulePredicate, this.executeMockPredicate, this.getWarningMessages, this.addRequestEventListeners, this.removeRequestEventListeners, this.initializeTestRunData, this.getAssertionActualValue, this.executeRoleInitFn, this.getCtx, this.getFixtureCtx, this.setCtx, this.setFixtureCtx, this.updateRoleProperty, this.executeJsExpression, this.executeAsyncJsExpression, this.executeAssertionFn, this.addUnexpectedError, this.checkWindow, this.removeTestRunFromState, this.removeFixtureCtxsFromState, this.removeUnitsFromState, ], this); } _setupDebuggerHandlers() { if (!this.cdp) return; test_run_tracker_1.default.on(debug_action_1.default.resume, async () => { if (!this.cdp) return; const disableDebugMethodName = test_controller_1.default.disableDebugForNonDebugCommands.name; // NOTE: disable `debugger` for non-debug commands if the `Resume` button is clicked // the `includeCommandLineAPI` option allows to use the `require` functoion in the expression // TODO: debugging: refactor to use absolute paths await this.cdp.Runtime.evaluate({ expression: `require.main.require('../../api/test-controller').${disableDebugMethodName}()`, includeCommandLineAPI: true, }); await this.cdp.Debugger.resume({ terminateOnResume: false }); }); test_run_tracker_1.default.on(debug_action_1.default.step, async () => { if (!this.cdp) return; const enableDebugMethodName = test_controller_1.default.enableDebugForNonDebugCommands.name; // NOTE: enable `debugger` for non-debug commands in the `Next Action` button is clicked // the `includeCommandLineAPI` option allows to use the `require` functoion in the expression // TODO: debugging: refactor to use absolute paths await this.cdp.Runtime.evaluate({ expression: `require.main.require('../../api/test-controller').${enableDebugMethodName}()`, includeCommandLineAPI: true, }); await this.cdp.Debugger.resume({ terminateOnResume: false }); }); // NOTE: need to step out from the source code until breakpoint is set in the code of test // force DebugCommand if breakpoint stopped in the test code // TODO: debugging: refactor to this.cdp.Debugger.on('paused') after updating to chrome-remote-interface@0.30.0 this.cdp.on('Debugger.paused', (args) => { const { callFrames } = args; if (this.cdp) { if (args.reason === INITIAL_DEBUGGER_BREAK_ON_START) return this.cdp.Debugger.resume({ terminateOnResume: false }); if (callFrames[0].url.includes(INTERNAL_FILES_URL)) return this.cdp.Debugger.stepOut(); Object.values(test_run_tracker_1.default.activeTestRuns).forEach(testRun => { if (!testRun.debugging) testRun.executeCommand(new observation_1.DebugCommand()); }); } return Promise.resolve(); }); // NOTE: need to hide Status Bar if debugger is resumed // TODO: debugging: refactor to this.cdp.Debugger.on('resumed') after updating to chrome-remote-interface@0.30.0 this.cdp.on('Debugger.resumed', () => { Object.values(test_run_tracker_1.default.activeTestRuns).forEach(testRun => { if (testRun.debugging) testRun.executeCommand(new observation_1.DisableDebugCommand()); }); }); } parseDebugPort() { if (this.v8Flags) { for (let i = 0; i < this.v8Flags.length; i++) { const match = this.v8Flags[i].match(INSPECT_PORT_RE); if (match) return match[3]; } } return null; } _getServiceProcessArgs(port) { let args = []; if (this.v8Flags) args = this.v8Flags.filter(flag => !INSPECT_RE.test(flag)); // TODO: debugging: refactor to a separate debug info parsing unit const inspectBrkFlag = `--inspect-brk=127.0.0.1:${port}`; args.push(inspectBrkFlag, SERVICE_PATH); return args; } async _init(runtime) { const resolvedRuntime = await runtime; if (resolvedRuntime) return resolvedRuntime; try { const port = this.parseDebugPort() || await (0, endpoint_utils_1.getFreePort)(); const args = this._getServiceProcessArgs(port.toString()); const service = (0, child_process_1.spawn)(process.argv0, args, { stdio: [0, 1, 2, 'pipe', 'pipe', 'pipe'] }); // NOTE: need to wait, otherwise the error will be at `await cdp(...)` // TODO: debugging: refactor to use delay and multiple tries await new Promise(r => setTimeout(r, 2000)); // @ts-ignore this.cdp = await (0, chrome_remote_interface_1.default)({ port }); if (!this.cdp) return void 0; if (!this.developmentMode) this._setupDebuggerHandlers(); await this.cdp.Debugger.enable({}); await this.cdp.Runtime.enable(); await this.cdp.Runtime.runIfWaitingForDebugger(); // HACK: Node.js definition are not correct when additional I/O channels are sp const stdio = service.stdio; const proxy = new proxy_1.IPCProxy(new transport_1.HostTransport(stdio[io_1.HOST_INPUT_FD], stdio[io_1.HOST_OUTPUT_FD], stdio[io_1.HOST_SYNC_FD])); this._setupRoutes(proxy); await this.once('ready'); return { proxy, service }; } catch (e) { return void 0; } } async _getRuntime() { const runtime = await this.runtime; if (!runtime) throw new Error('Runtime is not available.'); return runtime; } _getTargetTestRun(id) { return test_run_tracker_1.default.activeTestRuns[id]; } async init() { this.runtime = this._init(this.runtime); await this.runtime; this.initialized = true; } async stop() { if (!this.initialized) return; const { service, proxy } = await this._getRuntime(); service.kill(); proxy.stop(); } _wrapTestFunction(id, functionName) { return async (testRun) => { try { return await this.runTestFn({ id, functionName, testRunId: testRun.id }); } catch (err) { const errList = new error_list_1.default(); errList.addError(err); throw errList; } }; } _wrapRequestFilterRulePredicate({ testId, hookId, ruleId }) { return async (requestInfo) => { return await this.executeRequestFilterRulePredicate({ testId, hookId, ruleId, requestInfo }); }; } _wrapMockPredicate({ mock, testId, hookId, ruleId }) { mock.body = async (requestInfo, res) => { return await this.executeMockPredicate({ testId, hookId, ruleId, requestInfo, res }); }; } _getErrorTypeConstructor(type) { return errorTypeConstructors.get(type); } async ready() { this.emit('ready'); } executeCommandSync() { throw new method_should_not_be_called_error_1.default(); } async executeCommand({ command, id, callsite }) { return this ._getTargetTestRun(id) .executeCommand(command, callsite); } async getTests({ sourceList, compilerOptions, runnableConfigurationId }, baseUrl) { const { proxy } = await this._getRuntime(); const units = await proxy.call(this.getTests, { sourceList, compilerOptions, runnableConfigurationId }, baseUrl); return (0, test_structure_1.restore)(units, (...args) => this._wrapTestFunction(...args), (ruleLocator) => this._wrapRequestFilterRulePredicate(ruleLocator)); } async runTestFn({ id, functionName, testRunId }) { const { proxy } = await this._getRuntime(); return await proxy.call(this.runTestFn, { id, functionName, testRunId }); } async cleanUp() { const { proxy } = await this._getRuntime(); await proxy.call(this.cleanUp); } async setUserVariables(userVariables) { const { proxy } = await this._getRuntime(); await proxy.call(this.setUserVariables, userVariables); } async setOptions({ value }) { const { proxy } = await this._getRuntime(); const preparedOptions = (0, prepare_options_1.default)(value); await proxy.call(this.setOptions, { value: preparedOptions }); } async onRequestHookEvent({ name, testId, hookId, eventData }) { const { proxy } = await this._getRuntime(); await proxy.call(this.onRequestHookEvent, { name, testId, hookId, eventData, }); } async setMock({ testId, hookId, ruleId, responseEventId, mock }) { if (mock.isPredicate) this._wrapMockPredicate({ mock, testId, hookId, ruleId }); await this.emit('setMock', [responseEventId, mock]); } async setConfigureResponseEventOptions({ eventId, opts }) { await this.emit('setConfigureResponseEventOptions', [eventId, opts]); } async setHeaderOnConfigureResponseEvent({ eventId, headerName, headerValue }) { await this.emit('setHeaderOnConfigureResponseEvent', [eventId, headerName, headerValue]); } async removeHeaderOnConfigureResponseEvent({ eventId, headerName }) { await this.emit('removeHeaderOnConfigureResponseEvent', [eventId, headerName]); } async executeRequestFilterRulePredicate({ testId, hookId, ruleId, requestInfo }) { const { proxy } = await this._getRuntime(); return await proxy.call(this.executeRequestFilterRulePredicate, { testId, hookId, ruleId, requestInfo }); } async executeMockPredicate({ testId, hookId, ruleId, requestInfo, res }) { const { proxy } = await this._getRuntime(); return await proxy.call(this.executeMockPredicate, { testId, hookId, ruleId, requestInfo, res }); } async getWarningMessages({ testRunId }) { const { proxy } = await this._getRuntime(); return proxy.call(this.getWarningMessages, { testRunId }); } async addRequestEventListeners({ hookId, hookClassName, rules }) { await this.emit('addRequestEventListeners', { hookId, hookClassName, rules }); } async removeRequestEventListeners({ rules }) { await this.emit('removeRequestEventListeners', { rules }); } async initializeTestRunData({ testRunId, testId, browser, activeWindowId, messageBus }) { const { proxy } = await this._getRuntime(); return proxy.call(this.initializeTestRunData, { testRunId, testId, browser, activeWindowId, messageBus }); } async getAssertionActualValue({ testRunId, commandId }) { const { proxy } = await this._getRuntime(); return proxy.call(this.getAssertionActualValue, { testRunId, commandId: commandId }); } async executeRoleInitFn({ testRunId, roleId }) { const { proxy } = await this._getRuntime(); return proxy.call(this.executeRoleInitFn, { testRunId, roleId }); } async getCtx({ testRunId }) { const { proxy } = await this._getRuntime(); return proxy.call(this.getCtx, { testRunId }); } async getFixtureCtx({ testRunId }) { const { proxy } = await this._getRuntime(); return proxy.call(this.getFixtureCtx, { testRunId }); } async setCtx({ testRunId, value }) { const { proxy } = await this._getRuntime(); return proxy.call(this.setCtx, { testRunId, value }); } async setFixtureCtx({ testRunId, value }) { const { proxy } = await this._getRuntime(); return proxy.call(this.setFixtureCtx, { testRunId, value }); } onRoleAppeared() { throw new method_should_not_be_called_error_1.default(); } async updateRoleProperty({ roleId, name, value }) { const { proxy } = await this._getRuntime(); return proxy.call(this.updateRoleProperty, { roleId, name, value }); } async executeJsExpression({ expression, testRunId, options }) { const { proxy } = await this._getRuntime(); return proxy.call(this.executeJsExpression, { expression, testRunId, options }); } async executeAsyncJsExpression({ expression, testRunId, callsite }) { const { proxy } = await this._getRuntime(); return proxy.call(this.executeAsyncJsExpression, { expression, testRunId, callsite }); } async executeAssertionFn({ testRunId, commandId }) { const { proxy } = await this._getRuntime(); return proxy.call(this.executeAssertionFn, { testRunId, commandId }); } async addUnexpectedError({ type, message }) { const ErrorTypeConstructor = this._getErrorTypeConstructor(type); (0, handle_errors_1.handleUnexpectedError)(ErrorTypeConstructor, message); } async checkWindow({ testRunId, commandId, url, title }) { const { proxy } = await this._getRuntime(); return proxy.call(this.checkWindow, { testRunId, commandId, url, title }); } async removeTestRunFromState({ testRunId }) { const { proxy } = await this._getRuntime(); return proxy.call(this.removeTestRunFromState, { testRunId }); } async removeFixtureCtxsFromState({ fixtureIds }) { const { proxy } = await this._getRuntime(); return proxy.call(this.removeFixtureCtxsFromState, { fixtureIds }); } async removeUnitsFromState({ runnableConfigurationId }) { const { proxy } = await this._getRuntime(); return proxy.call(this.removeUnitsFromState, { runnableConfigurationId }); } } exports.default = CompilerHost; module.exports = exports.default; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"host.js","sourceRoot":"","sources":["../../../src/services/compiler/host.ts"],"names":[],"mappings":"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","sourcesContent":["import path from 'path';\nimport { pathToFileURL } from 'url';\nimport cdp from 'chrome-remote-interface';\nimport EventEmitter from 'events';\nimport { spawn, ChildProcess } from 'child_process';\nimport { getFreePort } from 'endpoint-utils';\n\nimport {\n    HOST_INPUT_FD,\n    HOST_OUTPUT_FD,\n    HOST_SYNC_FD,\n} from './io';\n\nimport { restore as restoreTestStructure } from '../serialization/test-structure';\nimport prepareOptions from '../serialization/prepare-options';\nimport { default as testRunTracker } from '../../api/test-run-tracker';\nimport TestController from '../../api/test-controller';\nimport TestRun from '../../test-run';\nimport { IPCProxy } from '../utils/ipc/proxy';\nimport { HostTransport } from '../utils/ipc/transport';\nimport AsyncEventEmitter from '../../utils/async-event-emitter';\nimport TestCafeErrorList from '../../errors/error-list';\nimport DEBUG_ACTION from '../../utils/debug-action';\n\nimport {\n    CompilerProtocol,\n    RunTestArguments,\n    FunctionProperties,\n} from './protocol';\n\nimport { CompilerArguments } from '../../compiler/interfaces';\nimport Test from '../../api/structure/test';\n\nimport {\n    RequestInfo,\n    ResponseMock,\n    IncomingMessageLikeInitOptions,\n} from 'testcafe-hammerhead';\n\nimport { DebugCommand, DisableDebugCommand } from '../../test-run/commands/observation';\nimport MethodShouldNotBeCalledError from '../utils/method-should-not-be-called-error';\n\nimport {\n    AddRequestEventListenersArguments,\n    ExecuteCommandArguments,\n    ExecuteMockPredicate,\n    ExecuteRequestFilterRulePredicateArguments,\n    ExecuteRoleInitFnArguments,\n    InitializeTestRunDataArguments,\n    RemoveHeaderOnConfigureResponseEventArguments,\n    RemoveRequestEventListenersArguments,\n    RequestFilterRuleLocator,\n    RequestHookEventArguments,\n    SetConfigureResponseEventOptionsArguments,\n    SetCtxArguments,\n    SetMockArguments,\n    SetHeaderOnConfigureResponseEventArguments,\n    SetOptionsArguments,\n    TestRunLocator,\n    UpdateRolePropertyArguments,\n    ExecuteJsExpressionArguments,\n    ExecuteAsyncJsExpressionArguments,\n    CommandLocator,\n    AddUnexpectedErrorArguments,\n    CheckWindowArgument,\n    RemoveFixtureCtxsArguments,\n    RemoveUnitsFromStateArguments,\n} from './interfaces';\n\nimport { UncaughtExceptionError, UnhandledPromiseRejectionError } from '../../errors/test-run';\nimport { handleUnexpectedError } from '../../utils/handle-errors';\nimport { V8_DEBUG_FLAGS } from '../../cli/node-arguments-filter';\nimport { WarningLogMessage } from '../../notifications/warning-log';\n\nconst SERVICE_PATH       = require.resolve('./service-loader');\nconst INTERNAL_FILES_URL = pathToFileURL(path.join(__dirname, '../../'));\n\nconst INSPECT_RE      = new RegExp(`^(${V8_DEBUG_FLAGS.join('|')})`);\nconst INSPECT_PORT_RE = new RegExp(`^(${V8_DEBUG_FLAGS.join('|')})=(.+:)?(\\\\d+)$`);\n\ninterface RuntimeResources {\n    service: ChildProcess;\n    proxy: IPCProxy;\n}\n\ninterface TestFunction {\n    (testRun: TestRun): Promise<unknown>;\n}\n\ninterface RequestFilterRulePredicate {\n    (requestInfo: RequestInfo): Promise<boolean>;\n}\n\ninterface WrapMockPredicateArguments extends RequestFilterRuleLocator {\n    mock: ResponseMock;\n}\n\nconst INITIAL_DEBUGGER_BREAK_ON_START = 'Break on start';\n\nconst errorTypeConstructors = new Map<string, Function>([\n    [UnhandledPromiseRejectionError.name, UnhandledPromiseRejectionError],\n    [UncaughtExceptionError.name, UncaughtExceptionError],\n]);\n\ninterface CompilerHostInitOptions {\n    developmentMode: boolean;\n    v8Flags: string[];\n}\n\nexport default class CompilerHost extends AsyncEventEmitter implements CompilerProtocol {\n    private runtime: Promise<RuntimeResources | undefined>;\n    private cdp: cdp.ProtocolApi & EventEmitter | undefined;\n    private readonly developmentMode: boolean;\n    private readonly v8Flags: string[];\n    public initialized: boolean;\n\n    public constructor ({ developmentMode, v8Flags }: CompilerHostInitOptions) {\n        super();\n\n        this.runtime         = Promise.resolve(void 0);\n        this.developmentMode = developmentMode;\n        this.v8Flags         = v8Flags;\n        this.initialized     = false;\n    }\n\n    private _setupRoutes (proxy: IPCProxy): void {\n        proxy.register([\n            this.executeCommand,\n            this.ready,\n            this.onRequestHookEvent,\n            this.setMock,\n            this.setConfigureResponseEventOptions,\n            this.setHeaderOnConfigureResponseEvent,\n            this.removeHeaderOnConfigureResponseEvent,\n            this.executeRequestFilterRulePredicate,\n            this.executeMockPredicate,\n            this.getWarningMessages,\n            this.addRequestEventListeners,\n            this.removeRequestEventListeners,\n            this.initializeTestRunData,\n            this.getAssertionActualValue,\n            this.executeRoleInitFn,\n            this.getCtx,\n            this.getFixtureCtx,\n            this.setCtx,\n            this.setFixtureCtx,\n            this.updateRoleProperty,\n            this.executeJsExpression,\n            this.executeAsyncJsExpression,\n            this.executeAssertionFn,\n            this.addUnexpectedError,\n            this.checkWindow,\n            this.removeTestRunFromState,\n            this.removeFixtureCtxsFromState,\n            this.removeUnitsFromState,\n        ], this);\n    }\n\n    private _setupDebuggerHandlers (): void {\n        if (!this.cdp)\n            return;\n\n        testRunTracker.on(DEBUG_ACTION.resume, async () => {\n            if (!this.cdp)\n                return;\n\n            const disableDebugMethodName = TestController.disableDebugForNonDebugCommands.name;\n\n            // NOTE: disable `debugger` for non-debug commands if the `Resume` button is clicked\n            // the `includeCommandLineAPI` option allows to use the `require` functoion in the expression\n            // TODO: debugging: refactor to use absolute paths\n            await this.cdp.Runtime.evaluate({\n                expression:            `require.main.require('../../api/test-controller').${disableDebugMethodName}()`,\n                includeCommandLineAPI: true,\n            });\n\n            await this.cdp.Debugger.resume({ terminateOnResume: false });\n        });\n\n        testRunTracker.on(DEBUG_ACTION.step, async () => {\n            if (!this.cdp)\n                return;\n\n            const enableDebugMethodName = TestController.enableDebugForNonDebugCommands.name;\n\n            // NOTE: enable `debugger` for non-debug commands in the `Next Action` button is clicked\n            // the `includeCommandLineAPI` option allows to use the `require` functoion in the expression\n            // TODO: debugging: refactor to use absolute paths\n            await this.cdp.Runtime.evaluate({\n                expression:            `require.main.require('../../api/test-controller').${enableDebugMethodName}()`,\n                includeCommandLineAPI: true,\n            });\n\n            await this.cdp.Debugger.resume({ terminateOnResume: false });\n        });\n\n        // NOTE: need to step out from the source code until breakpoint is set in the code of test\n        // force DebugCommand if breakpoint stopped in the test code\n        // TODO: debugging: refactor to this.cdp.Debugger.on('paused') after updating to chrome-remote-interface@0.30.0\n        this.cdp.on('Debugger.paused', (args: any): Promise<void> => {\n            const { callFrames } = args;\n\n            if (this.cdp) {\n                if (args.reason === INITIAL_DEBUGGER_BREAK_ON_START)\n                    return this.cdp.Debugger.resume({ terminateOnResume: false });\n\n                if (callFrames[0].url.includes(INTERNAL_FILES_URL))\n                    return this.cdp.Debugger.stepOut();\n\n                Object.values(testRunTracker.activeTestRuns).forEach(testRun => {\n                    if (!testRun.debugging)\n                        testRun.executeCommand(new DebugCommand());\n                });\n            }\n\n            return Promise.resolve();\n        });\n\n        // NOTE: need to hide Status Bar if debugger is resumed\n        // TODO: debugging: refactor to this.cdp.Debugger.on('resumed') after updating to chrome-remote-interface@0.30.0\n        this.cdp.on('Debugger.resumed', () => {\n            Object.values(testRunTracker.activeTestRuns).forEach(testRun => {\n                if (testRun.debugging)\n                    testRun.executeCommand(new DisableDebugCommand());\n            });\n        });\n    }\n\n    private parseDebugPort (): string | null {\n        if (this.v8Flags) {\n            for (let i = 0; i < this.v8Flags.length; i++) {\n                const match = this.v8Flags[i].match(INSPECT_PORT_RE);\n\n                if (match)\n                    return match[3];\n            }\n        }\n\n        return null;\n    }\n\n    private _getServiceProcessArgs (port: string): string [] {\n        let args: string[] = [];\n\n        if (this.v8Flags)\n            args = this.v8Flags.filter(flag => !INSPECT_RE.test(flag));\n\n        // TODO: debugging: refactor to a separate debug info parsing unit\n        const inspectBrkFlag = `--inspect-brk=127.0.0.1:${ port }`;\n\n        args.push(inspectBrkFlag, SERVICE_PATH);\n\n        return args;\n    }\n\n    private async _init (runtime: Promise<RuntimeResources | undefined>): Promise<RuntimeResources | undefined> {\n        const resolvedRuntime = await runtime;\n\n        if (resolvedRuntime)\n            return resolvedRuntime;\n\n        try {\n            const port    = this.parseDebugPort() || await getFreePort();\n            const args    = this._getServiceProcessArgs(port.toString());\n            const service = spawn(process.argv0, args, { stdio: [0, 1, 2, 'pipe', 'pipe', 'pipe'] });\n\n            // NOTE: need to wait, otherwise the error will be at `await cdp(...)`\n            // TODO: debugging: refactor to use delay and multiple tries\n            await new Promise(r => setTimeout(r, 2000));\n\n            // @ts-ignore\n            this.cdp = await cdp({ port });\n\n            if (!this.cdp)\n                return void 0;\n\n            if (!this.developmentMode)\n                this._setupDebuggerHandlers();\n\n            await this.cdp.Debugger.enable({});\n            await this.cdp.Runtime.enable();\n            await this.cdp.Runtime.runIfWaitingForDebugger();\n\n            // HACK: Node.js definition are not correct when additional I/O channels are sp\n            const stdio = service.stdio as any;\n            const proxy = new IPCProxy(new HostTransport(stdio[HOST_INPUT_FD], stdio[HOST_OUTPUT_FD], stdio[HOST_SYNC_FD]));\n\n            this._setupRoutes(proxy);\n\n            await this.once('ready');\n\n            return { proxy, service };\n        }\n        catch (e) {\n            return void 0;\n        }\n    }\n\n    private async _getRuntime (): Promise<RuntimeResources> {\n        const runtime = await this.runtime;\n\n        if (!runtime)\n            throw new Error('Runtime is not available.');\n\n        return runtime;\n    }\n\n    private _getTargetTestRun (id: string): TestRun {\n        return testRunTracker.activeTestRuns[id] as unknown as TestRun;\n    }\n\n    public async init (): Promise<void> {\n        this.runtime = this._init(this.runtime);\n\n        await this.runtime;\n\n        this.initialized = true;\n    }\n\n    public async stop (): Promise<void> {\n        if (!this.initialized)\n            return;\n\n        const { service, proxy } = await this._getRuntime();\n\n        service.kill();\n        proxy.stop();\n    }\n\n    private _wrapTestFunction (id: string, functionName: FunctionProperties): TestFunction {\n        return async testRun => {\n            try {\n                return await this.runTestFn({ id, functionName, testRunId: testRun.id });\n            }\n            catch (err) {\n                const errList = new TestCafeErrorList();\n\n                errList.addError(err);\n\n                throw errList;\n            }\n        };\n    }\n\n    private _wrapRequestFilterRulePredicate ({ testId, hookId, ruleId }: RequestFilterRuleLocator): RequestFilterRulePredicate {\n        return async (requestInfo: RequestInfo) => {\n            return await this.executeRequestFilterRulePredicate({ testId, hookId, ruleId, requestInfo });\n        };\n    }\n\n    private _wrapMockPredicate ({ mock, testId, hookId, ruleId }: WrapMockPredicateArguments): void {\n        mock.body = async (requestInfo: RequestInfo, res: IncomingMessageLikeInitOptions) => {\n            return await this.executeMockPredicate({ testId, hookId, ruleId, requestInfo, res });\n        };\n    }\n\n    private _getErrorTypeConstructor (type: string): Function {\n        return errorTypeConstructors.get(type) as Function;\n    }\n\n    public async ready (): Promise<void> {\n        this.emit('ready');\n    }\n\n    public executeCommandSync (): never {\n        throw new MethodShouldNotBeCalledError();\n    }\n\n    public async executeCommand ({ command, id, callsite }: ExecuteCommandArguments): Promise<unknown> {\n        return this\n            ._getTargetTestRun(id)\n            .executeCommand(command, callsite);\n    }\n\n    public async getTests ({ sourceList, compilerOptions, runnableConfigurationId }: CompilerArguments, baseUrl?: string): Promise<Test[]> {\n        const { proxy } = await this._getRuntime();\n\n        const units = await proxy.call(this.getTests, { sourceList, compilerOptions, runnableConfigurationId }, baseUrl);\n\n        return restoreTestStructure(\n            units,\n            (...args) => this._wrapTestFunction(...args),\n            (ruleLocator: RequestFilterRuleLocator) => this._wrapRequestFilterRulePredicate(ruleLocator)\n        );\n    }\n\n    public async runTestFn ({ id, functionName, testRunId }: RunTestArguments): Promise<unknown> {\n        const { proxy } = await this._getRuntime();\n\n        return await proxy.call(this.runTestFn, { id, functionName, testRunId });\n    }\n\n    public async cleanUp (): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        await proxy.call(this.cleanUp);\n    }\n\n    public async setUserVariables (userVariables: UserVariables | null): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        await proxy.call(this.setUserVariables, userVariables);\n    }\n\n\n    public async setOptions ({ value }: SetOptionsArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        const preparedOptions = prepareOptions(value);\n\n        await proxy.call(this.setOptions, { value: preparedOptions });\n    }\n\n    public async onRequestHookEvent ({ name, testId, hookId, eventData }: RequestHookEventArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        await proxy.call(this.onRequestHookEvent, {\n            name,\n            testId,\n            hookId,\n            eventData,\n        });\n    }\n\n    public async setMock ({ testId, hookId, ruleId, responseEventId, mock }: SetMockArguments): Promise<void> {\n        if (mock.isPredicate)\n            this._wrapMockPredicate({ mock, testId, hookId, ruleId });\n\n        await this.emit('setMock', [responseEventId, mock]);\n    }\n\n    public async setConfigureResponseEventOptions ({ eventId, opts }: SetConfigureResponseEventOptionsArguments): Promise<void> {\n        await this.emit('setConfigureResponseEventOptions', [eventId, opts]);\n    }\n\n    public async setHeaderOnConfigureResponseEvent ({ eventId, headerName, headerValue }: SetHeaderOnConfigureResponseEventArguments): Promise<void> {\n        await this.emit('setHeaderOnConfigureResponseEvent', [eventId, headerName, headerValue]);\n    }\n\n    public async removeHeaderOnConfigureResponseEvent ({ eventId, headerName }: RemoveHeaderOnConfigureResponseEventArguments): Promise<void> {\n        await this.emit('removeHeaderOnConfigureResponseEvent', [eventId, headerName]);\n    }\n\n    public async executeRequestFilterRulePredicate ({ testId, hookId, ruleId, requestInfo }: ExecuteRequestFilterRulePredicateArguments): Promise<boolean> {\n        const { proxy } = await this._getRuntime();\n\n        return await proxy.call(this.executeRequestFilterRulePredicate, { testId, hookId, ruleId, requestInfo });\n    }\n\n    public async executeMockPredicate ({ testId, hookId, ruleId, requestInfo, res }: ExecuteMockPredicate): Promise<IncomingMessageLikeInitOptions> {\n        const { proxy } = await this._getRuntime();\n\n        return await proxy.call(this.executeMockPredicate, { testId, hookId, ruleId, requestInfo, res });\n    }\n\n    public async getWarningMessages ({ testRunId }: TestRunLocator): Promise<WarningLogMessage[]> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.getWarningMessages, { testRunId });\n    }\n\n    public async addRequestEventListeners ( { hookId, hookClassName, rules }: AddRequestEventListenersArguments): Promise<void> {\n        await this.emit('addRequestEventListeners', { hookId, hookClassName, rules });\n    }\n\n    public async removeRequestEventListeners ({ rules }: RemoveRequestEventListenersArguments): Promise<void> {\n        await this.emit('removeRequestEventListeners', { rules });\n    }\n\n    public async initializeTestRunData ({ testRunId, testId, browser, activeWindowId, messageBus }: InitializeTestRunDataArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.initializeTestRunData, { testRunId, testId, browser, activeWindowId, messageBus });\n    }\n\n    public async getAssertionActualValue ({ testRunId, commandId }: CommandLocator): Promise<unknown> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.getAssertionActualValue, { testRunId, commandId: commandId });\n    }\n\n    public async executeRoleInitFn ({ testRunId, roleId }: ExecuteRoleInitFnArguments): Promise<unknown> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.executeRoleInitFn, { testRunId, roleId });\n    }\n\n    public async getCtx ({ testRunId }: TestRunLocator): Promise<object> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.getCtx, { testRunId });\n    }\n\n    public async getFixtureCtx ({ testRunId }: TestRunLocator): Promise<object> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.getFixtureCtx, { testRunId });\n    }\n\n    public async setCtx ({ testRunId, value }: SetCtxArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.setCtx, { testRunId, value });\n    }\n\n    public async setFixtureCtx ({ testRunId, value }: SetCtxArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.setFixtureCtx, { testRunId, value });\n    }\n\n    public onRoleAppeared (): void {\n        throw new MethodShouldNotBeCalledError();\n    }\n\n    public async updateRoleProperty ({ roleId, name, value }: UpdateRolePropertyArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.updateRoleProperty, { roleId, name, value });\n    }\n\n    public async executeJsExpression ({ expression, testRunId, options }: ExecuteJsExpressionArguments): Promise<unknown> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.executeJsExpression, { expression, testRunId, options });\n    }\n\n    public async executeAsyncJsExpression ({ expression, testRunId, callsite }: ExecuteAsyncJsExpressionArguments): Promise<unknown> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.executeAsyncJsExpression, { expression, testRunId, callsite });\n    }\n\n    public async executeAssertionFn ({ testRunId, commandId }: CommandLocator): Promise<unknown> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.executeAssertionFn, { testRunId, commandId });\n    }\n\n    public async addUnexpectedError ({ type, message }: AddUnexpectedErrorArguments): Promise<void> {\n        const ErrorTypeConstructor = this._getErrorTypeConstructor(type);\n\n        handleUnexpectedError(ErrorTypeConstructor, message);\n    }\n\n    public async checkWindow ({ testRunId, commandId, url, title }: CheckWindowArgument): Promise<boolean> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.checkWindow, { testRunId, commandId, url, title });\n    }\n\n    public async removeTestRunFromState ({ testRunId }: TestRunLocator): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.removeTestRunFromState, { testRunId });\n    }\n\n    public async removeFixtureCtxsFromState ({ fixtureIds }: RemoveFixtureCtxsArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.removeFixtureCtxsFromState, { fixtureIds });\n    }\n\n    public async removeUnitsFromState ({ runnableConfigurationId }: RemoveUnitsFromStateArguments): Promise<void> {\n        const { proxy } = await this._getRuntime();\n\n        return proxy.call(this.removeUnitsFromState, { runnableConfigurationId });\n    }\n}\n"]}