creevey 0.10.0-beta.9 → 0.10.0-rc.1
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/AUTHORS +2 -0
- package/CHANGELOG.md +281 -0
- package/README.md +19 -41
- package/dist/client/addon/components/Addon.js +18 -8
- 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/TestSelect.js +2 -2
- package/dist/client/addon/components/TestSelect.js.map +1 -1
- package/dist/client/addon/components/Tools.js +19 -9
- package/dist/client/addon/components/Tools.js.map +1 -1
- package/dist/client/addon/controller.d.ts +1 -1
- package/dist/client/addon/controller.js +3 -3
- package/dist/client/addon/controller.js.map +1 -1
- package/dist/client/addon/decorator.d.ts +1 -1
- package/dist/client/addon/makeDecorator.d.ts +9 -0
- package/dist/client/addon/makeDecorator.js +48 -0
- package/dist/client/addon/makeDecorator.js.map +1 -0
- package/dist/client/addon/manager.js +38 -39
- package/dist/client/addon/manager.js.map +1 -1
- package/dist/client/addon/preset.d.ts +0 -1
- package/dist/client/addon/preset.js +3 -2
- package/dist/client/addon/preset.js.map +1 -1
- package/dist/client/addon/preview.d.ts +1 -1
- package/dist/client/addon/withCreevey.d.ts +5 -3
- package/dist/client/addon/withCreevey.js +5 -20
- package/dist/client/addon/withCreevey.js.map +1 -1
- package/dist/client/shared/components/ImagesView/BlendView.d.ts +2 -2
- package/dist/client/shared/components/ImagesView/BlendView.js +18 -8
- package/dist/client/shared/components/ImagesView/BlendView.js.map +1 -1
- package/dist/client/shared/components/ImagesView/ImagesView.js +1 -1
- package/dist/client/shared/components/ImagesView/ImagesView.js.map +1 -1
- package/dist/client/shared/components/ImagesView/SideBySideView.d.ts +2 -2
- package/dist/client/shared/components/ImagesView/SideBySideView.js +19 -9
- package/dist/client/shared/components/ImagesView/SideBySideView.js.map +1 -1
- package/dist/client/shared/components/ImagesView/SlideView.d.ts +2 -2
- package/dist/client/shared/components/ImagesView/SlideView.js +19 -9
- package/dist/client/shared/components/ImagesView/SlideView.js.map +1 -1
- package/dist/client/shared/components/ImagesView/SwapView.d.ts +2 -2
- package/dist/client/shared/components/ImagesView/SwapView.js +19 -9
- package/dist/client/shared/components/ImagesView/SwapView.js.map +1 -1
- package/dist/client/shared/components/ImagesView/common.d.ts +1 -1
- package/dist/client/shared/components/PageFooter/PageFooter.js +1 -1
- package/dist/client/shared/components/PageFooter/PageFooter.js.map +1 -1
- package/dist/client/shared/components/PageFooter/Paging.js +1 -1
- package/dist/client/shared/components/PageFooter/Paging.js.map +1 -1
- package/dist/client/shared/components/PageHeader/ImagePreview.d.ts +2 -2
- package/dist/client/shared/components/PageHeader/ImagePreview.js +1 -1
- package/dist/client/shared/components/PageHeader/ImagePreview.js.map +1 -1
- package/dist/client/shared/components/PageHeader/PageHeader.js +34 -13
- package/dist/client/shared/components/PageHeader/PageHeader.js.map +1 -1
- package/dist/client/shared/components/ResultsPage.d.ts +2 -2
- package/dist/client/shared/components/ResultsPage.js +22 -10
- package/dist/client/shared/components/ResultsPage.js.map +1 -1
- package/dist/client/shared/creeveyClientApi.js +18 -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.d.ts +1 -0
- package/dist/client/web/CreeveyApp.js +22 -9
- package/dist/client/web/CreeveyApp.js.map +1 -1
- package/dist/client/web/CreeveyContext.d.ts +1 -0
- package/dist/client/web/CreeveyContext.js +18 -7
- package/dist/client/web/CreeveyContext.js.map +1 -1
- package/dist/client/web/CreeveyLoader.d.ts +1 -1
- package/dist/client/web/CreeveyLoader.js +3 -3
- package/dist/client/web/CreeveyLoader.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/Checkbox.d.ts +4 -4
- package/dist/client/web/CreeveyView/SideBar/Checkbox.js +36 -6
- package/dist/client/web/CreeveyView/SideBar/Checkbox.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/Search.js +18 -8
- package/dist/client/web/CreeveyView/SideBar/Search.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/SideBar.js +26 -12
- package/dist/client/web/CreeveyView/SideBar/SideBar.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/SideBarFooter.js +28 -17
- package/dist/client/web/CreeveyView/SideBar/SideBarFooter.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/SideBarHeader.js +32 -12
- package/dist/client/web/CreeveyView/SideBar/SideBarHeader.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/SuiteLink.d.ts +6 -6
- package/dist/client/web/CreeveyView/SideBar/SuiteLink.js +20 -11
- package/dist/client/web/CreeveyView/SideBar/SuiteLink.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/TestLink.js +20 -11
- package/dist/client/web/CreeveyView/SideBar/TestLink.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/TestStatusIcon.d.ts +2 -2
- package/dist/client/web/CreeveyView/SideBar/TestStatusIcon.js +2 -2
- package/dist/client/web/CreeveyView/SideBar/TestStatusIcon.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/TestsStatus.d.ts +2 -2
- package/dist/client/web/CreeveyView/SideBar/TestsStatus.js +3 -2
- package/dist/client/web/CreeveyView/SideBar/TestsStatus.js.map +1 -1
- package/dist/client/web/CreeveyView/SideBar/Toggle.js +1 -1
- package/dist/client/web/CreeveyView/SideBar/Toggle.js.map +1 -1
- package/dist/client/web/KeyboardEventsContext.js +17 -7
- package/dist/client/web/KeyboardEventsContext.js.map +1 -1
- package/dist/client/web/assets/index-CtSq3IhG.js +518 -0
- package/dist/client/web/index.html +1 -1
- package/dist/client/web/index.js +26 -11
- 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.d.ts +1 -1
- package/dist/creevey.js +122 -41
- package/dist/creevey.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/playwright/generator.d.ts +34 -0
- package/dist/playwright/generator.js +267 -0
- package/dist/playwright/generator.js.map +1 -0
- package/dist/playwright/helpers.d.ts +2 -0
- package/dist/playwright/helpers.js +29 -0
- package/dist/playwright/helpers.js.map +1 -0
- package/dist/playwright/reporter.d.ts +83 -0
- package/dist/playwright/reporter.js +334 -0
- package/dist/playwright/reporter.js.map +1 -0
- package/dist/playwright/setup.d.ts +3 -0
- package/dist/playwright/setup.js +72 -0
- package/dist/playwright/setup.js.map +1 -0
- package/dist/playwright.d.ts +1 -0
- package/dist/playwright.js +3 -1
- package/dist/playwright.js.map +1 -1
- package/dist/server/compare.d.ts +18 -0
- package/dist/server/compare.js +182 -0
- package/dist/server/compare.js.map +1 -0
- package/dist/server/config.d.ts +3 -3
- package/dist/server/config.js +75 -8
- 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 +54 -32
- package/dist/server/docker.js.map +1 -1
- package/dist/server/index.d.ts +2 -2
- package/dist/server/index.js +166 -64
- package/dist/server/index.js.map +1 -1
- package/dist/server/master/api.d.ts +11 -6
- package/dist/server/master/api.js +88 -25
- package/dist/server/master/api.js.map +1 -1
- package/dist/server/master/handlers/capture-handler.d.ts +5 -0
- package/dist/server/master/handlers/capture-handler.js +25 -0
- package/dist/server/master/handlers/capture-handler.js.map +1 -0
- package/dist/server/master/handlers/index.d.ts +4 -0
- package/dist/server/master/handlers/index.js +21 -0
- package/dist/server/master/handlers/index.js.map +1 -0
- package/dist/server/master/handlers/ping-handler.d.ts +2 -0
- package/dist/server/master/handlers/ping-handler.js +8 -0
- package/dist/server/master/handlers/ping-handler.js.map +1 -0
- package/dist/server/master/handlers/static-handler.d.ts +1 -0
- package/dist/server/master/handlers/static-handler.js +20 -0
- package/dist/server/master/handlers/static-handler.js.map +1 -0
- package/dist/server/master/handlers/stories-handler.d.ts +4 -0
- package/dist/server/master/handlers/stories-handler.js +24 -0
- package/dist/server/master/handlers/stories-handler.js.map +1 -0
- package/dist/server/master/master.js +7 -24
- package/dist/server/master/master.js.map +1 -1
- package/dist/server/master/pool.d.ts +1 -0
- package/dist/server/master/pool.js +5 -3
- package/dist/server/master/pool.js.map +1 -1
- package/dist/server/master/queue.d.ts +1 -1
- package/dist/server/master/queue.js +14 -6
- package/dist/server/master/queue.js.map +1 -1
- package/dist/server/master/runner.d.ts +6 -6
- package/dist/server/master/runner.js +98 -130
- package/dist/server/master/runner.js.map +1 -1
- package/dist/server/master/server.d.ts +1 -1
- package/dist/server/master/server.js +193 -88
- package/dist/server/master/server.js.map +1 -1
- package/dist/server/master/start.d.ts +1 -2
- package/dist/server/master/start.js +13 -29
- package/dist/server/master/start.js.map +1 -1
- package/dist/server/master/testsManager.d.ts +81 -0
- package/dist/server/master/testsManager.js +282 -0
- package/dist/server/master/testsManager.js.map +1 -0
- package/dist/server/playwright/docker-file.d.ts +1 -1
- package/dist/server/playwright/docker-file.js +17 -8
- 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 +7 -7
- package/dist/server/playwright/internal.js +137 -79
- package/dist/server/playwright/internal.js.map +1 -1
- package/dist/server/playwright/webdriver.d.ts +3 -3
- package/dist/server/playwright/webdriver.js +0 -6
- package/dist/server/playwright/webdriver.js.map +1 -1
- package/dist/server/providers/browser.js +4 -3
- package/dist/server/providers/browser.js.map +1 -1
- package/dist/server/providers/hybrid.js +2 -2
- package/dist/server/providers/hybrid.js.map +1 -1
- package/dist/server/report.d.ts +10 -0
- package/dist/server/report.js +45 -0
- package/dist/server/report.js.map +1 -0
- 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 +167 -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 -3
- package/dist/server/selenium/internal.js +48 -34
- package/dist/server/selenium/internal.js.map +1 -1
- package/dist/server/selenium/selenoid.js +12 -6
- package/dist/server/selenium/selenoid.js.map +1 -1
- package/dist/server/selenium/webdriver.d.ts +3 -3
- package/dist/server/selenium/webdriver.js +4 -8
- package/dist/server/selenium/webdriver.js.map +1 -1
- package/dist/server/shutdown.d.ts +1 -0
- package/dist/server/shutdown.js +23 -0
- package/dist/server/shutdown.js.map +1 -0
- package/dist/server/stories.d.ts +0 -1
- package/dist/server/stories.js +0 -12
- package/dist/server/stories.js.map +1 -1
- package/dist/server/telemetry.js +3 -3
- package/dist/server/telemetry.js.map +1 -1
- package/dist/server/testsFiles/parser.js +45 -5
- package/dist/server/testsFiles/parser.js.map +1 -1
- package/dist/server/utils.d.ts +23 -0
- package/dist/server/utils.js +113 -13
- package/dist/server/utils.js.map +1 -1
- package/dist/server/webdriver.d.ts +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 +8 -12
- package/dist/server/worker/match-image.js +11 -178
- package/dist/server/worker/match-image.js.map +1 -1
- package/dist/server/worker/start.d.ts +2 -2
- package/dist/server/worker/start.js +27 -63
- package/dist/server/worker/start.js.map +1 -1
- package/dist/shared/index.d.ts +1 -1
- package/dist/shared/index.js +9 -7
- package/dist/shared/index.js.map +1 -1
- package/dist/types.d.ts +84 -43
- package/dist/types.js +65 -1
- package/dist/types.js.map +1 -1
- package/docs/cli.md +80 -0
- package/docs/config.md +179 -165
- package/docs/examples/playwright-reporer/playwright.config.ts +36 -0
- package/docs/migration-0.9-to-0.10.md +182 -0
- package/docs/playwright-reporter.md +170 -0
- package/docs/storybook.md +60 -0
- package/docs/tests.md +50 -45
- package/package.json +78 -83
- package/playwright.config.mts +46 -0
- package/src/client/addon/components/Addon.tsx +1 -1
- package/src/client/addon/components/Panel.tsx +2 -2
- package/src/client/addon/components/TestSelect.tsx +2 -2
- package/src/client/addon/components/Tools.tsx +2 -2
- package/src/client/addon/controller.ts +4 -4
- package/src/client/addon/makeDecorator.ts +69 -0
- package/src/client/addon/manager.ts +38 -37
- package/src/client/addon/preset.ts +2 -1
- package/src/client/addon/withCreevey.ts +10 -18
- package/src/client/shared/components/ImagesView/BlendView.tsx +1 -1
- package/src/client/shared/components/ImagesView/ImagesView.tsx +1 -1
- package/src/client/shared/components/ImagesView/SideBySideView.tsx +2 -2
- package/src/client/shared/components/ImagesView/SlideView.tsx +2 -2
- package/src/client/shared/components/ImagesView/SwapView.tsx +2 -2
- package/src/client/shared/components/ImagesView/common.ts +1 -1
- package/src/client/shared/components/PageFooter/PageFooter.tsx +1 -1
- package/src/client/shared/components/PageFooter/Paging.tsx +1 -1
- package/src/client/shared/components/PageHeader/ImagePreview.tsx +1 -1
- package/src/client/shared/components/PageHeader/PageHeader.tsx +23 -7
- package/src/client/shared/components/ResultsPage.tsx +6 -4
- package/src/client/shared/creeveyClientApi.ts +19 -1
- package/src/client/shared/helpers.ts +4 -24
- package/src/client/web/CreeveyApp.tsx +5 -2
- package/src/client/web/CreeveyContext.tsx +2 -0
- package/src/client/web/CreeveyLoader.tsx +2 -2
- package/src/client/web/CreeveyView/SideBar/Checkbox.tsx +3 -3
- package/src/client/web/CreeveyView/SideBar/Search.tsx +1 -1
- package/src/client/web/CreeveyView/SideBar/SideBar.tsx +11 -6
- package/src/client/web/CreeveyView/SideBar/SideBarFooter.tsx +21 -19
- package/src/client/web/CreeveyView/SideBar/SideBarHeader.tsx +20 -5
- package/src/client/web/CreeveyView/SideBar/SuiteLink.tsx +10 -8
- package/src/client/web/CreeveyView/SideBar/TestLink.tsx +9 -7
- package/src/client/web/CreeveyView/SideBar/TestStatusIcon.tsx +2 -2
- package/src/client/web/CreeveyView/SideBar/TestsStatus.tsx +3 -2
- package/src/client/web/CreeveyView/SideBar/Toggle.tsx +1 -1
- package/src/client/web/index.tsx +10 -5
- package/src/client/web/themes.ts +24 -0
- package/src/creevey.ts +92 -38
- package/src/playwright/generator.ts +360 -0
- package/src/playwright/helpers.ts +31 -0
- package/src/playwright/reporter.ts +381 -0
- package/src/playwright/setup.ts +84 -0
- package/src/playwright.ts +1 -0
- package/src/server/compare.ts +260 -0
- package/src/server/config.ts +52 -9
- package/src/server/connection.ts +26 -0
- package/src/server/docker.ts +62 -34
- package/src/server/index.ts +165 -79
- package/src/server/master/api.ts +94 -28
- package/src/server/master/handlers/capture-handler.ts +20 -0
- package/src/server/master/handlers/index.ts +4 -0
- package/src/server/master/handlers/ping-handler.ts +6 -0
- package/src/server/master/handlers/static-handler.ts +16 -0
- package/src/server/master/handlers/stories-handler.ts +20 -0
- package/src/server/master/master.ts +10 -27
- package/src/server/master/pool.ts +7 -3
- package/src/server/master/queue.ts +21 -7
- package/src/server/master/runner.ts +123 -134
- package/src/server/master/server.ts +214 -101
- package/src/server/master/start.ts +19 -41
- package/src/server/master/testsManager.ts +316 -0
- package/src/server/playwright/docker-file.ts +20 -8
- package/src/server/playwright/docker.ts +16 -3
- package/src/server/playwright/index-source.mjs +16 -0
- package/src/server/playwright/internal.ts +169 -96
- package/src/server/playwright/webdriver.ts +4 -10
- package/src/server/providers/browser.ts +4 -3
- package/src/server/providers/hybrid.ts +2 -3
- package/src/server/report.ts +51 -0
- package/src/server/reporters/creevey.ts +74 -0
- package/src/server/reporters/index.ts +11 -0
- package/src/server/reporters/junit.ts +207 -0
- package/src/server/reporters/teamcity.ts +74 -0
- package/src/server/selenium/internal.ts +62 -45
- package/src/server/selenium/selenoid.ts +13 -6
- package/src/server/selenium/webdriver.ts +8 -12
- package/src/server/shutdown.ts +19 -0
- package/src/server/stories.ts +1 -12
- package/src/server/telemetry.ts +3 -3
- package/src/server/testsFiles/parser.ts +52 -4
- package/src/server/utils.ts +123 -14
- package/src/server/webdriver.ts +1 -1
- package/src/server/worker/context.ts +14 -0
- package/src/server/worker/match-image.ts +16 -248
- package/src/server/worker/start.ts +32 -75
- package/src/shared/index.ts +10 -8
- package/src/types.ts +91 -58
- package/types/global.d.ts +1 -0
- package/dist/client/web/assets/index-BE9CL5_G.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/dist/server/update.d.ts +0 -2
- package/dist/server/update.js +0 -53
- package/dist/server/update.js.map +0 -1
- package/src/server/reporter.ts +0 -139
- package/src/server/update.ts +0 -74
@@ -8,14 +8,20 @@ type MaybeWorker = Worker | { error: string };
|
|
8
8
|
|
9
9
|
export class WorkerQueue {
|
10
10
|
private isProcessing = false;
|
11
|
-
private queue: {
|
11
|
+
private queue: {
|
12
|
+
browser: string;
|
13
|
+
storybookUrl: string;
|
14
|
+
gridUrl?: string;
|
15
|
+
retry: number;
|
16
|
+
resolve: (mw: MaybeWorker) => void;
|
17
|
+
}[] = [];
|
12
18
|
|
13
19
|
// TODO Add concurrency
|
14
20
|
constructor(private useQueue: boolean) {}
|
15
21
|
|
16
|
-
async forkWorker(browser: string, gridUrl?: string, retry = 0): Promise<MaybeWorker> {
|
22
|
+
async forkWorker(browser: string, storybookUrl: string, gridUrl?: string, retry = 0): Promise<MaybeWorker> {
|
17
23
|
return new Promise<MaybeWorker>((resolve) => {
|
18
|
-
this.queue.push({ browser, gridUrl, retry, resolve });
|
24
|
+
this.queue.push({ browser, storybookUrl, gridUrl, retry, resolve });
|
19
25
|
|
20
26
|
void this.process();
|
21
27
|
});
|
@@ -24,9 +30,9 @@ export class WorkerQueue {
|
|
24
30
|
private async process() {
|
25
31
|
if (this.useQueue && this.isProcessing) return;
|
26
32
|
|
27
|
-
const { browser, gridUrl, retry, resolve } = this.queue.pop() ?? {};
|
33
|
+
const { browser, storybookUrl, gridUrl, retry, resolve } = this.queue.pop() ?? {};
|
28
34
|
|
29
|
-
if (browser == undefined || retry == undefined || resolve == undefined) return;
|
35
|
+
if (browser == undefined || storybookUrl == undefined || retry == undefined || resolve == undefined) return;
|
30
36
|
|
31
37
|
if (isShuttingDown.current) {
|
32
38
|
resolve({ error: 'Master process is shutting down' });
|
@@ -36,7 +42,15 @@ export class WorkerQueue {
|
|
36
42
|
this.isProcessing = true;
|
37
43
|
|
38
44
|
cluster.setupPrimary({
|
39
|
-
args: [
|
45
|
+
args: [
|
46
|
+
'worker',
|
47
|
+
'--browser',
|
48
|
+
browser,
|
49
|
+
...(gridUrl ? ['--gridUrl', gridUrl] : []),
|
50
|
+
...process.argv.slice(3),
|
51
|
+
'--storybookUrl',
|
52
|
+
storybookUrl,
|
53
|
+
],
|
40
54
|
});
|
41
55
|
const worker = cluster.fork();
|
42
56
|
const message = await new Promise((resolve: (value: WorkerMessage) => void) => {
|
@@ -52,7 +66,7 @@ export class WorkerQueue {
|
|
52
66
|
gracefullyKill(worker);
|
53
67
|
|
54
68
|
if (retry == FORK_RETRIES) resolve(message.payload);
|
55
|
-
else this.queue.push({ browser, gridUrl, retry: retry + 1, resolve });
|
69
|
+
else this.queue.push({ browser, storybookUrl, gridUrl, retry: retry + 1, resolve });
|
56
70
|
} else {
|
57
71
|
resolve(worker);
|
58
72
|
}
|
@@ -1,5 +1,3 @@
|
|
1
|
-
import path from 'path';
|
2
|
-
import { copyFile, mkdir } from 'fs/promises';
|
3
1
|
import { EventEmitter } from 'events';
|
4
2
|
import {
|
5
3
|
Config,
|
@@ -10,30 +8,59 @@ import {
|
|
10
8
|
CreeveyUpdate,
|
11
9
|
TestStatus,
|
12
10
|
ServerTest,
|
13
|
-
|
11
|
+
TEST_EVENTS,
|
12
|
+
FakeSuite,
|
13
|
+
FakeTest,
|
14
14
|
} from '../../types.js';
|
15
15
|
import Pool from './pool.js';
|
16
16
|
import { WorkerQueue } from './queue.js';
|
17
|
+
import { getTestPath } from '../utils.js';
|
18
|
+
import { getReporter } from '../reporters/index.js';
|
19
|
+
import type { TestsManager } from './testsManager.js';
|
20
|
+
|
21
|
+
// NOTE: This is workaround to fix parallel tests running with mocha-junit-reporter
|
22
|
+
let isJUnit = false;
|
23
|
+
|
24
|
+
class FakeRunner extends EventEmitter {
|
25
|
+
public stats = {
|
26
|
+
duration: 0,
|
27
|
+
failures: 0,
|
28
|
+
pending: 0,
|
29
|
+
};
|
30
|
+
}
|
17
31
|
|
18
32
|
export default class Runner extends EventEmitter {
|
19
33
|
private failFast: boolean;
|
20
|
-
private screenDir: string;
|
21
|
-
private reportDir: string;
|
22
34
|
private browsers: string[];
|
23
35
|
private scheduler: WorkerQueue;
|
24
36
|
private pools: Record<string, Pool> = {};
|
25
|
-
|
37
|
+
private fakeRunner: FakeRunner;
|
38
|
+
private config: Config;
|
39
|
+
public testsManager: TestsManager;
|
40
|
+
|
26
41
|
public get isRunning(): boolean {
|
27
42
|
return Object.values(this.pools).some((pool) => pool.isRunning);
|
28
43
|
}
|
29
|
-
|
44
|
+
|
45
|
+
constructor(config: Config, testsManager: TestsManager, gridUrl?: string) {
|
30
46
|
super();
|
31
47
|
|
48
|
+
this.config = config;
|
32
49
|
this.failFast = config.failFast;
|
33
|
-
this.
|
34
|
-
this.reportDir = config.reportDir;
|
50
|
+
this.testsManager = testsManager;
|
35
51
|
this.scheduler = new WorkerQueue(config.useWorkerQueue);
|
36
52
|
this.browsers = Object.keys(config.browsers);
|
53
|
+
|
54
|
+
const runner = new FakeRunner();
|
55
|
+
const Reporter = getReporter(config.reporter);
|
56
|
+
|
57
|
+
if (Reporter.name == 'MochaJUnitReporter') {
|
58
|
+
isJUnit = true;
|
59
|
+
}
|
60
|
+
|
61
|
+
new Reporter(runner, { reportDir: config.reportDir, reporterOptions: config.reporterOptions });
|
62
|
+
this.fakeRunner = runner;
|
63
|
+
|
37
64
|
this.browsers
|
38
65
|
.map((browser) => (this.pools[browser] = new Pool(this.scheduler, config, browser, gridUrl)))
|
39
66
|
.map((pool) => pool.on('test', this.handlePoolMessage));
|
@@ -41,46 +68,83 @@ export default class Runner extends EventEmitter {
|
|
41
68
|
|
42
69
|
private handlePoolMessage = (message: { id: string; status: TestStatus; result?: TestResult }): void => {
|
43
70
|
const { id, status, result } = message;
|
44
|
-
const test = this.
|
71
|
+
const test = this.testsManager.getTest(id);
|
45
72
|
|
46
73
|
if (!test) return;
|
47
|
-
const { browser, testName
|
48
|
-
|
49
|
-
|
74
|
+
const { browser, testName } = test;
|
75
|
+
|
76
|
+
const fakeSuite: FakeSuite = {
|
77
|
+
title: test.storyPath.slice(0, -1).join('/'),
|
78
|
+
fullTitle: () => fakeSuite.title,
|
79
|
+
titlePath: () => [fakeSuite.title],
|
80
|
+
tests: [],
|
81
|
+
};
|
82
|
+
|
83
|
+
const fakeTest: FakeTest = {
|
84
|
+
parent: fakeSuite,
|
85
|
+
title: [test.story.name, testName, browser].filter(isDefined).join('/'),
|
86
|
+
fullTitle: () => getTestPath(test).join('/'),
|
87
|
+
titlePath: () => getTestPath(test),
|
88
|
+
currentRetry: () => result?.retries,
|
89
|
+
retires: () => this.config.maxRetries,
|
90
|
+
slow: () => 1000,
|
91
|
+
err: result?.error,
|
92
|
+
creevey: {
|
93
|
+
sessionId: result?.sessionId ?? id,
|
94
|
+
browserName: result?.browserName ?? browser,
|
95
|
+
workerId: result?.workerId ?? process.pid,
|
96
|
+
willRetry: (result?.retries ?? 0) < this.config.maxRetries,
|
97
|
+
images: result?.images ?? {},
|
98
|
+
},
|
99
|
+
};
|
100
|
+
|
101
|
+
fakeSuite.tests.push(fakeTest);
|
102
|
+
|
103
|
+
const update = this.testsManager.updateTestStatus(id, status, result);
|
104
|
+
if (!update) return;
|
105
|
+
|
50
106
|
if (!result) {
|
51
|
-
|
52
|
-
this.sendUpdate(
|
107
|
+
this.fakeRunner.emit(TEST_EVENTS.TEST_BEGIN, fakeTest);
|
108
|
+
this.sendUpdate(update);
|
53
109
|
return;
|
54
110
|
}
|
55
|
-
|
56
|
-
|
111
|
+
|
112
|
+
const { duration, attachments } = result;
|
113
|
+
|
114
|
+
fakeTest.duration = duration;
|
115
|
+
fakeTest.attachments = attachments;
|
116
|
+
fakeTest.state = result.status === 'failed' ? 'failed' : 'passed';
|
117
|
+
if (duration !== undefined) {
|
118
|
+
fakeTest.speed = duration > fakeTest.slow() ? 'slow' : duration / 2 > fakeTest.slow() ? 'medium' : 'fast';
|
57
119
|
}
|
58
|
-
test.results.push(result);
|
59
120
|
|
60
|
-
if (
|
61
|
-
|
121
|
+
if (isJUnit) {
|
122
|
+
this.fakeRunner.emit(TEST_EVENTS.SUITE_BEGIN, fakeSuite);
|
62
123
|
}
|
63
124
|
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
125
|
+
if (result.status === 'failed') {
|
126
|
+
fakeTest.err = result.error;
|
127
|
+
this.fakeRunner.emit(TEST_EVENTS.TEST_FAIL, fakeTest, result.error);
|
128
|
+
this.fakeRunner.stats.failures++;
|
129
|
+
} else {
|
130
|
+
this.fakeRunner.emit(TEST_EVENTS.TEST_PASS, fakeTest);
|
131
|
+
this.fakeRunner.stats.duration += duration ?? 0;
|
132
|
+
}
|
133
|
+
|
134
|
+
if (isJUnit) {
|
135
|
+
this.fakeRunner.emit(TEST_EVENTS.SUITE_END, fakeSuite);
|
136
|
+
}
|
137
|
+
|
138
|
+
this.fakeRunner.emit(TEST_EVENTS.TEST_END, fakeTest);
|
139
|
+
|
140
|
+
this.sendUpdate(update);
|
78
141
|
|
79
142
|
if (this.failFast && status == 'failed') this.stop();
|
80
143
|
};
|
81
144
|
|
82
145
|
private handlePoolStop = (): void => {
|
83
146
|
if (!this.isRunning) {
|
147
|
+
this.fakeRunner.emit(TEST_EVENTS.RUN_END);
|
84
148
|
this.sendUpdate({ isRunning: false });
|
85
149
|
this.emit('stop');
|
86
150
|
}
|
@@ -91,31 +155,8 @@ export default class Runner extends EventEmitter {
|
|
91
155
|
}
|
92
156
|
|
93
157
|
public updateTests(testsDiff: Partial<Record<string, ServerTest>>): void {
|
94
|
-
const
|
95
|
-
|
96
|
-
Object.entries(testsDiff).forEach(([id, newTest]) => {
|
97
|
-
const oldTest = this.tests[id];
|
98
|
-
if (newTest) {
|
99
|
-
if (oldTest) {
|
100
|
-
this.tests[id] = {
|
101
|
-
...newTest,
|
102
|
-
retries: oldTest.retries,
|
103
|
-
results: oldTest.results,
|
104
|
-
approved: oldTest.approved,
|
105
|
-
};
|
106
|
-
} else this.tests[id] = newTest;
|
107
|
-
|
108
|
-
const { story: _, fn: __, ...restTest } = newTest;
|
109
|
-
tests[id] = { ...restTest, status: 'unknown' };
|
110
|
-
} else if (oldTest) {
|
111
|
-
const { id, browser, testName, storyPath, storyId } = oldTest;
|
112
|
-
removedTests.push({ id, browser, testName, storyPath, storyId });
|
113
|
-
// TODO Use Map instead
|
114
|
-
// eslint-disable-next-line @typescript-eslint/no-dynamic-delete
|
115
|
-
delete this.tests[id];
|
116
|
-
}
|
117
|
-
});
|
118
|
-
this.sendUpdate({ tests, removedTests });
|
158
|
+
const update = this.testsManager.updateTests(testsDiff);
|
159
|
+
if (update) this.sendUpdate(update);
|
119
160
|
}
|
120
161
|
|
121
162
|
public start(ids: string[]): void {
|
@@ -123,33 +164,39 @@ export default class Runner extends EventEmitter {
|
|
123
164
|
if (this.isRunning) return;
|
124
165
|
|
125
166
|
const testsToStart = ids
|
126
|
-
.map((id) => this.
|
167
|
+
.map((id) => this.testsManager.getTest(id))
|
127
168
|
.filter(isDefined)
|
128
169
|
.filter((test) => !test.skip);
|
129
170
|
|
130
171
|
if (testsToStart.length == 0) return;
|
131
172
|
|
173
|
+
const pendingTests: CreeveyUpdate['tests'] = testsToStart.reduce(
|
174
|
+
(update: CreeveyUpdate['tests'], { id, storyId, browser, testName, storyPath }) => ({
|
175
|
+
...update,
|
176
|
+
[id]: { id, browser, testName, storyPath, status: 'pending', storyId },
|
177
|
+
}),
|
178
|
+
{},
|
179
|
+
);
|
180
|
+
|
132
181
|
this.sendUpdate({
|
133
182
|
isRunning: true,
|
134
|
-
tests:
|
135
|
-
(update: CreeveyUpdate['tests'], { id, storyId, browser, testName, storyPath }) => ({
|
136
|
-
...update,
|
137
|
-
[id]: { id, browser, testName, storyPath, status: 'pending', storyId },
|
138
|
-
}),
|
139
|
-
{},
|
140
|
-
),
|
183
|
+
tests: pendingTests,
|
141
184
|
});
|
142
185
|
|
143
186
|
const testsByBrowser: Partial<TestsByBrowser> = testsToStart.reduce((tests: Partial<TestsByBrowser>, test) => {
|
144
187
|
const { id, browser, testName, storyPath } = test;
|
145
188
|
const restPath = [...storyPath, testName].filter(isDefined);
|
146
|
-
|
189
|
+
|
190
|
+
// Update status to pending in TestsManager
|
191
|
+
this.testsManager.updateTestStatus(id, 'pending');
|
192
|
+
|
147
193
|
return {
|
148
194
|
...tests,
|
149
195
|
[browser]: [...(tests[browser] ?? []), { id, path: restPath }],
|
150
196
|
};
|
151
197
|
}, {});
|
152
198
|
|
199
|
+
this.fakeRunner.emit(TEST_EVENTS.RUN_BEGIN);
|
153
200
|
this.browsers.forEach((browser) => {
|
154
201
|
const pool = this.pools[browser];
|
155
202
|
const tests = testsByBrowser[browser];
|
@@ -168,82 +215,24 @@ export default class Runner extends EventEmitter {
|
|
168
215
|
}
|
169
216
|
|
170
217
|
public get status(): CreeveyStatus {
|
171
|
-
const tests: CreeveyStatus['tests'] = {};
|
172
|
-
Object.values(this.tests)
|
173
|
-
.filter(isDefined)
|
174
|
-
|
175
|
-
.forEach(({ story: _, fn: __, ...test }) => (tests[test.id] = test));
|
176
218
|
return {
|
177
219
|
isRunning: this.isRunning,
|
178
|
-
tests,
|
220
|
+
tests: this.testsManager.getTestsData(),
|
179
221
|
browsers: this.browsers,
|
222
|
+
isUpdateMode: false,
|
180
223
|
};
|
181
224
|
}
|
182
225
|
|
183
|
-
private async copyImage(test: ServerTest, image: string, actual: string): Promise<void> {
|
184
|
-
const { browser, testName, storyPath } = test;
|
185
|
-
const restPath = [...storyPath, testName].filter(isDefined);
|
186
|
-
const testPath = path.join(...restPath, image == browser ? '' : browser);
|
187
|
-
const srcImagePath = path.join(this.reportDir, testPath, actual);
|
188
|
-
const dstImagePath = path.join(this.screenDir, testPath, `${image}.png`);
|
189
|
-
await mkdir(path.join(this.screenDir, testPath), { recursive: true });
|
190
|
-
await copyFile(srcImagePath, dstImagePath);
|
191
|
-
}
|
192
|
-
|
193
226
|
public async approveAll(): Promise<void> {
|
194
|
-
const
|
195
|
-
|
196
|
-
if (!test?.results) continue;
|
197
|
-
const retry = test.results.length - 1;
|
198
|
-
const { images, status } = test.results.at(retry) ?? {};
|
199
|
-
if (!images || status != 'failed') continue;
|
200
|
-
for (const [name, image] of Object.entries(images)) {
|
201
|
-
if (!image) continue;
|
202
|
-
await this.copyImage(test, name, image.actual);
|
203
|
-
|
204
|
-
if (!test.approved) {
|
205
|
-
test.approved = {};
|
206
|
-
}
|
207
|
-
test.approved[name] = retry;
|
208
|
-
test.status = 'approved';
|
209
|
-
|
210
|
-
updatedTests[test.id] = {
|
211
|
-
id: test.id,
|
212
|
-
browser: test.browser,
|
213
|
-
storyPath: test.storyPath,
|
214
|
-
storyId: test.storyId,
|
215
|
-
status: test.status,
|
216
|
-
approved: { [name]: retry },
|
217
|
-
};
|
218
|
-
}
|
219
|
-
}
|
220
|
-
this.sendUpdate({ tests: updatedTests });
|
227
|
+
const update = await this.testsManager.approveAll();
|
228
|
+
this.sendUpdate(update);
|
221
229
|
}
|
222
230
|
|
223
|
-
public async approve(
|
224
|
-
const
|
225
|
-
if (
|
226
|
-
const result = test.results[retry];
|
227
|
-
if (!result.images) return;
|
228
|
-
const images = result.images[image];
|
229
|
-
if (!images) return;
|
230
|
-
if (!test.approved) {
|
231
|
-
test.approved = {};
|
232
|
-
}
|
233
|
-
const { browser, testName, storyPath, storyId } = test;
|
234
|
-
|
235
|
-
await this.copyImage(test, image, images.actual);
|
236
|
-
|
237
|
-
test.approved[image] = retry;
|
238
|
-
|
239
|
-
if (Object.keys(result.images).every((name) => typeof test.approved?.[name] == 'number')) {
|
240
|
-
test.status = 'approved';
|
241
|
-
}
|
242
|
-
|
243
|
-
this.sendUpdate({
|
244
|
-
tests: { [id]: { id, browser, testName, storyPath, status: test.status, approved: { [image]: retry }, storyId } },
|
245
|
-
});
|
231
|
+
public async approve(payload: ApprovePayload): Promise<void> {
|
232
|
+
const update = await this.testsManager.approve(payload);
|
233
|
+
if (update) this.sendUpdate(update);
|
246
234
|
}
|
235
|
+
|
247
236
|
private sendUpdate(data: CreeveyUpdate): void {
|
248
237
|
this.emit('update', data);
|
249
238
|
}
|