happo 6.11.0 → 6.12.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/dist/cli/cancelJob-CXFNZISF.js +10 -0
- package/dist/cli/{chunk-SVDBGQ4O.js → chunk-ELEYE33M.js} +2 -2
- package/dist/cli/{chunk-6AZGN5XD.js → chunk-IN3NUOK5.js} +2 -2
- package/dist/cli/{chunk-IUOF4JKX.js → chunk-JP4CQJOB.js} +2 -2
- package/dist/cli/{chunk-BIONLQW5.js → chunk-KIKOPE76.js} +3 -3
- package/dist/cli/{chunk-GO45JS7U.js → chunk-M6KGLDWT.js} +4 -4
- package/dist/cli/{chunk-GO45JS7U.js.map → chunk-M6KGLDWT.js.map} +2 -2
- package/dist/cli/{chunk-KYZ5LJRW.js → chunk-R5S67WFY.js} +2 -2
- package/dist/cli/createAsyncComparison-A7XFBPPB.js +10 -0
- package/dist/cli/{createAsyncReport-JFB5U3MB.js → createAsyncReport-HDUAAI6X.js} +4 -4
- package/dist/cli/{createExtendsReportSnapRequest-OXWMNIG6.js → createExtendsReportSnapRequest-O4TCQEKU.js} +4 -4
- package/dist/cli/{findBaselineReport-L6GKAQVD.js → findBaselineReport-QJA6XU2W.js} +4 -4
- package/dist/cli/{getFlakes-LD2GKSTE.js → getFlakes-B5M53JHP.js} +4 -4
- package/dist/cli/main.js +24 -15
- package/dist/cli/main.js.map +2 -2
- package/dist/cli/package-X535EUT6.js +7 -0
- package/dist/cli/{prepareSnapRequests-Q5HCJH4V.js → prepareSnapRequests-LZPA55RF.js} +14 -9
- package/dist/cli/prepareSnapRequests-LZPA55RF.js.map +7 -0
- package/dist/cli/startJob-EY5AL55N.js +10 -0
- package/dist/cli/{wrapper-Z2ZPQNNP.js → wrapper-OCC73BIP.js} +7 -7
- package/dist/config/RemoteBrowserTarget.d.ts +6 -1
- package/dist/config/RemoteBrowserTarget.d.ts.map +1 -1
- package/dist/config/index.d.ts +39 -2
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js.map +2 -2
- package/dist/config/loadConfig.d.ts.map +1 -1
- package/dist/cypress/task.js +48 -23
- package/dist/cypress/task.js.map +3 -3
- package/dist/e2e/controller.d.ts.map +1 -1
- package/dist/network/prepareSnapRequests.d.ts.map +1 -1
- package/dist/playwright/index.d.ts.map +1 -1
- package/dist/playwright/index.js +55 -24
- package/dist/playwright/index.js.map +3 -3
- package/package.json +3 -3
- package/dist/cli/cancelJob-HDGBLBQQ.js +0 -10
- package/dist/cli/createAsyncComparison-3DNQLFCD.js +0 -10
- package/dist/cli/package-EM6BIUGF.js +0 -7
- package/dist/cli/prepareSnapRequests-Q5HCJH4V.js.map +0 -7
- package/dist/cli/startJob-6QVJYHOT.js +0 -10
- /package/dist/cli/{cancelJob-HDGBLBQQ.js.map → cancelJob-CXFNZISF.js.map} +0 -0
- /package/dist/cli/{chunk-SVDBGQ4O.js.map → chunk-ELEYE33M.js.map} +0 -0
- /package/dist/cli/{chunk-6AZGN5XD.js.map → chunk-IN3NUOK5.js.map} +0 -0
- /package/dist/cli/{chunk-IUOF4JKX.js.map → chunk-JP4CQJOB.js.map} +0 -0
- /package/dist/cli/{chunk-BIONLQW5.js.map → chunk-KIKOPE76.js.map} +0 -0
- /package/dist/cli/{chunk-KYZ5LJRW.js.map → chunk-R5S67WFY.js.map} +0 -0
- /package/dist/cli/{createAsyncComparison-3DNQLFCD.js.map → createAsyncComparison-A7XFBPPB.js.map} +0 -0
- /package/dist/cli/{createAsyncReport-JFB5U3MB.js.map → createAsyncReport-HDUAAI6X.js.map} +0 -0
- /package/dist/cli/{createExtendsReportSnapRequest-OXWMNIG6.js.map → createExtendsReportSnapRequest-O4TCQEKU.js.map} +0 -0
- /package/dist/cli/{findBaselineReport-L6GKAQVD.js.map → findBaselineReport-QJA6XU2W.js.map} +0 -0
- /package/dist/cli/{getFlakes-LD2GKSTE.js.map → getFlakes-B5M53JHP.js.map} +0 -0
- /package/dist/cli/{package-EM6BIUGF.js.map → package-X535EUT6.js.map} +0 -0
- /package/dist/cli/{startJob-6QVJYHOT.js.map → startJob-EY5AL55N.js.map} +0 -0
- /package/dist/cli/{wrapper-Z2ZPQNNP.js.map → wrapper-OCC73BIP.js.map} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"controller.d.ts","sourceRoot":"","sources":["../../src/e2e/controller.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"controller.d.ts","sourceRoot":"","sources":["../../src/e2e/controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepareSnapRequests.d.ts","sourceRoot":"","sources":["../../src/network/prepareSnapRequests.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAI7D,OAAO,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAqJjE,MAAM,WAAW,yBAAyB;IACxC,cAAc,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IAC9B,YAAY,CAAC,EAAE,KAAK,CAAC;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAC/D;AAED,wBAA8B,mBAAmB,CAC/C,MAAM,EAAE,kBAAkB,EAC1B,IAAI,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,EACtB,IAAI,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,GACrB,OAAO,CAAC,yBAAyB,CAAC,
|
|
1
|
+
{"version":3,"file":"prepareSnapRequests.d.ts","sourceRoot":"","sources":["../../src/network/prepareSnapRequests.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAI7D,OAAO,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAqJjE,MAAM,WAAW,yBAAyB;IACxC,cAAc,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IAC9B,YAAY,CAAC,EAAE,KAAK,CAAC;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAC/D;AAED,wBAA8B,mBAAmB,CAC/C,MAAM,EAAE,kBAAkB,EAC1B,IAAI,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,EACtB,IAAI,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,GACrB,OAAO,CAAC,yBAAyB,CAAC,CAgFpC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/playwright/index.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,aAAa,EACb,OAAO,EACP,kBAAkB,EAClB,qBAAqB,EACrB,oBAAoB,EACpB,uBAAuB,EACvB,QAAQ,EACT,MAAM,kBAAkB,CAAC;AAsB1B,KAAK,kBAAkB,GAAG,CACxB,eAAe,EAAE,aAAa,GAAG,OAAO,GAAG,IAAI,EAC/C,OAAO,EAAE;IACP,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,gBAAgB,CAAC,EAAE,OAAO,GAAG,MAAM,CAAC;IACpC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB,KACE,OAAO,CAAC,IAAI,CAAC,CAAC;AAEnB,MAAM,WAAW,YAAY;IAC3B,eAAe,EAAE,kBAAkB,CAAC;IACpC,iBAAiB,EAAE,IAAI,CAAC;CACzB;AAED,MAAM,WAAW,cAAc;IAC7B,mBAAmB,EAAE,IAAI,CAAC;CAC3B;AAMD,eAAO,MAAM,IAAI,EAAE,QAAQ,CACzB,kBAAkB,GAAG,qBAAqB,GAAG,YAAY,EACzD,oBAAoB,GAAG,uBAAuB,GAAG,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/playwright/index.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,aAAa,EACb,OAAO,EACP,kBAAkB,EAClB,qBAAqB,EACrB,oBAAoB,EACpB,uBAAuB,EACvB,QAAQ,EACT,MAAM,kBAAkB,CAAC;AAsB1B,KAAK,kBAAkB,GAAG,CACxB,eAAe,EAAE,aAAa,GAAG,OAAO,GAAG,IAAI,EAC/C,OAAO,EAAE;IACP,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,gBAAgB,CAAC,EAAE,OAAO,GAAG,MAAM,CAAC;IACpC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB,KACE,OAAO,CAAC,IAAI,CAAC,CAAC;AAEnB,MAAM,WAAW,YAAY;IAC3B,eAAe,EAAE,kBAAkB,CAAC;IACpC,iBAAiB,EAAE,IAAI,CAAC;CACzB;AAED,MAAM,WAAW,cAAc;IAC7B,mBAAmB,EAAE,IAAI,CAAC;CAC3B;AAMD,eAAO,MAAM,IAAI,EAAE,QAAQ,CACzB,kBAAkB,GAAG,qBAAqB,GAAG,YAAY,EACzD,oBAAoB,GAAG,uBAAuB,GAAG,cAAc,CA8I/D,CAAC"}
|
package/dist/playwright/index.js
CHANGED
|
@@ -5,12 +5,14 @@ import { test as base } from "@playwright/test";
|
|
|
5
5
|
|
|
6
6
|
// src/e2e/controller.ts
|
|
7
7
|
import fs4 from "node:fs";
|
|
8
|
+
import { inspect as inspect2 } from "node:util";
|
|
8
9
|
import limitConcur from "limit-concur";
|
|
9
10
|
|
|
10
11
|
// src/config/loadConfig.ts
|
|
11
12
|
import fs from "node:fs";
|
|
12
13
|
import path from "node:path";
|
|
13
14
|
import { pathToFileURL } from "node:url";
|
|
15
|
+
import { inspect } from "node:util";
|
|
14
16
|
import { any as findAny } from "empathic/find";
|
|
15
17
|
|
|
16
18
|
// src/network/fetchWithRetry.ts
|
|
@@ -19,7 +21,7 @@ import asyncRetry from "async-retry";
|
|
|
19
21
|
// package.json
|
|
20
22
|
var package_default = {
|
|
21
23
|
name: "happo",
|
|
22
|
-
version: "6.
|
|
24
|
+
version: "6.12.1",
|
|
23
25
|
description: "Catch unexpected visual and accessibility changes and UI bugs",
|
|
24
26
|
license: "MIT",
|
|
25
27
|
repository: {
|
|
@@ -145,7 +147,7 @@ var package_default = {
|
|
|
145
147
|
"eslint-config-prettier": "^10.1.8",
|
|
146
148
|
"eslint-plugin-compat": "^7.0.1",
|
|
147
149
|
"eslint-plugin-depend": "^1.4.0",
|
|
148
|
-
"eslint-plugin-simple-import-sort": "^
|
|
150
|
+
"eslint-plugin-simple-import-sort": "^13.0.0",
|
|
149
151
|
"eslint-plugin-unicorn": "^64.0.0",
|
|
150
152
|
jiti: "^2.6.1",
|
|
151
153
|
jsdom: "^29.0.0",
|
|
@@ -154,9 +156,9 @@ var package_default = {
|
|
|
154
156
|
react: "^19.2.0",
|
|
155
157
|
"react-dom": "^19.2.0",
|
|
156
158
|
"react-error-boundary": "^6.0.0",
|
|
159
|
+
"release-with-ease": "^2.4.0",
|
|
157
160
|
storybook: "^10.0.1",
|
|
158
161
|
typescript: "^6.0.2",
|
|
159
|
-
"release-with-ease": "^2.1.0",
|
|
160
162
|
"typescript-eslint": "^8.57.2"
|
|
161
163
|
},
|
|
162
164
|
dependencies: {
|
|
@@ -653,6 +655,14 @@ async function loadConfigFile(configFilePath, environment, logger = console) {
|
|
|
653
655
|
config.deepCompare.diffAlgorithm = "color-delta";
|
|
654
656
|
}
|
|
655
657
|
}
|
|
658
|
+
if (config.failOnWaitForTimeout !== void 0 && typeof config.failOnWaitForTimeout !== "boolean") {
|
|
659
|
+
throw new TypeError(
|
|
660
|
+
`Invalid \`failOnWaitForTimeout\` in config file ${configFilePath}: must be a boolean, got: ${inspect(config.failOnWaitForTimeout)}.`
|
|
661
|
+
);
|
|
662
|
+
}
|
|
663
|
+
if (config.failOnWaitForTimeout === void 0) {
|
|
664
|
+
config.failOnWaitForTimeout = true;
|
|
665
|
+
}
|
|
656
666
|
const configWithDefaults = {
|
|
657
667
|
endpoint: DEFAULT_ENDPOINT,
|
|
658
668
|
githubApiUrl: "https://api.github.com",
|
|
@@ -778,7 +788,8 @@ function buildChunkItem({
|
|
|
778
788
|
globalCSS,
|
|
779
789
|
staticPackage,
|
|
780
790
|
assetsPackage,
|
|
781
|
-
targetName
|
|
791
|
+
targetName,
|
|
792
|
+
failOnWaitForTimeout
|
|
782
793
|
}) {
|
|
783
794
|
const payloadString = JSON.stringify({
|
|
784
795
|
viewport,
|
|
@@ -790,7 +801,8 @@ function buildChunkItem({
|
|
|
790
801
|
staticPackage,
|
|
791
802
|
assetsPackage,
|
|
792
803
|
pages: pageSlice,
|
|
793
|
-
extendsSha: pageSlice ? pageSlice.extendsSha : void 0
|
|
804
|
+
extendsSha: pageSlice ? pageSlice.extendsSha : void 0,
|
|
805
|
+
failOnWaitForTimeout
|
|
794
806
|
});
|
|
795
807
|
const payloadHash = createHash(payloadString + (pageSlice ? Math.random() : ""));
|
|
796
808
|
const type = pageSlice && pageSlice.extendsSha ? "extends-report" : `browser-${browserName}`;
|
|
@@ -868,7 +880,8 @@ var RemoteBrowserTarget = class {
|
|
|
868
880
|
snapPayloads,
|
|
869
881
|
pages,
|
|
870
882
|
targetName,
|
|
871
|
-
estimatedSnapsCount
|
|
883
|
+
estimatedSnapsCount,
|
|
884
|
+
failOnWaitForTimeout
|
|
872
885
|
}, config) {
|
|
873
886
|
const buildItemParams = {
|
|
874
887
|
browserName: this.browserName,
|
|
@@ -878,7 +891,8 @@ var RemoteBrowserTarget = class {
|
|
|
878
891
|
globalCSS,
|
|
879
892
|
staticPackage,
|
|
880
893
|
assetsPackage,
|
|
881
|
-
targetName
|
|
894
|
+
targetName,
|
|
895
|
+
failOnWaitForTimeout
|
|
882
896
|
};
|
|
883
897
|
const items = [];
|
|
884
898
|
if (staticPackage) {
|
|
@@ -1571,7 +1585,8 @@ var Controller = class {
|
|
|
1571
1585
|
targetName: name,
|
|
1572
1586
|
globalCSS,
|
|
1573
1587
|
assetsPackage: assetsPath,
|
|
1574
|
-
snapPayloads: snapshotsForTarget
|
|
1588
|
+
snapPayloads: snapshotsForTarget,
|
|
1589
|
+
failOnWaitForTimeout: this.happoConfig.failOnWaitForTimeout
|
|
1575
1590
|
},
|
|
1576
1591
|
this.happoConfig
|
|
1577
1592
|
);
|
|
@@ -1700,23 +1715,33 @@ var Controller = class {
|
|
|
1700
1715
|
for (const target of targets) {
|
|
1701
1716
|
if (typeof target === "string") {
|
|
1702
1717
|
result.push(target);
|
|
1718
|
+
continue;
|
|
1703
1719
|
}
|
|
1704
|
-
if (typeof target
|
|
1705
|
-
|
|
1706
|
-
|
|
1707
|
-
|
|
1708
|
-
|
|
1709
|
-
|
|
1710
|
-
|
|
1711
|
-
|
|
1712
|
-
|
|
1713
|
-
|
|
1714
|
-
|
|
1715
|
-
|
|
1716
|
-
|
|
1717
|
-
|
|
1718
|
-
|
|
1720
|
+
if (typeof target !== "object" || target === null) {
|
|
1721
|
+
throw new TypeError(
|
|
1722
|
+
`Invalid target: expected a string or an object of the form { name, viewport, type }. Received ${typeof target}: ${inspect2(target)}`
|
|
1723
|
+
);
|
|
1724
|
+
}
|
|
1725
|
+
const missing = [];
|
|
1726
|
+
if (!target.name) missing.push("name");
|
|
1727
|
+
if (!target.viewport) missing.push("viewport");
|
|
1728
|
+
if (!target.type) missing.push("type");
|
|
1729
|
+
if (missing.length > 0) {
|
|
1730
|
+
const received = Object.keys(target);
|
|
1731
|
+
const hint = "browserType" in target || "browser" in target ? " (the `browser`/`browserType` field was renamed to `type`)" : "";
|
|
1732
|
+
throw new Error(
|
|
1733
|
+
`Invalid dynamic target: missing required field(s) ${missing.map((m) => `\`${m}\``).join(", ")}${hint}. Received fields: [${received.join(", ")}]. Full value: ${inspect2(target)}`
|
|
1734
|
+
);
|
|
1719
1735
|
}
|
|
1736
|
+
if (!this.happoConfig.targets[target.name]) {
|
|
1737
|
+
const constructedTarget = {
|
|
1738
|
+
viewport: target.viewport,
|
|
1739
|
+
type: target.type,
|
|
1740
|
+
__dynamic: true
|
|
1741
|
+
};
|
|
1742
|
+
this.happoConfig.targets[target.name] = constructedTarget;
|
|
1743
|
+
}
|
|
1744
|
+
result.push(target.name);
|
|
1720
1745
|
}
|
|
1721
1746
|
return result;
|
|
1722
1747
|
}
|
|
@@ -1873,9 +1898,14 @@ var test = base.extend({
|
|
|
1873
1898
|
{ scope: "worker", auto: true }
|
|
1874
1899
|
],
|
|
1875
1900
|
_happoForEachTest: [
|
|
1876
|
-
async ({}, use) => {
|
|
1901
|
+
async ({}, use, testInfo) => {
|
|
1877
1902
|
specCounter++;
|
|
1903
|
+
const start = Date.now();
|
|
1878
1904
|
await use();
|
|
1905
|
+
const end = Date.now();
|
|
1906
|
+
if (testInfo.status !== testInfo.expectedStatus) {
|
|
1907
|
+
controller.removeSnapshotsMadeBetween({ start, end });
|
|
1908
|
+
}
|
|
1879
1909
|
if (specCounter % BATCH_SIZE === 0) {
|
|
1880
1910
|
await controller.finish();
|
|
1881
1911
|
await controller.init();
|
|
@@ -1948,6 +1978,7 @@ var test = base.extend({
|
|
|
1948
1978
|
);
|
|
1949
1979
|
await controller.registerSnapshot({
|
|
1950
1980
|
...snapshot,
|
|
1981
|
+
timestamp: Date.now(),
|
|
1951
1982
|
component,
|
|
1952
1983
|
variant,
|
|
1953
1984
|
...rest
|