creevey 0.10.0-beta.4 → 0.10.0-beta.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +19 -41
- package/dist/client/addon/components/Addon.js +17 -7
- package/dist/client/addon/components/Addon.js.map +1 -1
- package/dist/client/addon/components/Panel.js +2 -2
- package/dist/client/addon/components/Panel.js.map +1 -1
- package/dist/client/addon/components/Tools.js +17 -7
- package/dist/client/addon/components/Tools.js.map +1 -1
- package/dist/client/addon/withCreevey.d.ts +2 -1
- package/dist/client/addon/withCreevey.js +11 -1
- package/dist/client/addon/withCreevey.js.map +1 -1
- package/dist/client/shared/components/ImagesView/BlendView.d.ts +1 -1
- package/dist/client/shared/components/ImagesView/BlendView.js +17 -7
- package/dist/client/shared/components/ImagesView/BlendView.js.map +1 -1
- package/dist/client/shared/components/ImagesView/SideBySideView.d.ts +1 -1
- package/dist/client/shared/components/ImagesView/SideBySideView.js +17 -7
- package/dist/client/shared/components/ImagesView/SideBySideView.js.map +1 -1
- package/dist/client/shared/components/ImagesView/SlideView.d.ts +1 -1
- package/dist/client/shared/components/ImagesView/SlideView.js +17 -7
- package/dist/client/shared/components/ImagesView/SlideView.js.map +1 -1
- package/dist/client/shared/components/ImagesView/SwapView.d.ts +1 -1
- package/dist/client/shared/components/ImagesView/SwapView.js +29 -7
- package/dist/client/shared/components/ImagesView/SwapView.js.map +1 -1
- package/dist/client/shared/components/PageHeader/ImagePreview.d.ts +1 -1
- package/dist/client/shared/components/PageHeader/ImagePreview.js +1 -0
- package/dist/client/shared/components/PageHeader/ImagePreview.js.map +1 -1
- package/dist/client/shared/components/PageHeader/PageHeader.js +20 -8
- package/dist/client/shared/components/PageHeader/PageHeader.js.map +1 -1
- package/dist/client/shared/components/ResultsPage.d.ts +1 -1
- package/dist/client/shared/components/ResultsPage.js +43 -13
- package/dist/client/shared/components/ResultsPage.js.map +1 -1
- package/dist/client/shared/creeveyClientApi.js +8 -1
- package/dist/client/shared/creeveyClientApi.js.map +1 -1
- package/dist/client/shared/helpers.d.ts +1 -3
- package/dist/client/shared/helpers.js +4 -19
- package/dist/client/shared/helpers.js.map +1 -1
- package/dist/client/web/CreeveyApp.js +42 -14
- package/dist/client/web/CreeveyApp.js.map +1 -1
- package/dist/client/web/CreeveyContext.d.ts +5 -0
- package/dist/client/web/CreeveyContext.js +20 -7
- package/dist/client/web/CreeveyContext.js.map +1 -1
- package/dist/client/web/CreeveyLoader.js +2 -2
- package/dist/client/web/CreeveyLoader.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/Search.js +19 -9
- package/dist/client/web/CreeveyView/SideBar/Search.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/SideBar.js +18 -7
- package/dist/client/web/CreeveyView/SideBar/SideBar.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/SideBarFooter.js +60 -7
- package/dist/client/web/CreeveyView/SideBar/SideBarFooter.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/SideBarHeader.js +17 -7
- package/dist/client/web/CreeveyView/SideBar/SideBarHeader.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/SuiteLink.d.ts +2 -2
- package/dist/client/web/CreeveyView/SideBar/SuiteLink.js +18 -10
- package/dist/client/web/CreeveyView/SideBar/SuiteLink.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/TestLink.js +18 -10
- package/dist/client/web/CreeveyView/SideBar/TestLink.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/TestStatusIcon.d.ts +1 -1
- package/dist/client/web/CreeveyView/SideBar/TestsStatus.d.ts +1 -1
- package/dist/client/web/KeyboardEventsContext.d.ts +1 -8
- package/dist/client/web/KeyboardEventsContext.js +79 -64
- package/dist/client/web/KeyboardEventsContext.js.map +1 -1
- package/dist/client/web/assets/index-C47njyZV.js +802 -0
- package/dist/client/web/index.html +1 -1
- package/dist/client/web/index.js +17 -7
- package/dist/client/web/index.js.map +1 -1
- package/dist/client/web/themes.d.ts +2 -0
- package/dist/client/web/themes.js +22 -0
- package/dist/client/web/themes.js.map +1 -0
- package/dist/creevey.js +16 -9
- package/dist/creevey.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/server/config.d.ts +1 -1
- package/dist/server/config.js +30 -7
- package/dist/server/config.js.map +1 -1
- package/dist/server/connection.d.ts +3 -0
- package/dist/server/connection.js +28 -0
- package/dist/server/connection.js.map +1 -0
- package/dist/server/docker.d.ts +1 -1
- package/dist/server/docker.js +56 -32
- package/dist/server/docker.js.map +1 -1
- package/dist/server/index.js +64 -11
- package/dist/server/index.js.map +1 -1
- package/dist/server/logger.d.ts +2 -1
- package/dist/server/logger.js +7 -3
- package/dist/server/logger.js.map +1 -1
- package/dist/server/master/api.js +1 -1
- package/dist/server/master/api.js.map +1 -1
- package/dist/server/master/pool.d.ts +4 -3
- package/dist/server/master/pool.js +13 -66
- package/dist/server/master/pool.js.map +1 -1
- package/dist/server/master/queue.d.ts +13 -0
- package/dist/server/master/queue.js +71 -0
- package/dist/server/master/queue.js.map +1 -0
- package/dist/server/master/runner.d.ts +3 -0
- package/dist/server/master/runner.js +78 -10
- package/dist/server/master/runner.js.map +1 -1
- package/dist/server/master/server.js +1 -1
- package/dist/server/master/server.js.map +1 -1
- package/dist/server/master/start.js +13 -11
- package/dist/server/master/start.js.map +1 -1
- package/dist/server/playwright/docker-file.d.ts +1 -1
- package/dist/server/playwright/docker-file.js +15 -6
- package/dist/server/playwright/docker-file.js.map +1 -1
- package/dist/server/playwright/docker.d.ts +2 -1
- package/dist/server/playwright/docker.js +10 -2
- package/dist/server/playwright/docker.js.map +1 -1
- package/dist/server/playwright/index-source.mjs +16 -0
- package/dist/server/playwright/internal.d.ts +6 -6
- package/dist/server/playwright/internal.js +143 -91
- package/dist/server/playwright/internal.js.map +1 -1
- package/dist/server/playwright/webdriver.d.ts +1 -1
- package/dist/server/playwright/webdriver.js +5 -8
- package/dist/server/playwright/webdriver.js.map +1 -1
- package/dist/server/providers/browser.js +6 -4
- package/dist/server/providers/browser.js.map +1 -1
- package/dist/server/providers/hybrid.js +1 -1
- package/dist/server/providers/hybrid.js.map +1 -1
- package/dist/server/reporters/creevey.d.ts +7 -0
- package/dist/server/reporters/creevey.js +63 -0
- package/dist/server/reporters/creevey.js.map +1 -0
- package/dist/server/reporters/index.d.ts +2 -0
- package/dist/server/reporters/index.js +16 -0
- package/dist/server/reporters/index.js.map +1 -0
- package/dist/server/reporters/junit.d.ts +16 -0
- package/dist/server/reporters/junit.js +165 -0
- package/dist/server/reporters/junit.js.map +1 -0
- package/dist/server/reporters/teamcity.d.ts +7 -0
- package/dist/server/reporters/teamcity.js +60 -0
- package/dist/server/reporters/teamcity.js.map +1 -0
- package/dist/server/selenium/internal.d.ts +3 -4
- package/dist/server/selenium/internal.js +127 -108
- package/dist/server/selenium/internal.js.map +1 -1
- package/dist/server/selenium/selenoid.js +8 -6
- package/dist/server/selenium/selenoid.js.map +1 -1
- package/dist/server/selenium/webdriver.d.ts +1 -1
- package/dist/server/selenium/webdriver.js +5 -9
- package/dist/server/selenium/webdriver.js.map +1 -1
- package/dist/server/telemetry.js +2 -2
- package/dist/server/testsFiles/parser.js +45 -5
- package/dist/server/testsFiles/parser.js.map +1 -1
- package/dist/server/utils.d.ts +19 -1
- package/dist/server/utils.js +87 -8
- package/dist/server/utils.js.map +1 -1
- package/dist/server/webdriver.d.ts +5 -4
- package/dist/server/webdriver.js +23 -10
- package/dist/server/webdriver.js.map +1 -1
- package/dist/server/worker/chai-image.d.ts +1 -2
- package/dist/server/worker/chai-image.js +4 -3
- package/dist/server/worker/chai-image.js.map +1 -1
- package/dist/server/worker/context.d.ts +3 -0
- package/dist/server/worker/context.js +15 -0
- package/dist/server/worker/context.js.map +1 -0
- package/dist/server/worker/match-image.d.ts +4 -4
- package/dist/server/worker/match-image.js +7 -4
- package/dist/server/worker/match-image.js.map +1 -1
- package/dist/server/worker/start.js +47 -73
- package/dist/server/worker/start.js.map +1 -1
- package/dist/shared/index.d.ts +1 -1
- package/dist/types.d.ts +46 -10
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -1
- package/docs/cli.md +12 -0
- package/docs/config.md +179 -165
- package/docs/storybook.md +60 -0
- package/docs/tests.md +50 -45
- package/package.json +64 -63
- package/src/client/addon/components/Panel.tsx +2 -2
- package/src/client/addon/withCreevey.ts +10 -2
- package/src/client/shared/components/ImagesView/SwapView.tsx +18 -0
- package/src/client/shared/components/PageHeader/ImagePreview.tsx +1 -0
- package/src/client/shared/components/PageHeader/PageHeader.tsx +4 -2
- package/src/client/shared/components/ResultsPage.tsx +31 -8
- package/src/client/shared/creeveyClientApi.ts +9 -1
- package/src/client/shared/helpers.ts +4 -24
- package/src/client/web/CreeveyApp.tsx +27 -8
- package/src/client/web/CreeveyContext.tsx +9 -0
- package/src/client/web/CreeveyLoader.tsx +1 -1
- package/src/client/web/CreeveyView/SideBar/Search.tsx +3 -3
- package/src/client/web/CreeveyView/SideBar/SideBar.tsx +1 -0
- package/src/client/web/CreeveyView/SideBar/SideBarFooter.tsx +37 -6
- package/src/client/web/CreeveyView/SideBar/SuiteLink.tsx +3 -5
- package/src/client/web/CreeveyView/SideBar/TestLink.tsx +2 -4
- package/src/client/web/KeyboardEventsContext.tsx +61 -73
- package/src/client/web/themes.ts +24 -0
- package/src/creevey.ts +16 -10
- package/src/server/config.ts +30 -7
- package/src/server/connection.ts +26 -0
- package/src/server/docker.ts +63 -34
- package/src/server/index.ts +72 -14
- package/src/server/logger.ts +6 -2
- package/src/server/master/api.ts +1 -1
- package/src/server/master/pool.ts +23 -59
- package/src/server/master/queue.ts +77 -0
- package/src/server/master/runner.ts +96 -10
- package/src/server/master/server.ts +1 -1
- package/src/server/master/start.ts +16 -11
- package/src/server/playwright/docker-file.ts +18 -6
- package/src/server/playwright/docker.ts +16 -3
- package/src/server/playwright/index-source.mjs +16 -0
- package/src/server/playwright/internal.ts +182 -111
- package/src/server/playwright/webdriver.ts +6 -9
- package/src/server/providers/browser.ts +6 -4
- package/src/server/providers/hybrid.ts +1 -1
- package/src/server/reporters/creevey.ts +71 -0
- package/src/server/reporters/index.ts +11 -0
- package/src/server/reporters/junit.ts +205 -0
- package/src/server/reporters/teamcity.ts +74 -0
- package/src/server/selenium/internal.ts +131 -116
- package/src/server/selenium/selenoid.ts +8 -6
- package/src/server/selenium/webdriver.ts +6 -10
- package/src/server/telemetry.ts +2 -2
- package/src/server/testsFiles/parser.ts +52 -4
- package/src/server/utils.ts +97 -9
- package/src/server/webdriver.ts +24 -16
- package/src/server/worker/chai-image.ts +4 -4
- package/src/server/worker/context.ts +14 -0
- package/src/server/worker/match-image.ts +12 -8
- package/src/server/worker/start.ts +51 -86
- package/src/shared/index.ts +1 -1
- package/src/types.ts +50 -11
- package/types/global.d.ts +1 -0
- package/.yarnrc.yml +0 -1
- package/chromatic.config.json +0 -5
- package/dist/client/web/assets/index-DkmZfG9C.js +0 -591
- package/dist/server/reporter.d.ts +0 -26
- package/dist/server/reporter.js +0 -108
- package/dist/server/reporter.js.map +0 -1
- package/src/server/reporter.ts +0 -138
package/dist/server/index.js
CHANGED
@@ -5,15 +5,21 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
6
|
exports.default = default_1;
|
7
7
|
const cluster_1 = __importDefault(require("cluster"));
|
8
|
+
const path_1 = __importDefault(require("path"));
|
9
|
+
const shelljs_1 = require("shelljs");
|
10
|
+
const detect_1 = require("package-manager-detector/detect");
|
11
|
+
const commands_1 = require("package-manager-detector/commands");
|
8
12
|
const config_js_1 = require("./config.js");
|
9
13
|
const types_js_1 = require("../types.js");
|
10
14
|
const logger_js_1 = require("./logger.js");
|
15
|
+
const connection_js_1 = require("./connection.js");
|
11
16
|
const webdriver_js_1 = require("./selenium/webdriver.js");
|
12
17
|
const webdriver_js_2 = require("./webdriver.js");
|
13
18
|
const utils_js_1 = require("./utils.js");
|
14
19
|
const messages_js_1 = require("./messages.js");
|
15
|
-
const docker_file_js_1 = require("./playwright/docker-file.js");
|
16
20
|
const docker_js_1 = require("./docker.js");
|
21
|
+
const promises_1 = require("fs/promises");
|
22
|
+
const assert_1 = __importDefault(require("assert"));
|
17
23
|
async function startWebdriverServer(browser, config, options) {
|
18
24
|
if (config.webdriver === webdriver_js_1.SeleniumWebdriver) {
|
19
25
|
if (cluster_1.default.isPrimary) {
|
@@ -31,24 +37,29 @@ async function startWebdriverServer(browser, config, options) {
|
|
31
37
|
else {
|
32
38
|
if (config.gridUrl)
|
33
39
|
return undefined;
|
34
|
-
|
40
|
+
if (!config.useDocker) {
|
41
|
+
if (cluster_1.default.isPrimary)
|
42
|
+
return undefined;
|
43
|
+
const { browserName } = config.browsers[browser];
|
44
|
+
return `creevey://${(0, utils_js_1.resolvePlaywrightBrowserType)(browserName)}`;
|
45
|
+
}
|
35
46
|
const { default: { version }, } = await import('playwright-core/package.json', { with: { type: 'json' } });
|
36
47
|
if (cluster_1.default.isWorker) {
|
37
48
|
// TODO Re-use dockerImage
|
38
|
-
// TODO Use https://hub.docker.com/r/playwright/chrome
|
39
|
-
// NOTE It will be possible to use `chrome` browserName
|
40
49
|
const { startPlaywrightContainer } = await import('./playwright/docker.js');
|
41
50
|
const { browserName } = config.browsers[browser];
|
42
51
|
const imageName = `creevey/${browserName}:v${version}`;
|
43
|
-
const host = await startPlaywrightContainer(imageName, options.debug);
|
52
|
+
const host = await startPlaywrightContainer(imageName, browser, config, options.debug);
|
44
53
|
return host;
|
45
54
|
}
|
46
55
|
else {
|
56
|
+
const { playwrightDockerFile } = await import('./playwright/docker-file.js');
|
57
|
+
const { default: { version: creeveyVersion }, } = await import('../../package.json', { with: { type: 'json' } });
|
47
58
|
const browsers = [...new Set(Object.values(config.browsers).map((c) => c.browserName))];
|
48
59
|
await Promise.all(browsers.map(async (browserName) => {
|
49
60
|
const imageName = `creevey/${browserName}:v${version}`;
|
50
|
-
const dockerfile =
|
51
|
-
await (0, docker_js_1.buildImage)(imageName, dockerfile);
|
61
|
+
const dockerfile = await playwrightDockerFile(browserName, version);
|
62
|
+
await (0, docker_js_1.buildImage)(imageName, creeveyVersion, dockerfile);
|
52
63
|
}));
|
53
64
|
const { default: getPort } = await import('get-port');
|
54
65
|
cluster_1.default.on('message', (worker, message) => {
|
@@ -73,11 +84,53 @@ async function default_1(options) {
|
|
73
84
|
const config = await (0, config_js_1.readConfig)(options);
|
74
85
|
const { browser = config_js_1.defaultBrowser, update, ui, port } = options;
|
75
86
|
let gridUrl = cluster_1.default.isPrimary ? config.gridUrl : options.gridUrl;
|
87
|
+
// TODO Add package.json with `"type": "commonjs"` as workaround for esm packages to load `data.js`
|
88
|
+
await (0, promises_1.mkdir)(config.reportDir, { recursive: true });
|
89
|
+
await (0, promises_1.writeFile)(path_1.default.join(config.reportDir, 'package.json'), '{"type": "commonjs"}');
|
76
90
|
// NOTE: We don't need docker nor selenoid for update option
|
77
91
|
if (!(gridUrl || Object.values(config.browsers).every(({ gridUrl }) => gridUrl)) &&
|
78
92
|
!update) {
|
79
93
|
gridUrl = await startWebdriverServer(browser, config, options);
|
80
94
|
}
|
95
|
+
if (cluster_1.default.isPrimary) {
|
96
|
+
const [localUrl, remoteUrl] = (0, connection_js_1.getStorybookUrl)(config, options);
|
97
|
+
if (options.storybookStart) {
|
98
|
+
const pm = (0, detect_1.getUserAgent)();
|
99
|
+
(0, assert_1.default)(pm, new Error('Failed to detect current package manager'));
|
100
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
101
|
+
const { command, args } = (0, commands_1.resolveCommand)(pm, 'run', ['storybook', 'dev']);
|
102
|
+
const storybookPort = new URL(localUrl).port;
|
103
|
+
const storybookCommand = `${config.storybookAutorunCmd ?? [command, ...args, '--ci'].join(' ')} -p ${storybookPort}`;
|
104
|
+
(0, logger_js_1.logger)().info(`Start Storybook via \`${storybookCommand}\`, it should be accessible at:`);
|
105
|
+
(0, logger_js_1.logger)().info(`Local - ${localUrl}`);
|
106
|
+
if (remoteUrl && localUrl != remoteUrl)
|
107
|
+
(0, logger_js_1.logger)().info(`On your network - ${remoteUrl}`);
|
108
|
+
(0, logger_js_1.logger)().info('Waiting Storybook...');
|
109
|
+
const storybook = (0, shelljs_1.exec)(storybookCommand, { async: true });
|
110
|
+
(0, messages_js_1.subscribeOn)('shutdown', () => {
|
111
|
+
if (storybook.pid)
|
112
|
+
void (0, utils_js_1.killTree)(storybook.pid);
|
113
|
+
});
|
114
|
+
}
|
115
|
+
else {
|
116
|
+
(0, logger_js_1.logger)().info('Storybook should be started and be accessible at:');
|
117
|
+
(0, logger_js_1.logger)().info(`Local - ${localUrl}`);
|
118
|
+
if (remoteUrl && localUrl != remoteUrl)
|
119
|
+
(0, logger_js_1.logger)().info(`On your network - ${remoteUrl}`);
|
120
|
+
(0, logger_js_1.logger)().info('Tip: Creevey can start Storybook automatically by using `-s` option at the command line. (e.g., yarn/npm run creevey -s)');
|
121
|
+
(0, logger_js_1.logger)().info('Waiting Storybook...');
|
122
|
+
}
|
123
|
+
if (options.storybookStart || process.env.CI !== 'true') {
|
124
|
+
const isConnected = await (0, connection_js_1.checkIsStorybookConnected)(localUrl);
|
125
|
+
if (isConnected) {
|
126
|
+
(0, logger_js_1.logger)().info('Storybook connected!\n');
|
127
|
+
}
|
128
|
+
else {
|
129
|
+
(0, logger_js_1.logger)().error('Storybook is not responding. Please start Storybook and restart Creevey');
|
130
|
+
(0, utils_js_1.shutdownWithError)();
|
131
|
+
}
|
132
|
+
}
|
133
|
+
}
|
81
134
|
switch (true) {
|
82
135
|
case Boolean(update): {
|
83
136
|
(await import('./update.js')).update(config, typeof update == 'string' ? update : undefined);
|
@@ -89,7 +142,7 @@ async function default_1(options) {
|
|
89
142
|
await import('selenium-webdriver');
|
90
143
|
}
|
91
144
|
catch {
|
92
|
-
logger_js_1.logger.error('Failed to start Creevey, missing required dependency: "selenium-webdriver"');
|
145
|
+
(0, logger_js_1.logger)().error('Failed to start Creevey, missing required dependency: "selenium-webdriver"');
|
93
146
|
process.exit(-1);
|
94
147
|
}
|
95
148
|
}
|
@@ -98,16 +151,16 @@ async function default_1(options) {
|
|
98
151
|
await import('playwright-core');
|
99
152
|
}
|
100
153
|
catch {
|
101
|
-
logger_js_1.logger.error('Failed to start Creevey, missing required dependency: "playwright-core"');
|
154
|
+
(0, logger_js_1.logger)().error('Failed to start Creevey, missing required dependency: "playwright-core"');
|
102
155
|
process.exit(-1);
|
103
156
|
}
|
104
157
|
}
|
105
|
-
logger_js_1.logger.info('Starting Master Process');
|
158
|
+
(0, logger_js_1.logger)().info('Starting Master Process');
|
106
159
|
const resolveApi = (await import('./master/server.js')).start(config.reportDir, port, ui);
|
107
160
|
return (await import('./master/start.js')).start(gridUrl, config, options, resolveApi);
|
108
161
|
}
|
109
162
|
default: {
|
110
|
-
logger_js_1.logger.info(`Starting Worker for ${browser}`);
|
163
|
+
(0, logger_js_1.logger)().info(`Starting Worker for ${browser}`);
|
111
164
|
// NOTE: We assume that we pass `gridUrl` to worker CLI options
|
112
165
|
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
113
166
|
return (await import('./worker/start.js')).start(browser, gridUrl, config, options);
|
package/dist/server/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/server/index.ts"],"names":[],"mappings":";;;;;
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/server/index.ts"],"names":[],"mappings":"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"}
|
package/dist/server/logger.d.ts
CHANGED
package/dist/server/logger.js
CHANGED
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
4
|
};
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
-
exports.logger = exports.colors = void 0;
|
6
|
+
exports.logger = exports.setRootName = exports.colors = void 0;
|
7
7
|
const chalk_1 = __importDefault(require("chalk"));
|
8
8
|
const loglevel_1 = __importDefault(require("loglevel"));
|
9
9
|
const loglevel_plugin_prefix_1 = __importDefault(require("loglevel-plugin-prefix"));
|
@@ -14,12 +14,16 @@ exports.colors = {
|
|
14
14
|
WARN: chalk_1.default.yellow,
|
15
15
|
ERROR: chalk_1.default.red,
|
16
16
|
};
|
17
|
+
let rootName = 'Creevey';
|
17
18
|
loglevel_plugin_prefix_1.default.reg(loglevel_1.default);
|
18
19
|
loglevel_plugin_prefix_1.default.apply(loglevel_1.default, {
|
19
|
-
format(level, name =
|
20
|
+
format(level, name = rootName) {
|
20
21
|
const levelColor = exports.colors[level.toUpperCase()];
|
21
22
|
return `[${name}:${chalk_1.default.gray(process.pid)}] ${levelColor(level)} =>`;
|
22
23
|
},
|
23
24
|
});
|
24
|
-
|
25
|
+
const setRootName = (newName) => (rootName = newName);
|
26
|
+
exports.setRootName = setRootName;
|
27
|
+
const logger = () => loglevel_1.default.getLogger(rootName);
|
28
|
+
exports.logger = logger;
|
25
29
|
//# sourceMappingURL=logger.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/server/logger.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAC1B,wDAA8B;AAC9B,oFAA4C;AAE/B,QAAA,MAAM,GAAG;IACpB,KAAK,EAAE,eAAK,CAAC,OAAO;IACpB,KAAK,EAAE,eAAK,CAAC,IAAI;IACjB,IAAI,EAAE,eAAK,CAAC,IAAI;IAChB,IAAI,EAAE,eAAK,CAAC,MAAM;IAClB,KAAK,EAAE,eAAK,CAAC,GAAG;CACjB,CAAC;AAEF,gCAAM,CAAC,GAAG,CAAC,kBAAM,CAAC,CAAC;AACnB,gCAAM,CAAC,KAAK,CAAC,kBAAM,EAAE;IACnB,MAAM,CAAC,KAAK,EAAE,IAAI,GAAG,
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/server/logger.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAC1B,wDAA8B;AAC9B,oFAA4C;AAE/B,QAAA,MAAM,GAAG;IACpB,KAAK,EAAE,eAAK,CAAC,OAAO;IACpB,KAAK,EAAE,eAAK,CAAC,IAAI;IACjB,IAAI,EAAE,eAAK,CAAC,IAAI;IAChB,IAAI,EAAE,eAAK,CAAC,MAAM;IAClB,KAAK,EAAE,eAAK,CAAC,GAAG;CACjB,CAAC;AAEF,IAAI,QAAQ,GAAG,SAAS,CAAC;AAEzB,gCAAM,CAAC,GAAG,CAAC,kBAAM,CAAC,CAAC;AACnB,gCAAM,CAAC,KAAK,CAAC,kBAAM,EAAE;IACnB,MAAM,CAAC,KAAK,EAAE,IAAI,GAAG,QAAQ;QAC3B,MAAM,UAAU,GAAG,cAAM,CAAC,KAAK,CAAC,WAAW,EAAyB,CAAC,CAAC;QACtE,OAAO,IAAI,IAAI,IAAI,eAAK,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC;IACxE,CAAC;CACF,CAAC,CAAC;AAEI,MAAM,WAAW,GAAG,CAAC,OAAe,EAAE,EAAE,CAAC,CAAC,QAAQ,GAAG,OAAO,CAAC,CAAC;AAAxD,QAAA,WAAW,eAA6C;AAE9D,MAAM,MAAM,GAAG,GAAG,EAAE,CAAC,kBAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;AAA1C,QAAA,MAAM,UAAoC"}
|
@@ -22,7 +22,7 @@ function creeveyApi(runner) {
|
|
22
22
|
},
|
23
23
|
handleMessage(ws, message) {
|
24
24
|
if (typeof message != 'string') {
|
25
|
-
logger_js_1.logger.info('unhandled message', message);
|
25
|
+
(0, logger_js_1.logger)().info('unhandled message', message);
|
26
26
|
return;
|
27
27
|
}
|
28
28
|
const command = JSON.parse(message);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../src/server/master/api.ts"],"names":[],"mappings":";;;;;AAkBA,6BAwCC;AA1DD,4CAA2B;AAG3B,4CAAsC;AAOtC,SAAS,SAAS,CAAC,GAAqB,EAAE,OAAiB;IACzD,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE;QACzB,IAAI,EAAE,CAAC,UAAU,KAAK,YAAS,CAAC,IAAI,EAAE,CAAC;YACrC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QACnC,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAwB,UAAU,CAAC,MAAc;IAC/C,OAAO;QACL,SAAS,CAAC,GAAqB;YAC7B,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,OAAsB,EAAE,EAAE;gBAC7C,SAAS,CAAC,GAAG,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;YAC9C,CAAC,CAAC,CAAC;QACL,CAAC;QAED,aAAa,CAAC,EAAa,EAAE,OAAuB;YAClD,IAAI,OAAO,OAAO,IAAI,QAAQ,EAAE,CAAC;gBAC/B,kBAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../src/server/master/api.ts"],"names":[],"mappings":";;;;;AAkBA,6BAwCC;AA1DD,4CAA2B;AAG3B,4CAAsC;AAOtC,SAAS,SAAS,CAAC,GAAqB,EAAE,OAAiB;IACzD,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE;QACzB,IAAI,EAAE,CAAC,UAAU,KAAK,YAAS,CAAC,IAAI,EAAE,CAAC;YACrC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QACnC,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAwB,UAAU,CAAC,MAAc;IAC/C,OAAO;QACL,SAAS,CAAC,GAAqB;YAC7B,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,OAAsB,EAAE,EAAE;gBAC7C,SAAS,CAAC,GAAG,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;YAC9C,CAAC,CAAC,CAAC;QACL,CAAC;QAED,aAAa,CAAC,EAAa,EAAE,OAAuB;YAClD,IAAI,OAAO,OAAO,IAAI,QAAQ,EAAE,CAAC;gBAC/B,IAAA,kBAAM,GAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;gBAC5C,OAAO;YACT,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAY,CAAC;YAE/C,QAAQ,OAAO,CAAC,IAAI,EAAE,CAAC;gBACrB,KAAK,QAAQ,CAAC,CAAC,CAAC;oBACd,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;oBACpE,OAAO;gBACT,CAAC;gBACD,KAAK,OAAO,CAAC,CAAC,CAAC;oBACb,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;oBAC9B,OAAO;gBACT,CAAC;gBACD,KAAK,MAAM,CAAC,CAAC,CAAC;oBACZ,MAAM,CAAC,IAAI,EAAE,CAAC;oBACd,OAAO;gBACT,CAAC;gBACD,KAAK,SAAS,CAAC,CAAC,CAAC;oBACf,KAAK,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;oBACrC,OAAO;gBACT,CAAC;gBACD,KAAK,YAAY,CAAC,CAAC,CAAC;oBAClB,KAAK,MAAM,CAAC,UAAU,EAAE,CAAC;oBACzB,OAAO;gBACT,CAAC;YACH,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC"}
|
@@ -1,6 +1,8 @@
|
|
1
1
|
import { EventEmitter } from 'events';
|
2
2
|
import { Config } from '../../types.js';
|
3
|
+
import { WorkerQueue } from './queue.js';
|
3
4
|
export default class Pool extends EventEmitter {
|
5
|
+
scheduler: WorkerQueue;
|
4
6
|
private browser;
|
5
7
|
private maxRetries;
|
6
8
|
private config;
|
@@ -9,8 +11,9 @@ export default class Pool extends EventEmitter {
|
|
9
11
|
private forcedStop;
|
10
12
|
private failFast;
|
11
13
|
private gridUrl?;
|
14
|
+
private storybookUrl;
|
12
15
|
get isRunning(): boolean;
|
13
|
-
constructor(config: Config, browser: string, gridUrl?: string);
|
16
|
+
constructor(scheduler: WorkerQueue, config: Config, browser: string, gridUrl?: string);
|
14
17
|
init(): Promise<void>;
|
15
18
|
start(tests: {
|
16
19
|
id: string;
|
@@ -22,9 +25,7 @@ export default class Pool extends EventEmitter {
|
|
22
25
|
private getFreeWorker;
|
23
26
|
private get aliveWorkers();
|
24
27
|
private get freeWorkers();
|
25
|
-
private forkWorker;
|
26
28
|
private exitHandler;
|
27
|
-
private gracefullyKill;
|
28
29
|
private shouldRetry;
|
29
30
|
private handleTestResult;
|
30
31
|
private subscribe;
|
@@ -1,35 +1,11 @@
|
|
1
1
|
"use strict";
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
-
if (k2 === undefined) k2 = k;
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
-
}
|
8
|
-
Object.defineProperty(o, k2, desc);
|
9
|
-
}) : (function(o, m, k, k2) {
|
10
|
-
if (k2 === undefined) k2 = k;
|
11
|
-
o[k2] = m[k];
|
12
|
-
}));
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
-
}) : function(o, v) {
|
16
|
-
o["default"] = v;
|
17
|
-
});
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
-
if (mod && mod.__esModule) return mod;
|
20
|
-
var result = {};
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
-
__setModuleDefault(result, mod);
|
23
|
-
return result;
|
24
|
-
};
|
25
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
26
|
-
const cluster_1 =
|
3
|
+
const cluster_1 = require("cluster");
|
27
4
|
const events_1 = require("events");
|
28
|
-
const types_js_1 = require("../../types.js");
|
29
5
|
const messages_js_1 = require("../messages.js");
|
30
6
|
const utils_js_1 = require("../utils.js");
|
31
|
-
const FORK_RETRIES = 5;
|
32
7
|
class Pool extends events_1.EventEmitter {
|
8
|
+
scheduler;
|
33
9
|
browser;
|
34
10
|
maxRetries;
|
35
11
|
config;
|
@@ -38,21 +14,23 @@ class Pool extends events_1.EventEmitter {
|
|
38
14
|
forcedStop = false;
|
39
15
|
failFast;
|
40
16
|
gridUrl;
|
17
|
+
storybookUrl;
|
41
18
|
get isRunning() {
|
42
19
|
return this.workers.length !== this.freeWorkers.length;
|
43
20
|
}
|
44
|
-
constructor(config, browser, gridUrl) {
|
21
|
+
constructor(scheduler, config, browser, gridUrl) {
|
45
22
|
super();
|
23
|
+
this.scheduler = scheduler;
|
46
24
|
this.browser = browser;
|
47
25
|
this.failFast = config.failFast;
|
48
26
|
this.maxRetries = config.maxRetries;
|
49
27
|
this.config = config.browsers[browser];
|
50
28
|
this.gridUrl = this.config.gridUrl ?? gridUrl;
|
29
|
+
this.storybookUrl = this.config.storybookUrl ?? config.storybookUrl;
|
51
30
|
}
|
52
31
|
async init() {
|
53
32
|
const poolSize = Math.max(1, this.config.limit ?? 1);
|
54
|
-
|
55
|
-
this.workers = (await Promise.all(Array.from({ length: poolSize }).map(() => this.forkWorker()))).filter((workerOrError) => workerOrError instanceof cluster_1.Worker);
|
33
|
+
this.workers = (await Promise.all(Array.from({ length: poolSize }).map(() => this.scheduler.forkWorker(this.browser, this.storybookUrl, this.gridUrl)))).filter((workerOrError) => workerOrError instanceof cluster_1.Worker);
|
56
34
|
if (this.workers.length != poolSize)
|
57
35
|
throw new Error(`Can't instantiate workers for ${this.browser} due many errors`);
|
58
36
|
this.workers.forEach((worker) => {
|
@@ -90,7 +68,9 @@ class Pool extends events_1.EventEmitter {
|
|
90
68
|
this.sendStatus({ id, status: 'running' });
|
91
69
|
this.subscribe(worker, test);
|
92
70
|
(0, messages_js_1.sendTestMessage)(worker, { type: 'start', payload: test });
|
93
|
-
|
71
|
+
setImmediate(() => {
|
72
|
+
this.process();
|
73
|
+
});
|
94
74
|
}
|
95
75
|
sendStatus(message) {
|
96
76
|
this.emit('test', message);
|
@@ -105,35 +85,12 @@ class Pool extends events_1.EventEmitter {
|
|
105
85
|
get freeWorkers() {
|
106
86
|
return this.aliveWorkers.filter((worker) => !worker.isRunning);
|
107
87
|
}
|
108
|
-
async forkWorker(retry = 0) {
|
109
|
-
if (utils_js_1.isShuttingDown.current)
|
110
|
-
return { error: 'Master process is shutting down' };
|
111
|
-
cluster_1.default.setupPrimary({
|
112
|
-
args: ['--browser', this.browser, ...(this.gridUrl ? ['--gridUrl', this.gridUrl] : []), ...process.argv.slice(2)],
|
113
|
-
});
|
114
|
-
const worker = cluster_1.default.fork();
|
115
|
-
const message = await new Promise((resolve) => {
|
116
|
-
const readyHandler = (message) => {
|
117
|
-
if (!(0, types_js_1.isWorkerMessage)(message) || message.type == 'port')
|
118
|
-
return;
|
119
|
-
worker.off('message', readyHandler);
|
120
|
-
resolve(message);
|
121
|
-
};
|
122
|
-
worker.on('message', readyHandler);
|
123
|
-
});
|
124
|
-
if (message.type != 'error')
|
125
|
-
return worker;
|
126
|
-
this.gracefullyKill(worker);
|
127
|
-
if (retry == FORK_RETRIES)
|
128
|
-
return message.payload;
|
129
|
-
return this.forkWorker(retry + 1);
|
130
|
-
}
|
131
88
|
exitHandler(worker) {
|
132
89
|
// eslint-disable-next-line @typescript-eslint/no-misused-promises
|
133
90
|
worker.once('exit', async () => {
|
134
91
|
if (utils_js_1.isShuttingDown.current)
|
135
92
|
return;
|
136
|
-
const workerOrError = await this.forkWorker();
|
93
|
+
const workerOrError = await this.scheduler.forkWorker(this.browser, this.storybookUrl, this.gridUrl);
|
137
94
|
if (!(workerOrError instanceof cluster_1.Worker))
|
138
95
|
throw new Error(`Can't instantiate worker for ${this.browser} due many errors`);
|
139
96
|
this.exitHandler(workerOrError);
|
@@ -141,16 +98,6 @@ class Pool extends events_1.EventEmitter {
|
|
141
98
|
this.process();
|
142
99
|
});
|
143
100
|
}
|
144
|
-
gracefullyKill(worker) {
|
145
|
-
worker.isShuttingDown = true;
|
146
|
-
const timeout = setTimeout(() => {
|
147
|
-
worker.kill();
|
148
|
-
}, 10000);
|
149
|
-
worker.on('exit', () => {
|
150
|
-
clearTimeout(timeout);
|
151
|
-
});
|
152
|
-
(0, messages_js_1.sendShutdownMessage)(worker);
|
153
|
-
}
|
154
101
|
shouldRetry(test) {
|
155
102
|
return test.retries < this.maxRetries && !this.forcedStop;
|
156
103
|
}
|
@@ -175,9 +122,9 @@ class Pool extends events_1.EventEmitter {
|
|
175
122
|
unsubscribe();
|
176
123
|
});
|
177
124
|
if (message.payload.subtype == 'unknown') {
|
178
|
-
|
125
|
+
(0, utils_js_1.gracefullyKill)(worker);
|
179
126
|
}
|
180
|
-
this.handleTestResult(worker, test, { status: 'failed', error: message.payload.error });
|
127
|
+
this.handleTestResult(worker, test, { status: 'failed', error: message.payload.error, retries: test.retries });
|
181
128
|
}),
|
182
129
|
(0, messages_js_1.subscribeOnWorker)(worker, 'test', (message) => {
|
183
130
|
if (message.type != 'end')
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"pool.js","sourceRoot":"","sources":["../../../src/server/master/pool.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"pool.js","sourceRoot":"","sources":["../../../src/server/master/pool.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import { Worker } from '../../types.js';
|
2
|
+
type MaybeWorker = Worker | {
|
3
|
+
error: string;
|
4
|
+
};
|
5
|
+
export declare class WorkerQueue {
|
6
|
+
private useQueue;
|
7
|
+
private isProcessing;
|
8
|
+
private queue;
|
9
|
+
constructor(useQueue: boolean);
|
10
|
+
forkWorker(browser: string, storybookUrl: string, gridUrl?: string, retry?: number): Promise<MaybeWorker>;
|
11
|
+
private process;
|
12
|
+
}
|
13
|
+
export {};
|
@@ -0,0 +1,71 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.WorkerQueue = void 0;
|
7
|
+
const cluster_1 = __importDefault(require("cluster"));
|
8
|
+
const types_js_1 = require("../../types.js");
|
9
|
+
const utils_js_1 = require("../utils.js");
|
10
|
+
const FORK_RETRIES = 5;
|
11
|
+
class WorkerQueue {
|
12
|
+
useQueue;
|
13
|
+
isProcessing = false;
|
14
|
+
queue = [];
|
15
|
+
// TODO Add concurrency
|
16
|
+
constructor(useQueue) {
|
17
|
+
this.useQueue = useQueue;
|
18
|
+
}
|
19
|
+
async forkWorker(browser, storybookUrl, gridUrl, retry = 0) {
|
20
|
+
return new Promise((resolve) => {
|
21
|
+
this.queue.push({ browser, storybookUrl, gridUrl, retry, resolve });
|
22
|
+
void this.process();
|
23
|
+
});
|
24
|
+
}
|
25
|
+
async process() {
|
26
|
+
if (this.useQueue && this.isProcessing)
|
27
|
+
return;
|
28
|
+
const { browser, storybookUrl, gridUrl, retry, resolve } = this.queue.pop() ?? {};
|
29
|
+
if (browser == undefined || storybookUrl == undefined || retry == undefined || resolve == undefined)
|
30
|
+
return;
|
31
|
+
if (utils_js_1.isShuttingDown.current) {
|
32
|
+
resolve({ error: 'Master process is shutting down' });
|
33
|
+
return;
|
34
|
+
}
|
35
|
+
this.isProcessing = true;
|
36
|
+
cluster_1.default.setupPrimary({
|
37
|
+
args: [
|
38
|
+
'--browser',
|
39
|
+
browser,
|
40
|
+
...(gridUrl ? ['--gridUrl', gridUrl] : []),
|
41
|
+
...process.argv.slice(2),
|
42
|
+
'--storybookUrl',
|
43
|
+
storybookUrl,
|
44
|
+
],
|
45
|
+
});
|
46
|
+
const worker = cluster_1.default.fork();
|
47
|
+
const message = await new Promise((resolve) => {
|
48
|
+
const readyHandler = (message) => {
|
49
|
+
if (!(0, types_js_1.isWorkerMessage)(message) || message.type == 'port')
|
50
|
+
return;
|
51
|
+
worker.off('message', readyHandler);
|
52
|
+
resolve(message);
|
53
|
+
};
|
54
|
+
worker.on('message', readyHandler);
|
55
|
+
});
|
56
|
+
if (message.type == 'error') {
|
57
|
+
(0, utils_js_1.gracefullyKill)(worker);
|
58
|
+
if (retry == FORK_RETRIES)
|
59
|
+
resolve(message.payload);
|
60
|
+
else
|
61
|
+
this.queue.push({ browser, storybookUrl, gridUrl, retry: retry + 1, resolve });
|
62
|
+
}
|
63
|
+
else {
|
64
|
+
resolve(worker);
|
65
|
+
}
|
66
|
+
this.isProcessing = false;
|
67
|
+
setImmediate(() => void this.process());
|
68
|
+
}
|
69
|
+
}
|
70
|
+
exports.WorkerQueue = WorkerQueue;
|
71
|
+
//# sourceMappingURL=queue.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../../src/server/master/queue.ts"],"names":[],"mappings":"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"}
|
@@ -5,7 +5,10 @@ export default class Runner extends EventEmitter {
|
|
5
5
|
private screenDir;
|
6
6
|
private reportDir;
|
7
7
|
private browsers;
|
8
|
+
private scheduler;
|
8
9
|
private pools;
|
10
|
+
private fakeRunner;
|
11
|
+
private config;
|
9
12
|
tests: Partial<Record<string, ServerTest>>;
|
10
13
|
get isRunning(): boolean;
|
11
14
|
constructor(config: Config, gridUrl?: string);
|