@storybook/addon-vitest 0.0.0-pr-32717-sha-8803ec2c → 0.0.0-pr-32859-sha-0ff3fd82
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/_node-chunks/chunk-5QWKJDTA.js +2574 -0
- package/dist/_node-chunks/{chunk-J3TMKAGQ.js → chunk-6M6GHGXN.js} +18 -6
- package/dist/_node-chunks/{chunk-RC52X23D.js → chunk-BNGDH3FQ.js} +7 -7
- package/dist/_node-chunks/{chunk-WODMNDRC.js → chunk-GIBMIESY.js} +6 -6
- package/dist/_node-chunks/chunk-KMLD65EU.js +98 -0
- package/dist/_node-chunks/{chunk-HTINZ3Y3.js → chunk-OAIA5C7K.js} +7 -7
- package/dist/_node-chunks/chunk-QNH3623B.js +37 -0
- package/dist/_node-chunks/{chunk-UGJMNNQB.js → chunk-YKP4ELDV.js} +7 -7
- package/dist/manager.js +1 -1
- package/dist/node/coverage-reporter.js +8 -8
- package/dist/node/vitest.js +14 -25
- package/dist/postinstall.js +449 -199
- package/dist/preset.js +15 -2239
- package/dist/vitest-plugin/global-setup.js +7 -7
- package/dist/vitest-plugin/index.js +9 -9
- package/dist/vitest-plugin/setup-file.js +1 -1
- package/package.json +4 -2
- package/dist/_node-chunks/chunk-NXAZJQMW.js +0 -40
- package/dist/_node-chunks/chunk-X5TW6UQ6.js +0 -348
- package/dist/_node-chunks/chunk-ZUDGK5GP.js +0 -60
- /package/dist/_browser-chunks/{chunk-RPDOPHZX.js → chunk-CAYLRBRX.js} +0 -0
package/dist/postinstall.js
CHANGED
|
@@ -1,29 +1,33 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
1
|
+
import CJS_COMPAT_NODE_URL_svf4gveizge from 'node:url';
|
|
2
|
+
import CJS_COMPAT_NODE_PATH_svf4gveizge from 'node:path';
|
|
3
|
+
import CJS_COMPAT_NODE_MODULE_svf4gveizge from "node:module";
|
|
4
4
|
|
|
5
|
-
var __filename =
|
|
6
|
-
var __dirname =
|
|
7
|
-
var require =
|
|
5
|
+
var __filename = CJS_COMPAT_NODE_URL_svf4gveizge.fileURLToPath(import.meta.url);
|
|
6
|
+
var __dirname = CJS_COMPAT_NODE_PATH_svf4gveizge.dirname(__filename);
|
|
7
|
+
var require = CJS_COMPAT_NODE_MODULE_svf4gveizge.createRequire(import.meta.url);
|
|
8
8
|
|
|
9
9
|
// ------------------------------------------------------------
|
|
10
10
|
// end of CJS compatibility banner, injected by Storybook's esbuild configuration
|
|
11
11
|
// ------------------------------------------------------------
|
|
12
12
|
import {
|
|
13
|
+
execa,
|
|
13
14
|
resolvePackageDir
|
|
14
|
-
} from "./_node-chunks/chunk-
|
|
15
|
+
} from "./_node-chunks/chunk-5QWKJDTA.js";
|
|
15
16
|
import {
|
|
16
|
-
any
|
|
17
|
-
|
|
17
|
+
any,
|
|
18
|
+
getAddonNames,
|
|
19
|
+
up
|
|
20
|
+
} from "./_node-chunks/chunk-KMLD65EU.js";
|
|
18
21
|
import {
|
|
19
|
-
DOCUMENTATION_LINK
|
|
20
|
-
|
|
22
|
+
DOCUMENTATION_LINK,
|
|
23
|
+
SUPPORTED_FRAMEWORKS
|
|
24
|
+
} from "./_node-chunks/chunk-6M6GHGXN.js";
|
|
21
25
|
import {
|
|
22
26
|
dirname,
|
|
23
27
|
join,
|
|
24
28
|
relative,
|
|
25
29
|
resolve
|
|
26
|
-
} from "./_node-chunks/chunk-
|
|
30
|
+
} from "./_node-chunks/chunk-OAIA5C7K.js";
|
|
27
31
|
import {
|
|
28
32
|
require_compare,
|
|
29
33
|
require_constants,
|
|
@@ -33,12 +37,12 @@ import {
|
|
|
33
37
|
require_parse_options,
|
|
34
38
|
require_re,
|
|
35
39
|
require_semver
|
|
36
|
-
} from "./_node-chunks/chunk-
|
|
40
|
+
} from "./_node-chunks/chunk-BNGDH3FQ.js";
|
|
37
41
|
import {
|
|
38
42
|
__commonJS,
|
|
39
43
|
__name,
|
|
40
44
|
__toESM
|
|
41
|
-
} from "./_node-chunks/chunk-
|
|
45
|
+
} from "./_node-chunks/chunk-GIBMIESY.js";
|
|
42
46
|
|
|
43
47
|
// ../../node_modules/semver/functions/parse.js
|
|
44
48
|
var require_parse = __commonJS({
|
|
@@ -360,7 +364,7 @@ var require_coerce = __commonJS({
|
|
|
360
364
|
var SemVer = require_semver();
|
|
361
365
|
var parse = require_parse();
|
|
362
366
|
var { safeRe: re, t } = require_re();
|
|
363
|
-
var
|
|
367
|
+
var coerce2 = /* @__PURE__ */ __name((version, options) => {
|
|
364
368
|
if (version instanceof SemVer) {
|
|
365
369
|
return version;
|
|
366
370
|
}
|
|
@@ -395,7 +399,7 @@ var require_coerce = __commonJS({
|
|
|
395
399
|
const build = options.includePrerelease && match[6] ? `+${match[6]}` : "";
|
|
396
400
|
return parse(`${major}.${minor}.${patch}${prerelease}${build}`, options);
|
|
397
401
|
}, "coerce");
|
|
398
|
-
module.exports =
|
|
402
|
+
module.exports = coerce2;
|
|
399
403
|
}
|
|
400
404
|
});
|
|
401
405
|
|
|
@@ -968,7 +972,7 @@ var require_max_satisfying = __commonJS({
|
|
|
968
972
|
"use strict";
|
|
969
973
|
var SemVer = require_semver();
|
|
970
974
|
var Range = require_range();
|
|
971
|
-
var maxSatisfying = /* @__PURE__ */ __name((
|
|
975
|
+
var maxSatisfying = /* @__PURE__ */ __name((versions, range, options) => {
|
|
972
976
|
let max = null;
|
|
973
977
|
let maxSV = null;
|
|
974
978
|
let rangeObj = null;
|
|
@@ -977,7 +981,7 @@ var require_max_satisfying = __commonJS({
|
|
|
977
981
|
} catch (er) {
|
|
978
982
|
return null;
|
|
979
983
|
}
|
|
980
|
-
|
|
984
|
+
versions.forEach((v) => {
|
|
981
985
|
if (rangeObj.test(v)) {
|
|
982
986
|
if (!max || maxSV.compare(v) === -1) {
|
|
983
987
|
max = v;
|
|
@@ -997,7 +1001,7 @@ var require_min_satisfying = __commonJS({
|
|
|
997
1001
|
"use strict";
|
|
998
1002
|
var SemVer = require_semver();
|
|
999
1003
|
var Range = require_range();
|
|
1000
|
-
var minSatisfying = /* @__PURE__ */ __name((
|
|
1004
|
+
var minSatisfying = /* @__PURE__ */ __name((versions, range, options) => {
|
|
1001
1005
|
let min = null;
|
|
1002
1006
|
let minSV = null;
|
|
1003
1007
|
let rangeObj = null;
|
|
@@ -1006,7 +1010,7 @@ var require_min_satisfying = __commonJS({
|
|
|
1006
1010
|
} catch (er) {
|
|
1007
1011
|
return null;
|
|
1008
1012
|
}
|
|
1009
|
-
|
|
1013
|
+
versions.forEach((v) => {
|
|
1010
1014
|
if (rangeObj.test(v)) {
|
|
1011
1015
|
if (!min || minSV.compare(v) === 1) {
|
|
1012
1016
|
min = v;
|
|
@@ -1204,11 +1208,11 @@ var require_simplify = __commonJS({
|
|
|
1204
1208
|
"use strict";
|
|
1205
1209
|
var satisfies2 = require_satisfies();
|
|
1206
1210
|
var compare = require_compare();
|
|
1207
|
-
module.exports = (
|
|
1211
|
+
module.exports = (versions, range, options) => {
|
|
1208
1212
|
const set = [];
|
|
1209
1213
|
let first = null;
|
|
1210
1214
|
let prev = null;
|
|
1211
|
-
const v =
|
|
1215
|
+
const v = versions.sort((a, b) => compare(a, b, options));
|
|
1212
1216
|
for (const version of v) {
|
|
1213
1217
|
const included = satisfies2(version, range, options);
|
|
1214
1218
|
if (included) {
|
|
@@ -1440,7 +1444,7 @@ var require_semver2 = __commonJS({
|
|
|
1440
1444
|
var gte = require_gte();
|
|
1441
1445
|
var lte = require_lte();
|
|
1442
1446
|
var cmp = require_cmp();
|
|
1443
|
-
var
|
|
1447
|
+
var coerce2 = require_coerce();
|
|
1444
1448
|
var Comparator = require_comparator();
|
|
1445
1449
|
var Range = require_range();
|
|
1446
1450
|
var satisfies2 = require_satisfies();
|
|
@@ -1478,7 +1482,7 @@ var require_semver2 = __commonJS({
|
|
|
1478
1482
|
gte,
|
|
1479
1483
|
lte,
|
|
1480
1484
|
cmp,
|
|
1481
|
-
coerce,
|
|
1485
|
+
coerce: coerce2,
|
|
1482
1486
|
Comparator,
|
|
1483
1487
|
Range,
|
|
1484
1488
|
satisfies: satisfies2,
|
|
@@ -1509,24 +1513,56 @@ var require_semver2 = __commonJS({
|
|
|
1509
1513
|
import { existsSync } from "node:fs";
|
|
1510
1514
|
import * as fs2 from "node:fs/promises";
|
|
1511
1515
|
import { writeFile } from "node:fs/promises";
|
|
1512
|
-
import {
|
|
1513
|
-
import {
|
|
1516
|
+
import { isAbsolute, posix, sep } from "node:path";
|
|
1517
|
+
import { fileURLToPath, pathToFileURL } from "node:url";
|
|
1518
|
+
import { babelParse, generate, traverse } from "storybook/internal/babel";
|
|
1514
1519
|
import {
|
|
1515
1520
|
JsPackageManagerFactory,
|
|
1516
1521
|
formatFileContent,
|
|
1522
|
+
getInterpretedFile,
|
|
1517
1523
|
getProjectRoot,
|
|
1518
|
-
|
|
1519
|
-
|
|
1524
|
+
isCI as isCI2,
|
|
1525
|
+
loadMainConfig,
|
|
1526
|
+
scanAndTransformFiles,
|
|
1527
|
+
transformImportFiles
|
|
1520
1528
|
} from "storybook/internal/common";
|
|
1521
|
-
import {
|
|
1522
|
-
import {
|
|
1523
|
-
|
|
1524
|
-
|
|
1525
|
-
|
|
1526
|
-
|
|
1529
|
+
import { experimental_loadStorybook } from "storybook/internal/core-server";
|
|
1530
|
+
import { readConfig, writeConfig } from "storybook/internal/csf-tools";
|
|
1531
|
+
import { logger as logger2 } from "storybook/internal/node-logger";
|
|
1532
|
+
|
|
1533
|
+
// ../../node_modules/empathic/package.mjs
|
|
1534
|
+
function up2(options) {
|
|
1535
|
+
return up("package.json", options);
|
|
1536
|
+
}
|
|
1537
|
+
__name(up2, "up");
|
|
1538
|
+
|
|
1539
|
+
// src/postinstall.ts
|
|
1527
1540
|
var import_semver = __toESM(require_semver2(), 1);
|
|
1541
|
+
import prompts from "prompts";
|
|
1528
1542
|
import { dedent } from "ts-dedent";
|
|
1529
1543
|
|
|
1544
|
+
// src/postinstall-logger.ts
|
|
1545
|
+
import { isCI } from "storybook/internal/common";
|
|
1546
|
+
import { colors, logger } from "storybook/internal/node-logger";
|
|
1547
|
+
var fancy = process.platform !== "win32" || isCI() || process.env.TERM === "xterm-256color";
|
|
1548
|
+
var step = colors.gray("\u203A");
|
|
1549
|
+
var info = colors.blue(fancy ? "\u2139" : "i");
|
|
1550
|
+
var success = colors.green(fancy ? "\u2714" : "\u221A");
|
|
1551
|
+
var warning = colors.orange(fancy ? "\u26A0" : "\u203C");
|
|
1552
|
+
var error = colors.red(fancy ? "\u2716" : "\xD7");
|
|
1553
|
+
var baseOptions = {
|
|
1554
|
+
borderStyle: "round",
|
|
1555
|
+
padding: 1
|
|
1556
|
+
};
|
|
1557
|
+
var print = /* @__PURE__ */ __name((message, options) => {
|
|
1558
|
+
logger.line(1);
|
|
1559
|
+
logger.logBox(message, { ...baseOptions, ...options });
|
|
1560
|
+
}, "print");
|
|
1561
|
+
var printInfo = /* @__PURE__ */ __name((title, message, options) => print(message, { borderColor: "blue", title, ...options }), "printInfo");
|
|
1562
|
+
var printWarning = /* @__PURE__ */ __name((title, message, options) => print(message, { borderColor: "yellow", title, ...options }), "printWarning");
|
|
1563
|
+
var printError = /* @__PURE__ */ __name((title, message, options) => print(message, { borderColor: "red", title, ...options }), "printError");
|
|
1564
|
+
var printSuccess = /* @__PURE__ */ __name((title, message, options) => print(message, { borderColor: "green", title, ...options }), "printSuccess");
|
|
1565
|
+
|
|
1530
1566
|
// src/updateVitestFile.ts
|
|
1531
1567
|
import * as fs from "node:fs/promises";
|
|
1532
1568
|
var loadTemplate = /* @__PURE__ */ __name(async (name, replacements) => {
|
|
@@ -1580,10 +1616,7 @@ var updateConfigFile = /* @__PURE__ */ __name((source, target) => {
|
|
|
1580
1616
|
} else if (targetExportDefault.declaration.type === "CallExpression" && targetExportDefault.declaration.callee.type === "Identifier" && targetExportDefault.declaration.callee.name === "defineConfig" && targetExportDefault.declaration.arguments[0]?.type === "ObjectExpression") {
|
|
1581
1617
|
canHandleConfig = true;
|
|
1582
1618
|
} else if (targetExportDefault.declaration.type === "CallExpression" && targetExportDefault.declaration.callee.type === "Identifier" && targetExportDefault.declaration.callee.name === "mergeConfig" && targetExportDefault.declaration.arguments.length >= 2) {
|
|
1583
|
-
|
|
1584
|
-
(arg) => arg?.type === "CallExpression" && arg.callee.type === "Identifier" && arg.callee.name === "defineConfig" && arg.arguments[0]?.type === "ObjectExpression"
|
|
1585
|
-
);
|
|
1586
|
-
canHandleConfig = defineConfigNodes.length > 0;
|
|
1619
|
+
canHandleConfig = true;
|
|
1587
1620
|
}
|
|
1588
1621
|
if (!canHandleConfig) {
|
|
1589
1622
|
return false;
|
|
@@ -1616,20 +1649,24 @@ var updateConfigFile = /* @__PURE__ */ __name((source, target) => {
|
|
|
1616
1649
|
mergeProperties(properties, exportDefault.declaration.arguments[0].properties);
|
|
1617
1650
|
updated = true;
|
|
1618
1651
|
} else if (exportDefault.declaration.type === "CallExpression" && exportDefault.declaration.callee.type === "Identifier" && exportDefault.declaration.callee.name === "mergeConfig" && exportDefault.declaration.arguments.length >= 2) {
|
|
1619
|
-
const
|
|
1620
|
-
|
|
1621
|
-
|
|
1622
|
-
|
|
1623
|
-
|
|
1652
|
+
const configObjectNodes = [];
|
|
1653
|
+
for (const arg of exportDefault.declaration.arguments) {
|
|
1654
|
+
if (arg?.type === "CallExpression" && arg.callee.type === "Identifier" && arg.callee.name === "defineConfig" && arg.arguments[0]?.type === "ObjectExpression") {
|
|
1655
|
+
configObjectNodes.push(arg.arguments[0]);
|
|
1656
|
+
} else if (arg?.type === "ObjectExpression") {
|
|
1657
|
+
configObjectNodes.push(arg);
|
|
1658
|
+
}
|
|
1659
|
+
}
|
|
1660
|
+
const configObjectWithTest = configObjectNodes.find(
|
|
1661
|
+
(obj) => obj.properties.some(
|
|
1624
1662
|
(p) => p.type === "ObjectProperty" && p.key.type === "Identifier" && p.key.name === "test"
|
|
1625
1663
|
)
|
|
1626
1664
|
);
|
|
1627
|
-
const
|
|
1628
|
-
if (!
|
|
1665
|
+
const targetConfigObject = configObjectWithTest || configObjectNodes[0];
|
|
1666
|
+
if (!targetConfigObject) {
|
|
1629
1667
|
return false;
|
|
1630
1668
|
}
|
|
1631
|
-
const
|
|
1632
|
-
const existingTestProp = defineConfigProps.properties.find(
|
|
1669
|
+
const existingTestProp = targetConfigObject.properties.find(
|
|
1633
1670
|
(p) => p.type === "ObjectProperty" && p.key.type === "Identifier" && p.key.name === "test"
|
|
1634
1671
|
);
|
|
1635
1672
|
if (existingTestProp && existingTestProp.value.type === "ObjectExpression") {
|
|
@@ -1641,6 +1678,16 @@ var updateConfigFile = /* @__PURE__ */ __name((source, target) => {
|
|
|
1641
1678
|
(p) => p.type === "ObjectProperty" && p.key.type === "Identifier" && (p.key.name === "workspace" || p.key.name === "projects")
|
|
1642
1679
|
);
|
|
1643
1680
|
if (workspaceOrProjectsProp && workspaceOrProjectsProp.value.type === "ArrayExpression") {
|
|
1681
|
+
const coverageProp = existingTestProp.value.properties.find(
|
|
1682
|
+
(p) => p.type === "ObjectProperty" && p.key.type === "Identifier" && p.key.name === "coverage"
|
|
1683
|
+
);
|
|
1684
|
+
const testPropsWithoutCoverage = existingTestProp.value.properties.filter(
|
|
1685
|
+
(p) => p !== coverageProp
|
|
1686
|
+
);
|
|
1687
|
+
const testConfigForProject = {
|
|
1688
|
+
type: "ObjectExpression",
|
|
1689
|
+
properties: testPropsWithoutCoverage
|
|
1690
|
+
};
|
|
1644
1691
|
const existingTestProject = {
|
|
1645
1692
|
type: "ObjectExpression",
|
|
1646
1693
|
properties: [
|
|
@@ -1654,25 +1701,28 @@ var updateConfigFile = /* @__PURE__ */ __name((source, target) => {
|
|
|
1654
1701
|
{
|
|
1655
1702
|
type: "ObjectProperty",
|
|
1656
1703
|
key: { type: "Identifier", name: "test" },
|
|
1657
|
-
value:
|
|
1704
|
+
value: testConfigForProject,
|
|
1658
1705
|
computed: false,
|
|
1659
1706
|
shorthand: false
|
|
1660
1707
|
}
|
|
1661
1708
|
]
|
|
1662
1709
|
};
|
|
1663
1710
|
workspaceOrProjectsProp.value.elements.unshift(existingTestProject);
|
|
1664
|
-
|
|
1711
|
+
targetConfigObject.properties = targetConfigObject.properties.filter(
|
|
1665
1712
|
(p) => p !== existingTestProp
|
|
1666
1713
|
);
|
|
1667
|
-
|
|
1714
|
+
if (coverageProp && templateTestProp.value.type === "ObjectExpression") {
|
|
1715
|
+
templateTestProp.value.properties.unshift(coverageProp);
|
|
1716
|
+
}
|
|
1717
|
+
mergeProperties(properties, targetConfigObject.properties);
|
|
1668
1718
|
} else {
|
|
1669
|
-
mergeProperties(properties,
|
|
1719
|
+
mergeProperties(properties, targetConfigObject.properties);
|
|
1670
1720
|
}
|
|
1671
1721
|
} else {
|
|
1672
|
-
mergeProperties(properties,
|
|
1722
|
+
mergeProperties(properties, targetConfigObject.properties);
|
|
1673
1723
|
}
|
|
1674
1724
|
} else {
|
|
1675
|
-
mergeProperties(properties,
|
|
1725
|
+
mergeProperties(properties, targetConfigObject.properties);
|
|
1676
1726
|
}
|
|
1677
1727
|
updated = true;
|
|
1678
1728
|
}
|
|
@@ -1721,126 +1771,274 @@ var updateWorkspaceFile = /* @__PURE__ */ __name((source, target) => {
|
|
|
1721
1771
|
var ADDON_NAME = "@storybook/addon-vitest";
|
|
1722
1772
|
var EXTENSIONS = [".ts", ".tsx", ".js", ".jsx", ".cts", ".mts", ".cjs", ".mjs"];
|
|
1723
1773
|
var addonA11yName = "@storybook/addon-a11y";
|
|
1774
|
+
var hasErrors = false;
|
|
1775
|
+
function nameMatches(name, pattern) {
|
|
1776
|
+
if (name === pattern) {
|
|
1777
|
+
return true;
|
|
1778
|
+
}
|
|
1779
|
+
if (name.includes(`${pattern}${sep}`)) {
|
|
1780
|
+
return true;
|
|
1781
|
+
}
|
|
1782
|
+
if (name.includes(`${pattern}${posix.sep}`)) {
|
|
1783
|
+
return true;
|
|
1784
|
+
}
|
|
1785
|
+
return false;
|
|
1786
|
+
}
|
|
1787
|
+
__name(nameMatches, "nameMatches");
|
|
1788
|
+
var logErrors = /* @__PURE__ */ __name((...args) => {
|
|
1789
|
+
hasErrors = true;
|
|
1790
|
+
printError(...args);
|
|
1791
|
+
}, "logErrors");
|
|
1792
|
+
var findFile = /* @__PURE__ */ __name((basename, extensions = EXTENSIONS) => any(
|
|
1793
|
+
extensions.map((ext) => basename + ext),
|
|
1794
|
+
{ last: getProjectRoot() }
|
|
1795
|
+
), "findFile");
|
|
1724
1796
|
async function postInstall(options) {
|
|
1725
|
-
|
|
1726
|
-
|
|
1797
|
+
printSuccess(
|
|
1798
|
+
"\u{1F44B} Howdy!",
|
|
1799
|
+
dedent`
|
|
1800
|
+
I'm the installation helper for ${ADDON_NAME}
|
|
1801
|
+
|
|
1802
|
+
Hold on for a moment while I look at your project and get it set up...
|
|
1803
|
+
`
|
|
1804
|
+
);
|
|
1727
1805
|
const packageManager = JsPackageManagerFactory.getPackageManager({
|
|
1728
1806
|
force: options.packageManager
|
|
1729
1807
|
});
|
|
1730
|
-
const findFile = /* @__PURE__ */ __name((basename, extensions = EXTENSIONS) => any(
|
|
1731
|
-
extensions.map((ext) => basename + ext),
|
|
1732
|
-
{ last: getProjectRoot(), cwd: options.configDir }
|
|
1733
|
-
), "findFile");
|
|
1734
1808
|
const vitestVersionSpecifier = await packageManager.getInstalledVersion("vitest");
|
|
1809
|
+
const coercedVitestVersion = vitestVersionSpecifier ? (0, import_semver.coerce)(vitestVersionSpecifier) : null;
|
|
1735
1810
|
const isVitest3_2To4 = vitestVersionSpecifier ? (0, import_semver.satisfies)(vitestVersionSpecifier, ">=3.2.0 <4.0.0") : false;
|
|
1736
1811
|
const isVitest4OrNewer = vitestVersionSpecifier ? (0, import_semver.satisfies)(vitestVersionSpecifier, ">=4.0.0") : true;
|
|
1737
|
-
const
|
|
1812
|
+
const info2 = await getStorybookInfo(options);
|
|
1738
1813
|
const allDeps = packageManager.getAllDependencies();
|
|
1739
|
-
const
|
|
1740
|
-
|
|
1741
|
-
|
|
1742
|
-
|
|
1743
|
-
|
|
1744
|
-
|
|
1745
|
-
|
|
1746
|
-
|
|
1747
|
-
|
|
1748
|
-
|
|
1749
|
-
|
|
1750
|
-
|
|
1751
|
-
|
|
1752
|
-
|
|
1753
|
-
dedent`
|
|
1754
|
-
|
|
1755
|
-
|
|
1814
|
+
const dependencies = [
|
|
1815
|
+
"vitest",
|
|
1816
|
+
"playwright",
|
|
1817
|
+
isVitest4OrNewer ? "@vitest/browser-playwright" : "@vitest/browser"
|
|
1818
|
+
];
|
|
1819
|
+
const uniqueDependencies = dependencies.filter((p) => !allDeps[p]);
|
|
1820
|
+
const mainJsPath = getInterpretedFile(resolve(options.configDir, "main"));
|
|
1821
|
+
const config = await readConfig(mainJsPath);
|
|
1822
|
+
const hasCustomWebpackConfig = !!config.getFieldNode(["webpackFinal"]);
|
|
1823
|
+
const isInteractive = process.stdout.isTTY && !isCI2();
|
|
1824
|
+
if (nameMatches(info2.frameworkPackageName, "@storybook/nextjs") && !hasCustomWebpackConfig) {
|
|
1825
|
+
const out = options.yes || !isInteractive ? { migrateToNextjsVite: !!options.yes } : await prompts({
|
|
1826
|
+
type: "confirm",
|
|
1827
|
+
name: "migrateToNextjsVite",
|
|
1828
|
+
message: dedent`
|
|
1829
|
+
The addon requires the use of @storybook/nextjs-vite to work with Next.js.
|
|
1830
|
+
https://storybook.js.org/docs/next/${DOCUMENTATION_LINK}#install-and-set-up
|
|
1756
1831
|
|
|
1757
|
-
|
|
1758
|
-
|
|
1759
|
-
|
|
1760
|
-
);
|
|
1761
|
-
result = reasons.map((r) => r.trim()).join("\n\n");
|
|
1762
|
-
}
|
|
1763
|
-
if (result) {
|
|
1764
|
-
logger.error(result);
|
|
1765
|
-
throw new AddonVitestPostinstallPrerequisiteCheckError({
|
|
1766
|
-
reasons: compatibilityResult.reasons
|
|
1832
|
+
Do you want to migrate?
|
|
1833
|
+
`,
|
|
1834
|
+
initial: true
|
|
1767
1835
|
});
|
|
1836
|
+
if (out.migrateToNextjsVite) {
|
|
1837
|
+
await packageManager.addDependencies({ type: "devDependencies", skipInstall: true }, [
|
|
1838
|
+
"@storybook/nextjs-vite"
|
|
1839
|
+
]);
|
|
1840
|
+
await packageManager.removeDependencies(["@storybook/nextjs"]);
|
|
1841
|
+
traverse(config._ast, {
|
|
1842
|
+
StringLiteral(path) {
|
|
1843
|
+
if (path.node.value === "@storybook/nextjs") {
|
|
1844
|
+
path.node.value = "@storybook/nextjs-vite";
|
|
1845
|
+
}
|
|
1846
|
+
}
|
|
1847
|
+
});
|
|
1848
|
+
await writeConfig(config, mainJsPath);
|
|
1849
|
+
info2.frameworkPackageName = "@storybook/nextjs-vite";
|
|
1850
|
+
info2.builderPackageName = "@storybook/builder-vite";
|
|
1851
|
+
await scanAndTransformFiles({
|
|
1852
|
+
promptMessage: "Enter a glob to scan for all @storybook/nextjs imports to substitute with @storybook/nextjs-vite:",
|
|
1853
|
+
force: options.yes,
|
|
1854
|
+
dryRun: false,
|
|
1855
|
+
transformFn: /* @__PURE__ */ __name((files, options2, dryRun) => transformImportFiles(files, options2, dryRun), "transformFn"),
|
|
1856
|
+
transformOptions: {
|
|
1857
|
+
"@storybook/nextjs": "@storybook/nextjs-vite"
|
|
1858
|
+
}
|
|
1859
|
+
});
|
|
1860
|
+
}
|
|
1768
1861
|
}
|
|
1769
|
-
|
|
1770
|
-
|
|
1771
|
-
|
|
1772
|
-
|
|
1773
|
-
|
|
1862
|
+
const annotationsImport = SUPPORTED_FRAMEWORKS.find(
|
|
1863
|
+
(f) => nameMatches(info2.frameworkPackageName, f)
|
|
1864
|
+
) ? info2.frameworkPackageName === "@storybook/nextjs" ? "@storybook/nextjs-vite" : info2.frameworkPackageName : null;
|
|
1865
|
+
const isRendererSupported = !!annotationsImport;
|
|
1866
|
+
const prerequisiteCheck = /* @__PURE__ */ __name(async () => {
|
|
1867
|
+
const reasons = [];
|
|
1868
|
+
if (hasCustomWebpackConfig) {
|
|
1869
|
+
reasons.push("\u2022 The addon can not be used with a custom Webpack configuration.");
|
|
1870
|
+
}
|
|
1871
|
+
if (!nameMatches(info2.frameworkPackageName, "@storybook/nextjs") && !nameMatches(info2.builderPackageName, "@storybook/builder-vite")) {
|
|
1872
|
+
reasons.push(
|
|
1873
|
+
"\u2022 The addon can only be used with a Vite-based Storybook framework or Next.js."
|
|
1874
|
+
);
|
|
1875
|
+
}
|
|
1876
|
+
if (!isRendererSupported) {
|
|
1877
|
+
reasons.push(dedent`
|
|
1878
|
+
• The addon cannot yet be used with ${info2.frameworkPackageName}
|
|
1879
|
+
`);
|
|
1880
|
+
}
|
|
1881
|
+
if (coercedVitestVersion && !(0, import_semver.satisfies)(coercedVitestVersion, ">=3.0.0")) {
|
|
1882
|
+
reasons.push(dedent`
|
|
1883
|
+
• The addon requires Vitest 3.0.0 or higher. You are currently using ${vitestVersionSpecifier}.
|
|
1884
|
+
Please update all of your Vitest dependencies and try again.
|
|
1885
|
+
`);
|
|
1886
|
+
}
|
|
1887
|
+
const mswVersionSpecifier = await packageManager.getInstalledVersion("msw");
|
|
1888
|
+
const coercedMswVersion = mswVersionSpecifier ? (0, import_semver.coerce)(mswVersionSpecifier) : null;
|
|
1889
|
+
if (coercedMswVersion && !(0, import_semver.satisfies)(coercedMswVersion, ">=2.0.0")) {
|
|
1890
|
+
reasons.push(dedent`
|
|
1891
|
+
• The addon uses Vitest behind the scenes, which supports only version 2 and above of MSW. However, we have detected version ${coercedMswVersion.version} in this project.
|
|
1892
|
+
Please update the 'msw' package and try again.
|
|
1893
|
+
`);
|
|
1894
|
+
}
|
|
1895
|
+
if (nameMatches(info2.frameworkPackageName, "@storybook/nextjs")) {
|
|
1896
|
+
const nextVersion = await packageManager.getInstalledVersion("next");
|
|
1897
|
+
if (!nextVersion) {
|
|
1898
|
+
reasons.push(dedent`
|
|
1899
|
+
• You are using @storybook/nextjs without having "next" installed.
|
|
1900
|
+
Please install "next" or use a different Storybook framework integration and try again.
|
|
1901
|
+
`);
|
|
1774
1902
|
}
|
|
1775
1903
|
}
|
|
1776
|
-
|
|
1777
|
-
|
|
1778
|
-
|
|
1779
|
-
|
|
1904
|
+
if (reasons.length > 0) {
|
|
1905
|
+
reasons.unshift(
|
|
1906
|
+
`@storybook/addon-vitest's automated setup failed due to the following package incompatibilities:`
|
|
1907
|
+
);
|
|
1908
|
+
reasons.push("--------------------------------");
|
|
1909
|
+
reasons.push(
|
|
1780
1910
|
dedent`
|
|
1781
|
-
You
|
|
1782
|
-
|
|
1783
|
-
Adding "@vitest/coverage-v8" to enable coverage reporting.
|
|
1784
|
-
Read more about Vitest coverage providers at https://vitest.dev/guide/coverage.html#coverage-providers
|
|
1911
|
+
You can fix these issues and rerun the command to reinstall. If you wish to roll back the installation, remove ${ADDON_NAME} from the "addons" array
|
|
1912
|
+
in your main Storybook config file and remove the dependency from your package.json file.
|
|
1785
1913
|
`
|
|
1786
1914
|
);
|
|
1915
|
+
if (!isRendererSupported) {
|
|
1916
|
+
reasons.push(
|
|
1917
|
+
dedent`
|
|
1918
|
+
Please check the documentation for more information about its requirements and installation:
|
|
1919
|
+
https://storybook.js.org/docs/next/${DOCUMENTATION_LINK}
|
|
1920
|
+
`
|
|
1921
|
+
);
|
|
1922
|
+
} else {
|
|
1923
|
+
reasons.push(
|
|
1924
|
+
dedent`
|
|
1925
|
+
Fear not, however, you can follow the manual installation process instead at:
|
|
1926
|
+
https://storybook.js.org/docs/next/${DOCUMENTATION_LINK}#manual-setup
|
|
1927
|
+
`
|
|
1928
|
+
);
|
|
1929
|
+
}
|
|
1930
|
+
return reasons.map((r) => r.trim()).join("\n\n");
|
|
1787
1931
|
}
|
|
1788
|
-
|
|
1789
|
-
|
|
1790
|
-
|
|
1791
|
-
|
|
1792
|
-
|
|
1793
|
-
|
|
1794
|
-
|
|
1932
|
+
return null;
|
|
1933
|
+
}, "prerequisiteCheck");
|
|
1934
|
+
const result = await prerequisiteCheck();
|
|
1935
|
+
if (result) {
|
|
1936
|
+
logErrors("\u26D4\uFE0F Sorry!", result);
|
|
1937
|
+
logger2.line(1);
|
|
1938
|
+
return;
|
|
1939
|
+
}
|
|
1940
|
+
if (info2.frameworkPackageName === "@storybook/nextjs") {
|
|
1941
|
+
printInfo(
|
|
1942
|
+
"\u{1F37F} Just so you know...",
|
|
1943
|
+
dedent`
|
|
1944
|
+
It looks like you're using Next.js.
|
|
1945
|
+
|
|
1946
|
+
Adding "@storybook/nextjs-vite/vite-plugin" so you can use it with Vitest.
|
|
1947
|
+
|
|
1948
|
+
More info about the plugin at https://github.com/storybookjs/vite-plugin-storybook-nextjs
|
|
1949
|
+
`
|
|
1950
|
+
);
|
|
1951
|
+
try {
|
|
1952
|
+
const storybookVersion = await packageManager.getInstalledVersion("storybook");
|
|
1953
|
+
uniqueDependencies.push(`@storybook/nextjs-vite@^${storybookVersion}`);
|
|
1954
|
+
} catch (e) {
|
|
1955
|
+
console.error("Failed to install @storybook/nextjs-vite. Please install it manually");
|
|
1795
1956
|
}
|
|
1796
|
-
|
|
1797
|
-
|
|
1957
|
+
}
|
|
1958
|
+
const v8Version = await packageManager.getInstalledVersion("@vitest/coverage-v8");
|
|
1959
|
+
const istanbulVersion = await packageManager.getInstalledVersion("@vitest/coverage-istanbul");
|
|
1960
|
+
if (!v8Version && !istanbulVersion) {
|
|
1961
|
+
printInfo(
|
|
1962
|
+
"\u{1F648} Let me cover this for you",
|
|
1963
|
+
dedent`
|
|
1964
|
+
You don't seem to have a coverage reporter installed. Vitest needs either V8 or Istanbul to generate coverage reports.
|
|
1965
|
+
|
|
1966
|
+
Adding "@vitest/coverage-v8" to enable coverage reporting.
|
|
1967
|
+
Read more about Vitest coverage providers at https://vitest.dev/guide/coverage.html#coverage-providers
|
|
1968
|
+
`
|
|
1969
|
+
);
|
|
1970
|
+
uniqueDependencies.push(`@vitest/coverage-v8`);
|
|
1971
|
+
}
|
|
1972
|
+
const versionedDependencies = uniqueDependencies.map((p) => {
|
|
1973
|
+
if (p.includes("vitest")) {
|
|
1974
|
+
return vitestVersionSpecifier ? `${p}@${vitestVersionSpecifier}` : p;
|
|
1798
1975
|
}
|
|
1976
|
+
return p;
|
|
1977
|
+
});
|
|
1978
|
+
if (versionedDependencies.length > 0) {
|
|
1979
|
+
await packageManager.addDependencies(
|
|
1980
|
+
{ type: "devDependencies", skipInstall: true },
|
|
1981
|
+
versionedDependencies
|
|
1982
|
+
);
|
|
1983
|
+
logger2.line(1);
|
|
1984
|
+
logger2.plain(`${step} Installing dependencies:`);
|
|
1985
|
+
logger2.plain(" " + versionedDependencies.join(", "));
|
|
1799
1986
|
}
|
|
1800
|
-
|
|
1801
|
-
|
|
1802
|
-
|
|
1803
|
-
|
|
1804
|
-
|
|
1987
|
+
await packageManager.installDependencies();
|
|
1988
|
+
logger2.line(1);
|
|
1989
|
+
if (options.skipInstall) {
|
|
1990
|
+
logger2.plain("Skipping Playwright installation, please run this command manually:");
|
|
1991
|
+
logger2.plain(" npx playwright install chromium --with-deps");
|
|
1992
|
+
} else {
|
|
1993
|
+
logger2.plain(`${step} Configuring Playwright with Chromium (this might take some time):`);
|
|
1994
|
+
logger2.plain(" npx playwright install chromium --with-deps");
|
|
1995
|
+
try {
|
|
1996
|
+
await packageManager.executeCommand({
|
|
1997
|
+
command: "npx",
|
|
1998
|
+
args: ["playwright", "install", "chromium", "--with-deps"]
|
|
1999
|
+
});
|
|
2000
|
+
} catch (e) {
|
|
2001
|
+
console.error("Failed to install Playwright. Please install it manually");
|
|
2002
|
+
}
|
|
1805
2003
|
}
|
|
1806
2004
|
const fileExtension = allDeps.typescript || findFile("tsconfig", [...EXTENSIONS, ".json"]) ? "ts" : "js";
|
|
1807
2005
|
const vitestSetupFile = resolve(options.configDir, `vitest.setup.${fileExtension}`);
|
|
1808
2006
|
if (existsSync(vitestSetupFile)) {
|
|
1809
|
-
|
|
1810
|
-
|
|
1811
|
-
${vitestSetupFile}
|
|
1812
|
-
Please refer to the documentation to complete the setup manually:
|
|
1813
|
-
https://storybook.js.org/docs/next/${DOCUMENTATION_LINK}#manual-setup
|
|
1814
|
-
`;
|
|
1815
|
-
logger.line();
|
|
1816
|
-
logger.error(`${errorMessage}
|
|
1817
|
-
`);
|
|
1818
|
-
errors.push("Found existing Vitest setup file");
|
|
1819
|
-
} else {
|
|
1820
|
-
logger.step(`Creating a Vitest setup file for Storybook:`);
|
|
1821
|
-
logger.log(`${vitestSetupFile}
|
|
1822
|
-
`);
|
|
1823
|
-
const previewExists = EXTENSIONS.map((ext) => resolve(options.configDir, `preview${ext}`)).some(
|
|
1824
|
-
existsSync
|
|
1825
|
-
);
|
|
1826
|
-
const annotationsImport = info.frameworkPackage;
|
|
1827
|
-
const imports = [`import { setProjectAnnotations } from '${annotationsImport}';`];
|
|
1828
|
-
const projectAnnotations = [];
|
|
1829
|
-
if (previewExists) {
|
|
1830
|
-
imports.push(`import * as projectAnnotations from './preview';`);
|
|
1831
|
-
projectAnnotations.push("projectAnnotations");
|
|
1832
|
-
}
|
|
1833
|
-
await writeFile(
|
|
1834
|
-
vitestSetupFile,
|
|
2007
|
+
logErrors(
|
|
2008
|
+
"\u{1F6A8} Oh no!",
|
|
1835
2009
|
dedent`
|
|
2010
|
+
Found an existing Vitest setup file:
|
|
2011
|
+
${vitestSetupFile}
|
|
2012
|
+
|
|
2013
|
+
Please refer to the documentation to complete the setup manually:
|
|
2014
|
+
https://storybook.js.org/docs/next/${DOCUMENTATION_LINK}#manual-setup
|
|
2015
|
+
`
|
|
2016
|
+
);
|
|
2017
|
+
logger2.line(1);
|
|
2018
|
+
return;
|
|
2019
|
+
}
|
|
2020
|
+
logger2.line(1);
|
|
2021
|
+
logger2.plain(`${step} Creating a Vitest setup file for Storybook:`);
|
|
2022
|
+
logger2.plain(` ${vitestSetupFile}`);
|
|
2023
|
+
const previewExists = EXTENSIONS.map((ext) => resolve(options.configDir, `preview${ext}`)).some(
|
|
2024
|
+
existsSync
|
|
2025
|
+
);
|
|
2026
|
+
const imports = [`import { setProjectAnnotations } from '${annotationsImport}';`];
|
|
2027
|
+
const projectAnnotations = [];
|
|
2028
|
+
if (previewExists) {
|
|
2029
|
+
imports.push(`import * as projectAnnotations from './preview';`);
|
|
2030
|
+
projectAnnotations.push("projectAnnotations");
|
|
2031
|
+
}
|
|
2032
|
+
await writeFile(
|
|
2033
|
+
vitestSetupFile,
|
|
2034
|
+
dedent`
|
|
1836
2035
|
${imports.join("\n")}
|
|
1837
2036
|
|
|
1838
2037
|
// This is an important step to apply the right configuration when testing your stories.
|
|
1839
2038
|
// More info at: https://storybook.js.org/docs/api/portable-stories/portable-stories-vitest#setprojectannotations
|
|
1840
2039
|
setProjectAnnotations([${projectAnnotations.join(", ")}]);
|
|
1841
2040
|
`
|
|
1842
|
-
|
|
1843
|
-
}
|
|
2041
|
+
);
|
|
1844
2042
|
const vitestWorkspaceFile = findFile("vitest.workspace", [".ts", ".js", ".json"]);
|
|
1845
2043
|
const viteConfigFile = findFile("vite.config");
|
|
1846
2044
|
const vitestConfigFile = findFile("vitest.config");
|
|
@@ -1872,12 +2070,14 @@ async function postInstall(options) {
|
|
|
1872
2070
|
const target = babelParse(workspaceFile);
|
|
1873
2071
|
const updated = updateWorkspaceFile(source, target);
|
|
1874
2072
|
if (updated) {
|
|
1875
|
-
|
|
1876
|
-
|
|
2073
|
+
logger2.line(1);
|
|
2074
|
+
logger2.plain(`${step} Updating your Vitest workspace file:`);
|
|
2075
|
+
logger2.plain(` ${vitestWorkspaceFile}`);
|
|
1877
2076
|
const formattedContent = await formatFileContent(vitestWorkspaceFile, generate(target).code);
|
|
1878
2077
|
await writeFile(vitestWorkspaceFile, formattedContent);
|
|
1879
2078
|
} else {
|
|
1880
|
-
|
|
2079
|
+
logErrors(
|
|
2080
|
+
"\u{1F6A8} Oh no!",
|
|
1881
2081
|
dedent`
|
|
1882
2082
|
Could not update existing Vitest workspace file:
|
|
1883
2083
|
${vitestWorkspaceFile}
|
|
@@ -1889,7 +2089,8 @@ async function postInstall(options) {
|
|
|
1889
2089
|
https://storybook.js.org/docs/next/${DOCUMENTATION_LINK}#manual-setup
|
|
1890
2090
|
`
|
|
1891
2091
|
);
|
|
1892
|
-
|
|
2092
|
+
logger2.line(1);
|
|
2093
|
+
return;
|
|
1893
2094
|
}
|
|
1894
2095
|
} else if (rootConfig) {
|
|
1895
2096
|
let target, updated;
|
|
@@ -1908,100 +2109,149 @@ async function postInstall(options) {
|
|
|
1908
2109
|
updated = updateConfigFile(source, target);
|
|
1909
2110
|
}
|
|
1910
2111
|
if (target && updated) {
|
|
1911
|
-
|
|
1912
|
-
|
|
2112
|
+
logger2.line(1);
|
|
2113
|
+
logger2.plain(`${step} Updating your ${vitestConfigFile ? "Vitest" : "Vite"} config file:`);
|
|
2114
|
+
logger2.plain(` ${rootConfig}`);
|
|
1913
2115
|
const formattedContent = await formatFileContent(rootConfig, generate(target).code);
|
|
2116
|
+
const shouldAddReference = !configFileHasTypeReference && !vitestConfigFile;
|
|
1914
2117
|
await writeFile(
|
|
1915
2118
|
rootConfig,
|
|
1916
|
-
|
|
2119
|
+
shouldAddReference ? '/// <reference types="vitest/config" />\n' + formattedContent : formattedContent
|
|
1917
2120
|
);
|
|
1918
2121
|
} else {
|
|
1919
|
-
|
|
2122
|
+
logErrors(
|
|
2123
|
+
"\u{1F6A8} Oh no!",
|
|
2124
|
+
dedent`
|
|
1920
2125
|
We were unable to update your existing ${vitestConfigFile ? "Vitest" : "Vite"} config file.
|
|
1921
2126
|
|
|
1922
2127
|
Please refer to the documentation to complete the setup manually:
|
|
1923
2128
|
https://storybook.js.org/docs/writing-tests/integrations/vitest-addon#manual-setup
|
|
1924
|
-
`
|
|
1925
|
-
|
|
2129
|
+
`
|
|
2130
|
+
);
|
|
1926
2131
|
}
|
|
1927
2132
|
} else {
|
|
1928
|
-
const
|
|
1929
|
-
const newConfigFile = resolve(parentDir, `vitest.config.${fileExtension}`);
|
|
2133
|
+
const newConfigFile = resolve(`vitest.config.${fileExtension}`);
|
|
1930
2134
|
const configTemplate = await loadTemplate(getTemplateName(), {
|
|
1931
2135
|
CONFIG_DIR: options.configDir,
|
|
1932
2136
|
SETUP_FILE: relative(dirname(newConfigFile), vitestSetupFile)
|
|
1933
2137
|
});
|
|
1934
|
-
|
|
1935
|
-
|
|
2138
|
+
logger2.line(1);
|
|
2139
|
+
logger2.plain(`${step} Creating a Vitest config file:`);
|
|
2140
|
+
logger2.plain(` ${newConfigFile}`);
|
|
1936
2141
|
const formattedContent = await formatFileContent(newConfigFile, configTemplate);
|
|
1937
2142
|
await writeFile(newConfigFile, formattedContent);
|
|
1938
2143
|
}
|
|
1939
|
-
const a11yAddon =
|
|
2144
|
+
const a11yAddon = info2.addons.find((addon) => addon.includes(addonA11yName));
|
|
1940
2145
|
if (a11yAddon) {
|
|
1941
2146
|
try {
|
|
1942
|
-
|
|
1943
|
-
|
|
1944
|
-
command.push("--yes", "--skip-doctor");
|
|
1945
|
-
if (options.packageManager) {
|
|
1946
|
-
command.push("--package-manager", options.packageManager);
|
|
1947
|
-
}
|
|
1948
|
-
if (options.skipInstall) {
|
|
1949
|
-
command.push("--skip-install");
|
|
1950
|
-
}
|
|
1951
|
-
if (options.configDir !== ".storybook") {
|
|
1952
|
-
command.push("--config-dir", `"${options.configDir}"`);
|
|
1953
|
-
}
|
|
1954
|
-
const remoteCommand = packageManager.getRemoteRunCommand(
|
|
2147
|
+
logger2.plain(`${step} Setting up ${addonA11yName} for @storybook/addon-vitest:`);
|
|
2148
|
+
await execa(
|
|
1955
2149
|
"storybook",
|
|
1956
|
-
|
|
1957
|
-
|
|
2150
|
+
[
|
|
2151
|
+
"automigrate",
|
|
2152
|
+
"addon-a11y-addon-test",
|
|
2153
|
+
"--loglevel",
|
|
2154
|
+
"silent",
|
|
2155
|
+
"--yes",
|
|
2156
|
+
"--skip-doctor",
|
|
2157
|
+
...options.packageManager ? ["--package-manager", options.packageManager] : [],
|
|
2158
|
+
...options.skipInstall ? ["--skip-install"] : [],
|
|
2159
|
+
...options.configDir !== ".storybook" ? ["--config-dir", `"${options.configDir}"`] : []
|
|
2160
|
+
],
|
|
2161
|
+
{
|
|
2162
|
+
stdio: "inherit"
|
|
2163
|
+
}
|
|
1958
2164
|
);
|
|
1959
|
-
const [cmd, ...args] = remoteCommand.split(" ");
|
|
1960
|
-
await prompt.executeTask(() => packageManager.executeCommand({ command: cmd, args }), {
|
|
1961
|
-
id: "a11y-addon-setup",
|
|
1962
|
-
intro: "Setting up a11y addon for @storybook/addon-vitest",
|
|
1963
|
-
error: "Failed to setup a11y addon for @storybook/addon-vitest",
|
|
1964
|
-
success: "a11y addon setup successfully"
|
|
1965
|
-
});
|
|
1966
2165
|
} catch (e) {
|
|
1967
|
-
|
|
1968
|
-
|
|
1969
|
-
|
|
1970
|
-
|
|
2166
|
+
logErrors(
|
|
2167
|
+
"\u{1F6A8} Oh no!",
|
|
2168
|
+
dedent`
|
|
2169
|
+
We have detected that you have ${addonA11yName} installed but could not automatically set it up for @storybook/addon-vitest:
|
|
2170
|
+
|
|
2171
|
+
${e instanceof Error ? e.message : String(e)}
|
|
2172
|
+
|
|
1971
2173
|
Please refer to the documentation to complete the setup manually:
|
|
1972
2174
|
https://storybook.js.org/docs/writing-tests/accessibility-testing#test-addon-integration
|
|
1973
|
-
`
|
|
1974
|
-
errors.push(
|
|
1975
|
-
"The @storybook/addon-a11y couldn't be set up for the Vitest addon" + (e instanceof Error ? e.stack : String(e))
|
|
2175
|
+
`
|
|
1976
2176
|
);
|
|
1977
2177
|
}
|
|
1978
2178
|
}
|
|
1979
2179
|
const runCommand = rootConfig ? `npx vitest --project=storybook` : `npx vitest`;
|
|
1980
|
-
|
|
1981
|
-
|
|
1982
|
-
|
|
1983
|
-
|
|
2180
|
+
if (!hasErrors) {
|
|
2181
|
+
printSuccess(
|
|
2182
|
+
"\u{1F389} All done!",
|
|
2183
|
+
dedent`
|
|
1984
2184
|
@storybook/addon-vitest is now configured and you're ready to run your tests!
|
|
2185
|
+
|
|
1985
2186
|
Here are a couple of tips to get you started:
|
|
1986
|
-
|
|
1987
|
-
•
|
|
1988
|
-
|
|
1989
|
-
|
|
2187
|
+
• You can run tests with "${runCommand}"
|
|
2188
|
+
• When using the Vitest extension in your editor, all of your stories will be shown as tests!
|
|
2189
|
+
|
|
1990
2190
|
Check the documentation for more information about its features and options at:
|
|
1991
2191
|
https://storybook.js.org/docs/next/${DOCUMENTATION_LINK}
|
|
1992
|
-
`
|
|
2192
|
+
`
|
|
2193
|
+
);
|
|
1993
2194
|
} else {
|
|
1994
|
-
|
|
2195
|
+
printWarning(
|
|
2196
|
+
"\u26A0\uFE0F Done, but with errors!",
|
|
1995
2197
|
dedent`
|
|
1996
|
-
|
|
1997
|
-
|
|
2198
|
+
@storybook/addon-vitest was installed successfully, but there were some errors during the setup process.
|
|
2199
|
+
|
|
2200
|
+
Please refer to the documentation to complete the setup manually and check the errors above:
|
|
1998
2201
|
https://storybook.js.org/docs/next/${DOCUMENTATION_LINK}#manual-setup
|
|
1999
2202
|
`
|
|
2000
2203
|
);
|
|
2001
|
-
throw new AddonVitestPostinstallError({ errors });
|
|
2002
2204
|
}
|
|
2205
|
+
logger2.line(1);
|
|
2003
2206
|
}
|
|
2004
2207
|
__name(postInstall, "postInstall");
|
|
2208
|
+
async function getPackageNameFromPath(input) {
|
|
2209
|
+
const path = input.startsWith("file://") ? fileURLToPath(input) : input;
|
|
2210
|
+
if (!isAbsolute(path)) {
|
|
2211
|
+
return path;
|
|
2212
|
+
}
|
|
2213
|
+
const packageJsonPath = up2({ cwd: path });
|
|
2214
|
+
if (!packageJsonPath) {
|
|
2215
|
+
throw new Error(`Could not find package.json in path: ${path}`);
|
|
2216
|
+
}
|
|
2217
|
+
const { default: packageJson } = await import(pathToFileURL(packageJsonPath).href, {
|
|
2218
|
+
with: { type: "json" }
|
|
2219
|
+
});
|
|
2220
|
+
return packageJson.name;
|
|
2221
|
+
}
|
|
2222
|
+
__name(getPackageNameFromPath, "getPackageNameFromPath");
|
|
2223
|
+
async function getStorybookInfo({ configDir, packageManager: pkgMgr }) {
|
|
2224
|
+
const packageManager = JsPackageManagerFactory.getPackageManager({ force: pkgMgr, configDir });
|
|
2225
|
+
const { packageJson } = packageManager.primaryPackageJson;
|
|
2226
|
+
const config = await loadMainConfig({ configDir });
|
|
2227
|
+
const { presets } = await experimental_loadStorybook({
|
|
2228
|
+
configDir,
|
|
2229
|
+
packageJson
|
|
2230
|
+
});
|
|
2231
|
+
const framework = await presets.apply("framework", {});
|
|
2232
|
+
const core = await presets.apply("core", {});
|
|
2233
|
+
const { builder, renderer } = core;
|
|
2234
|
+
if (!builder) {
|
|
2235
|
+
throw new Error("Could not detect your Storybook builder.");
|
|
2236
|
+
}
|
|
2237
|
+
const frameworkPackageName = await getPackageNameFromPath(
|
|
2238
|
+
typeof framework === "string" ? framework : framework.name
|
|
2239
|
+
);
|
|
2240
|
+
const builderPackageName = await getPackageNameFromPath(
|
|
2241
|
+
typeof builder === "string" ? builder : builder.name
|
|
2242
|
+
);
|
|
2243
|
+
let rendererPackageName;
|
|
2244
|
+
if (renderer) {
|
|
2245
|
+
rendererPackageName = await getPackageNameFromPath(renderer);
|
|
2246
|
+
}
|
|
2247
|
+
return {
|
|
2248
|
+
frameworkPackageName,
|
|
2249
|
+
builderPackageName,
|
|
2250
|
+
rendererPackageName,
|
|
2251
|
+
addons: getAddonNames(config)
|
|
2252
|
+
};
|
|
2253
|
+
}
|
|
2254
|
+
__name(getStorybookInfo, "getStorybookInfo");
|
|
2005
2255
|
export {
|
|
2006
2256
|
postInstall as default
|
|
2007
2257
|
};
|