@sentry/wizard 4.5.0 → 4.7.0
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/CHANGELOG.md +25 -1
- package/README.md +23 -19
- package/dist/bin.js +22 -0
- package/dist/bin.js.map +1 -1
- package/dist/e2e-tests/tests/flutter.test.js +16 -16
- package/dist/e2e-tests/tests/flutter.test.js.map +1 -1
- package/dist/e2e-tests/tests/help-message.test.js +56 -0
- package/dist/e2e-tests/tests/help-message.test.js.map +1 -0
- package/dist/e2e-tests/tests/nextjs-14.test.js +17 -16
- package/dist/e2e-tests/tests/nextjs-14.test.js.map +1 -1
- package/dist/e2e-tests/tests/nextjs-15.test.js +16 -16
- package/dist/e2e-tests/tests/nextjs-15.test.js.map +1 -1
- package/dist/e2e-tests/tests/nuxt-3.test.js +13 -12
- package/dist/e2e-tests/tests/nuxt-3.test.js.map +1 -1
- package/dist/e2e-tests/tests/nuxt-4.test.js +13 -12
- package/dist/e2e-tests/tests/nuxt-4.test.js.map +1 -1
- package/dist/e2e-tests/tests/remix.test.js +20 -20
- package/dist/e2e-tests/tests/remix.test.js.map +1 -1
- package/dist/e2e-tests/tests/sveltekit.test.js +20 -20
- package/dist/e2e-tests/tests/sveltekit.test.js.map +1 -1
- package/dist/e2e-tests/utils/index.d.ts +1 -1
- package/dist/e2e-tests/utils/index.js +35 -13
- package/dist/e2e-tests/utils/index.js.map +1 -1
- package/dist/lib/Constants.d.ts +7 -1
- package/dist/lib/Constants.js.map +1 -1
- package/dist/lib/Helper/File.d.ts +1 -1
- package/dist/lib/Helper/File.js +1 -3
- package/dist/lib/Helper/File.js.map +1 -1
- package/dist/lib/Helper/Logging.d.ts +4 -1
- package/dist/lib/Helper/Logging.js +3 -0
- package/dist/lib/Helper/Logging.js.map +1 -1
- package/dist/lib/Helper/Package.d.ts +5 -3
- package/dist/lib/Helper/Package.js +2 -2
- package/dist/lib/Helper/Package.js.map +1 -1
- package/dist/lib/Helper/SentryCli.d.ts +20 -7
- package/dist/lib/Helper/SentryCli.js +21 -13
- package/dist/lib/Helper/SentryCli.js.map +1 -1
- package/dist/lib/Helper/Wizard.js +9 -5
- package/dist/lib/Helper/Wizard.js.map +1 -1
- package/dist/lib/Helper/__tests__/File.js +9 -9
- package/dist/lib/Helper/__tests__/File.js.map +1 -1
- package/dist/lib/Helper/__tests__/MergeConfig.js +17 -17
- package/dist/lib/Helper/__tests__/MergeConfig.js.map +1 -1
- package/dist/lib/Helper/__tests__/SentryCli.js +39 -21
- package/dist/lib/Helper/__tests__/SentryCli.js.map +1 -1
- package/dist/lib/Setup.d.ts +4 -1
- package/dist/lib/Setup.js +12 -2
- package/dist/lib/Setup.js.map +1 -1
- package/dist/lib/Steps/BaseStep.d.ts +1 -1
- package/dist/lib/Steps/BaseStep.js.map +1 -1
- package/dist/lib/Steps/Integrations/BaseIntegration.js +1 -2
- package/dist/lib/Steps/Integrations/BaseIntegration.js.map +1 -1
- package/dist/lib/Steps/Integrations/Cordova.js +14 -10
- package/dist/lib/Steps/Integrations/Cordova.js.map +1 -1
- package/dist/lib/Steps/Integrations/Electron.d.ts +4 -1
- package/dist/lib/Steps/Integrations/Electron.js +1 -1
- package/dist/lib/Steps/Integrations/Electron.js.map +1 -1
- package/dist/lib/Steps/Integrations/MobileProject.d.ts +3 -1
- package/dist/lib/Steps/Integrations/MobileProject.js +1 -1
- package/dist/lib/Steps/Integrations/MobileProject.js.map +1 -1
- package/dist/lib/Steps/PromptForParameters.d.ts +4 -1
- package/dist/lib/Steps/PromptForParameters.js.map +1 -1
- package/dist/lib/Steps/SentryProjectSelector.d.ts +42 -1
- package/dist/lib/Steps/SentryProjectSelector.js +1 -1
- package/dist/lib/Steps/SentryProjectSelector.js.map +1 -1
- package/dist/lib/Steps/WaitForSentry.d.ts +3 -1
- package/dist/lib/Steps/WaitForSentry.js +4 -4
- package/dist/lib/Steps/WaitForSentry.js.map +1 -1
- package/dist/lib/Steps/Welcome.js +5 -0
- package/dist/lib/Steps/Welcome.js.map +1 -1
- package/dist/lib/Types.d.ts +14 -0
- package/dist/lib/Types.js +3 -0
- package/dist/lib/Types.js.map +1 -0
- package/dist/lib/__tests__/Env.js +10 -16
- package/dist/lib/__tests__/Env.js.map +1 -1
- package/dist/src/android/android-wizard.js +15 -12
- package/dist/src/android/android-wizard.js.map +1 -1
- package/dist/src/android/code-tools.js +1 -1
- package/dist/src/android/code-tools.js.map +1 -1
- package/dist/src/android/gradle.js +4 -4
- package/dist/src/android/gradle.js.map +1 -1
- package/dist/src/android/manifest.js +1 -1
- package/dist/src/android/manifest.js.map +1 -1
- package/dist/src/apple/apple-wizard.d.ts +2 -2
- package/dist/src/apple/apple-wizard.js +54 -175
- package/dist/src/apple/apple-wizard.js.map +1 -1
- package/dist/src/apple/check-installed-cli.d.ts +1 -0
- package/dist/src/apple/check-installed-cli.js +60 -0
- package/dist/src/apple/check-installed-cli.js.map +1 -0
- package/dist/src/apple/cocoapod.js +1 -1
- package/dist/src/apple/cocoapod.js.map +1 -1
- package/dist/src/apple/code-tools.js +1 -1
- package/dist/src/apple/code-tools.js.map +1 -1
- package/dist/src/apple/configure-fastlane.d.ts +5 -0
- package/dist/src/apple/configure-fastlane.js +66 -0
- package/dist/src/apple/configure-fastlane.js.map +1 -0
- package/dist/src/apple/configure-package-manager.d.ts +5 -0
- package/dist/src/apple/configure-package-manager.js +68 -0
- package/dist/src/apple/configure-package-manager.js.map +1 -0
- package/dist/src/apple/configure-sentry-cli.d.ts +4 -0
- package/dist/src/apple/configure-sentry-cli.js +47 -0
- package/dist/src/apple/configure-sentry-cli.js.map +1 -0
- package/dist/src/apple/configure-xcode-project.d.ts +8 -0
- package/dist/src/apple/configure-xcode-project.js +11 -0
- package/dist/src/apple/configure-xcode-project.js.map +1 -0
- package/dist/src/apple/fastlane.d.ts +1 -1
- package/dist/src/apple/fastlane.js +5 -5
- package/dist/src/apple/fastlane.js.map +1 -1
- package/dist/src/apple/inject-code-snippet.d.ts +6 -0
- package/dist/src/apple/inject-code-snippet.js +54 -0
- package/dist/src/apple/inject-code-snippet.js.map +1 -0
- package/dist/src/apple/lookup-xcode-project.d.ts +7 -0
- package/dist/src/apple/lookup-xcode-project.js +98 -0
- package/dist/src/apple/lookup-xcode-project.js.map +1 -0
- package/dist/src/apple/options.d.ts +4 -0
- package/dist/src/apple/options.js +3 -0
- package/dist/src/apple/options.js.map +1 -0
- package/dist/src/apple/search-xcode-project-at-path.d.ts +1 -0
- package/dist/src/apple/search-xcode-project-at-path.js +70 -0
- package/dist/src/apple/search-xcode-project-at-path.js.map +1 -0
- package/dist/src/apple/templates.js +11 -7
- package/dist/src/apple/templates.js.map +1 -1
- package/dist/src/apple/xcode-manager.js +4 -7
- package/dist/src/apple/xcode-manager.js.map +1 -1
- package/dist/src/flutter/code-tools.js +3 -3
- package/dist/src/flutter/code-tools.js.map +1 -1
- package/dist/src/flutter/flutter-wizard.js +21 -15
- package/dist/src/flutter/flutter-wizard.js.map +1 -1
- package/dist/src/flutter/templates.js +4 -4
- package/dist/src/flutter/templates.js.map +1 -1
- package/dist/src/nextjs/nextjs-wizard.js +118 -43
- package/dist/src/nextjs/nextjs-wizard.js.map +1 -1
- package/dist/src/nextjs/templates.d.ts +10 -1
- package/dist/src/nextjs/templates.js +192 -62
- package/dist/src/nextjs/templates.js.map +1 -1
- package/dist/src/nuxt/nuxt-wizard.js +21 -16
- package/dist/src/nuxt/nuxt-wizard.js.map +1 -1
- package/dist/src/nuxt/sdk-example.js +3 -3
- package/dist/src/nuxt/sdk-example.js.map +1 -1
- package/dist/src/nuxt/sdk-setup.js +9 -9
- package/dist/src/nuxt/sdk-setup.js.map +1 -1
- package/dist/src/nuxt/templates.js +173 -58
- package/dist/src/nuxt/templates.js.map +1 -1
- package/dist/src/nuxt/utils.js +6 -3
- package/dist/src/nuxt/utils.js.map +1 -1
- package/dist/src/react-native/expo-env-file.js +1 -1
- package/dist/src/react-native/expo-env-file.js.map +1 -1
- package/dist/src/react-native/expo-metro.js +4 -4
- package/dist/src/react-native/expo-metro.js.map +1 -1
- package/dist/src/react-native/expo.js +4 -4
- package/dist/src/react-native/expo.js.map +1 -1
- package/dist/src/react-native/javascript.d.ts +6 -4
- package/dist/src/react-native/javascript.js +31 -15
- package/dist/src/react-native/javascript.js.map +1 -1
- package/dist/src/react-native/metro.js +8 -8
- package/dist/src/react-native/metro.js.map +1 -1
- package/dist/src/react-native/react-native-wizard.d.ts +5 -1
- package/dist/src/react-native/react-native-wizard.js +66 -36
- package/dist/src/react-native/react-native-wizard.js.map +1 -1
- package/dist/src/react-native/uninstall.js +8 -5
- package/dist/src/react-native/uninstall.js.map +1 -1
- package/dist/src/react-native/xcode.d.ts +9 -4
- package/dist/src/react-native/xcode.js +65 -22
- package/dist/src/react-native/xcode.js.map +1 -1
- package/dist/src/remix/codemods/handle-error.js +4 -1
- package/dist/src/remix/codemods/handle-error.js.map +1 -1
- package/dist/src/remix/remix-wizard.js +23 -18
- package/dist/src/remix/remix-wizard.js.map +1 -1
- package/dist/src/remix/sdk-example.js +163 -64
- package/dist/src/remix/sdk-example.js.map +1 -1
- package/dist/src/remix/sdk-setup.js +11 -7
- package/dist/src/remix/sdk-setup.js.map +1 -1
- package/dist/src/run.d.ts +3 -1
- package/dist/src/run.js +29 -9
- package/dist/src/run.js.map +1 -1
- package/dist/src/sourcemaps/sourcemaps-wizard.js +30 -28
- package/dist/src/sourcemaps/sourcemaps-wizard.js.map +1 -1
- package/dist/src/sourcemaps/tools/angular.js +3 -3
- package/dist/src/sourcemaps/tools/angular.js.map +1 -1
- package/dist/src/sourcemaps/tools/create-react-app.js +3 -3
- package/dist/src/sourcemaps/tools/create-react-app.js.map +1 -1
- package/dist/src/sourcemaps/tools/esbuild.js +6 -6
- package/dist/src/sourcemaps/tools/esbuild.js.map +1 -1
- package/dist/src/sourcemaps/tools/nextjs.js +5 -5
- package/dist/src/sourcemaps/tools/nextjs.js.map +1 -1
- package/dist/src/sourcemaps/tools/remix.js +4 -4
- package/dist/src/sourcemaps/tools/remix.js.map +1 -1
- package/dist/src/sourcemaps/tools/rollup.js +6 -6
- package/dist/src/sourcemaps/tools/rollup.js.map +1 -1
- package/dist/src/sourcemaps/tools/sentry-cli.js +15 -15
- package/dist/src/sourcemaps/tools/sentry-cli.js.map +1 -1
- package/dist/src/sourcemaps/tools/tsc.js +6 -6
- package/dist/src/sourcemaps/tools/tsc.js.map +1 -1
- package/dist/src/sourcemaps/tools/vite.js +12 -12
- package/dist/src/sourcemaps/tools/vite.js.map +1 -1
- package/dist/src/sourcemaps/tools/webpack.js +10 -10
- package/dist/src/sourcemaps/tools/webpack.js.map +1 -1
- package/dist/src/sourcemaps/utils/detect-tool.js +2 -2
- package/dist/src/sourcemaps/utils/detect-tool.js.map +1 -1
- package/dist/src/sourcemaps/utils/other-wizards.js +5 -5
- package/dist/src/sourcemaps/utils/other-wizards.js.map +1 -1
- package/dist/src/sourcemaps/utils/sdk-version.js +7 -7
- package/dist/src/sourcemaps/utils/sdk-version.js.map +1 -1
- package/dist/src/sveltekit/sdk-example.js +1 -1
- package/dist/src/sveltekit/sdk-example.js.map +1 -1
- package/dist/src/sveltekit/sdk-setup.js +15 -14
- package/dist/src/sveltekit/sdk-setup.js.map +1 -1
- package/dist/src/sveltekit/sveltekit-wizard.js +25 -20
- package/dist/src/sveltekit/sveltekit-wizard.js.map +1 -1
- package/dist/src/sveltekit/templates.js +126 -37
- package/dist/src/sveltekit/templates.js.map +1 -1
- package/dist/src/telemetry.js +11 -0
- package/dist/src/telemetry.js.map +1 -1
- package/dist/src/utils/{clack-utils.d.ts → clack/index.d.ts} +45 -7
- package/dist/src/utils/{clack-utils.js → clack/index.js} +75 -20
- package/dist/src/utils/clack/index.js.map +1 -0
- package/dist/src/utils/debug.js +1 -1
- package/dist/src/utils/debug.js.map +1 -1
- package/dist/src/utils/find-files-with-extension.d.ts +1 -0
- package/dist/src/utils/find-files-with-extension.js +39 -0
- package/dist/src/utils/find-files-with-extension.js.map +1 -0
- package/dist/src/utils/package-manager.d.ts +8 -1
- package/dist/src/utils/package-manager.js +79 -23
- package/dist/src/utils/package-manager.js.map +1 -1
- package/dist/src/utils/sentrycli-utils.js +0 -1
- package/dist/src/utils/sentrycli-utils.js.map +1 -1
- package/dist/src/utils/types.d.ts +4 -0
- package/dist/src/utils/types.js.map +1 -1
- package/dist/src/version.d.ts +1 -1
- package/dist/src/version.js +1 -1
- package/dist/src/version.js.map +1 -1
- package/dist/test/android/code-tools.test.js +13 -13
- package/dist/test/android/code-tools.test.js.map +1 -1
- package/dist/test/apple/cocoapod.test.js +78 -73
- package/dist/test/apple/cocoapod.test.js.map +1 -1
- package/dist/test/apple/code-tools.test.js +174 -167
- package/dist/test/apple/code-tools.test.js.map +1 -1
- package/dist/test/apple/fastfile.test.js +87 -84
- package/dist/test/apple/fastfile.test.js.map +1 -1
- package/dist/test/apple/templates.test.js +32 -27
- package/dist/test/apple/templates.test.js.map +1 -1
- package/dist/test/apple/xcode-manager.test.js +208 -185
- package/dist/test/apple/xcode-manager.test.js.map +1 -1
- package/dist/test/flutter/code-tools.test.js +29 -30
- package/dist/test/flutter/code-tools.test.js.map +1 -1
- package/dist/test/flutter/templates.test.js +38 -37
- package/dist/test/flutter/templates.test.js.map +1 -1
- package/dist/test/nextjs/templates.test.js +155 -103
- package/dist/test/nextjs/templates.test.js.map +1 -1
- package/dist/test/nuxt/templates.test.js +25 -24
- package/dist/test/nuxt/templates.test.js.map +1 -1
- package/dist/test/react-native/expo-metro.test.js +12 -11
- package/dist/test/react-native/expo-metro.test.js.map +1 -1
- package/dist/test/react-native/expo.test.js +11 -10
- package/dist/test/react-native/expo.test.js.map +1 -1
- package/dist/test/react-native/gradle.test.js +27 -26
- package/dist/test/react-native/gradle.test.js.map +1 -1
- package/dist/test/react-native/javascript.test.js +109 -59
- package/dist/test/react-native/javascript.test.js.map +1 -1
- package/dist/test/react-native/metro.test.js +66 -65
- package/dist/test/react-native/metro.test.js.map +1 -1
- package/dist/test/react-native/xcode.test.js +138 -37
- package/dist/test/react-native/xcode.test.js.map +1 -1
- package/dist/test/remix/client-entry.test.js +8 -7
- package/dist/test/remix/client-entry.test.js.map +1 -1
- package/dist/test/remix/server-instrumentation.test.js +6 -5
- package/dist/test/remix/server-instrumentation.test.js.map +1 -1
- package/dist/test/sourcemaps/tools/sentry-cli.test.js +21 -21
- package/dist/test/sourcemaps/tools/sentry-cli.test.js.map +1 -1
- package/dist/test/sourcemaps/tools/tsc.test.js +13 -14
- package/dist/test/sourcemaps/tools/tsc.test.js.map +1 -1
- package/dist/test/sourcemaps/tools/vite.test.js +13 -14
- package/dist/test/sourcemaps/tools/vite.test.js.map +1 -1
- package/dist/test/sourcemaps/tools/webpack.test.js +19 -20
- package/dist/test/sourcemaps/tools/webpack.test.js.map +1 -1
- package/dist/test/sveltekit/templates.test.js +13 -12
- package/dist/test/sveltekit/templates.test.js.map +1 -1
- package/dist/test/utils/ast-utils.test.js +45 -44
- package/dist/test/utils/ast-utils.test.js.map +1 -1
- package/dist/test/utils/clack/index.test.d.ts +1 -0
- package/dist/test/utils/clack/index.test.js +375 -0
- package/dist/test/utils/clack/index.test.js.map +1 -0
- package/dist/test/utils/package-manager.test.d.ts +1 -0
- package/dist/test/utils/package-manager.test.js +30 -0
- package/dist/test/utils/package-manager.test.js.map +1 -0
- package/package.json +10 -38
- package/dist/e2e-tests/jest.config.d.ts +0 -17
- package/dist/e2e-tests/jest.config.js +0 -23
- package/dist/e2e-tests/jest.config.js.map +0 -1
- package/dist/src/utils/clack-utils.js.map +0 -1
- package/dist/test/utils/clack-utils.test.js +0 -306
- package/dist/test/utils/clack-utils.test.js.map +0 -1
- /package/dist/{test/utils/clack-utils.test.d.ts → e2e-tests/tests/help-message.test.d.ts} +0 -0
|
@@ -26,8 +26,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
26
26
|
const ast_utils_1 = require("../../src/utils/ast-utils");
|
|
27
27
|
const recast = __importStar(require("recast"));
|
|
28
28
|
const b = recast.types.builders;
|
|
29
|
-
|
|
30
|
-
|
|
29
|
+
const vitest_1 = require("vitest");
|
|
30
|
+
(0, vitest_1.describe)('hasSentryContent', () => {
|
|
31
|
+
vitest_1.it.each([
|
|
31
32
|
`
|
|
32
33
|
const { sentryVitePlugin } = require("@sentry/vite-plugin");
|
|
33
34
|
const somethingelse = require('gs');
|
|
@@ -45,9 +46,9 @@ describe('hasSentryContent', () => {
|
|
|
45
46
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
|
46
47
|
const program = recast.parse(code)
|
|
47
48
|
.program;
|
|
48
|
-
expect((0, ast_utils_1.hasSentryContent)(program)).toBe(true);
|
|
49
|
+
(0, vitest_1.expect)((0, ast_utils_1.hasSentryContent)(program)).toBe(true);
|
|
49
50
|
});
|
|
50
|
-
it.each([
|
|
51
|
+
vitest_1.it.each([
|
|
51
52
|
`const whatever = require('something')`,
|
|
52
53
|
`// const {sentryWebpackPlugin} = require('@sentry/webpack-plugin')`,
|
|
53
54
|
`const {sAntryWebpackPlugin} = require('webpack-plugin-@sentry')`,
|
|
@@ -73,11 +74,11 @@ describe('hasSentryContent', () => {
|
|
|
73
74
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
|
74
75
|
const program = recast.parse(code)
|
|
75
76
|
.program;
|
|
76
|
-
expect((0, ast_utils_1.hasSentryContent)(program)).toBe(false);
|
|
77
|
+
(0, vitest_1.expect)((0, ast_utils_1.hasSentryContent)(program)).toBe(false);
|
|
77
78
|
});
|
|
78
79
|
});
|
|
79
|
-
describe('getObjectProperty', () => {
|
|
80
|
-
it.each([
|
|
80
|
+
(0, vitest_1.describe)('getObjectProperty', () => {
|
|
81
|
+
vitest_1.it.each([
|
|
81
82
|
[
|
|
82
83
|
'literal',
|
|
83
84
|
b.objectExpression([
|
|
@@ -101,58 +102,58 @@ describe('getObjectProperty', () => {
|
|
|
101
102
|
],
|
|
102
103
|
])('returns the poperty (%s) if it exists', (_, object) => {
|
|
103
104
|
const property = (0, ast_utils_1.getObjectProperty)(object, 'needle');
|
|
104
|
-
expect(property).toBeDefined();
|
|
105
|
+
(0, vitest_1.expect)(property).toBeDefined();
|
|
105
106
|
// @ts-expect-error we know it's defined due to the expect above
|
|
106
|
-
expect(recast.print(property).code).toEqual(expect.stringContaining('needle'));
|
|
107
|
+
(0, vitest_1.expect)(recast.print(property).code).toEqual(vitest_1.expect.stringContaining('needle'));
|
|
107
108
|
});
|
|
108
|
-
it('returns undefined if the property does not exist', () => {
|
|
109
|
+
(0, vitest_1.it)('returns undefined if the property does not exist', () => {
|
|
109
110
|
const object = b.objectExpression([
|
|
110
111
|
b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),
|
|
111
112
|
]);
|
|
112
113
|
const property = (0, ast_utils_1.getObjectProperty)(object, 'needle');
|
|
113
|
-
expect(property).toBeUndefined();
|
|
114
|
+
(0, vitest_1.expect)(property).toBeUndefined();
|
|
114
115
|
});
|
|
115
|
-
it('handles objects without simple properties', () => {
|
|
116
|
+
(0, vitest_1.it)('handles objects without simple properties', () => {
|
|
116
117
|
const object = b.objectExpression([b.spreadElement(b.identifier('foo'))]);
|
|
117
118
|
const property = (0, ast_utils_1.getObjectProperty)(object, 'needle');
|
|
118
|
-
expect(property).toBeUndefined();
|
|
119
|
+
(0, vitest_1.expect)(property).toBeUndefined();
|
|
119
120
|
});
|
|
120
121
|
});
|
|
121
|
-
describe('getOrSetObjectProperty', () => {
|
|
122
|
-
it('returns the property if it exists', () => {
|
|
122
|
+
(0, vitest_1.describe)('getOrSetObjectProperty', () => {
|
|
123
|
+
(0, vitest_1.it)('returns the property if it exists', () => {
|
|
123
124
|
const object = b.objectExpression([
|
|
124
125
|
b.objectProperty(b.identifier('needle'), b.stringLiteral('haystack')),
|
|
125
126
|
]);
|
|
126
127
|
const property = (0, ast_utils_1.getOrSetObjectProperty)(object, 'needle', b.stringLiteral('nope'));
|
|
127
|
-
expect(property).toBeDefined();
|
|
128
|
-
expect(property.type).toBe('ObjectProperty');
|
|
128
|
+
(0, vitest_1.expect)(property).toBeDefined();
|
|
129
|
+
(0, vitest_1.expect)(property.type).toBe('ObjectProperty');
|
|
129
130
|
// @ts-expect-error we know its type
|
|
130
|
-
expect(property.key.name).toBe('needle');
|
|
131
|
+
(0, vitest_1.expect)(property.key.name).toBe('needle');
|
|
131
132
|
// @ts-expect-error we know its type
|
|
132
|
-
expect(property.value.value).toBe('haystack');
|
|
133
|
+
(0, vitest_1.expect)(property.value.value).toBe('haystack');
|
|
133
134
|
});
|
|
134
|
-
it('adds the property if it does not exist', () => {
|
|
135
|
+
(0, vitest_1.it)('adds the property if it does not exist', () => {
|
|
135
136
|
const object = b.objectExpression([
|
|
136
137
|
b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),
|
|
137
138
|
]);
|
|
138
139
|
const property = (0, ast_utils_1.getOrSetObjectProperty)(object, 'needle', b.stringLiteral('haystack'));
|
|
139
|
-
expect(property).toBeDefined();
|
|
140
|
-
expect(property.type).toBe('Property');
|
|
140
|
+
(0, vitest_1.expect)(property).toBeDefined();
|
|
141
|
+
(0, vitest_1.expect)(property.type).toBe('Property');
|
|
141
142
|
// @ts-expect-error we know its type
|
|
142
|
-
expect(property.key.value).toBe('needle');
|
|
143
|
+
(0, vitest_1.expect)(property.key.value).toBe('needle');
|
|
143
144
|
// @ts-expect-error we know its type
|
|
144
|
-
expect(property.value.value).toBe('haystack');
|
|
145
|
+
(0, vitest_1.expect)(property.value.value).toBe('haystack');
|
|
145
146
|
});
|
|
146
147
|
});
|
|
147
|
-
describe('setOrUpdateObjectProperty', () => {
|
|
148
|
-
it('sets a new property if it does not exist yet', () => {
|
|
148
|
+
(0, vitest_1.describe)('setOrUpdateObjectProperty', () => {
|
|
149
|
+
(0, vitest_1.it)('sets a new property if it does not exist yet', () => {
|
|
149
150
|
const object = b.objectExpression([
|
|
150
151
|
b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),
|
|
151
152
|
]);
|
|
152
153
|
(0, ast_utils_1.setOrUpdateObjectProperty)(object, 'needle', b.stringLiteral('haystack'));
|
|
153
|
-
expect((0, ast_utils_1.getObjectProperty)(object, 'needle')).toBeDefined();
|
|
154
|
+
(0, vitest_1.expect)((0, ast_utils_1.getObjectProperty)(object, 'needle')).toBeDefined();
|
|
154
155
|
});
|
|
155
|
-
it('updates an existing property if it exists', () => {
|
|
156
|
+
(0, vitest_1.it)('updates an existing property if it exists', () => {
|
|
156
157
|
const object = b.objectExpression([
|
|
157
158
|
b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),
|
|
158
159
|
b.objectProperty(b.identifier('needle'), b.stringLiteral('haystack')),
|
|
@@ -160,31 +161,31 @@ describe('setOrUpdateObjectProperty', () => {
|
|
|
160
161
|
(0, ast_utils_1.setOrUpdateObjectProperty)(object, 'needle', b.stringLiteral('haystack2'));
|
|
161
162
|
const property = (0, ast_utils_1.getObjectProperty)(object, 'needle');
|
|
162
163
|
// @ts-expect-error it must be defiend, otherwise we fail anyway
|
|
163
|
-
expect(property?.value.value).toBe('haystack2');
|
|
164
|
+
(0, vitest_1.expect)(property?.value.value).toBe('haystack2');
|
|
164
165
|
});
|
|
165
|
-
it('adds a comment to the existing property if provided', () => {
|
|
166
|
+
(0, vitest_1.it)('adds a comment to the existing property if provided', () => {
|
|
166
167
|
const object = b.objectExpression([
|
|
167
168
|
b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),
|
|
168
169
|
]);
|
|
169
170
|
(0, ast_utils_1.setOrUpdateObjectProperty)(object, 'needle', b.stringLiteral('haystack'), 'This is a comment');
|
|
170
171
|
const property = (0, ast_utils_1.getObjectProperty)(object, 'needle');
|
|
171
|
-
expect(property?.comments).toHaveLength(1);
|
|
172
|
+
(0, vitest_1.expect)(property?.comments).toHaveLength(1);
|
|
172
173
|
// @ts-expect-error it must be defiend, otherwise we fail anyway
|
|
173
|
-
expect(property?.comments[0].value).toBe(' This is a comment');
|
|
174
|
+
(0, vitest_1.expect)(property?.comments[0].value).toBe(' This is a comment');
|
|
174
175
|
});
|
|
175
|
-
it('adds a comment to the new property if provided', () => {
|
|
176
|
+
(0, vitest_1.it)('adds a comment to the new property if provided', () => {
|
|
176
177
|
const object = b.objectExpression([
|
|
177
178
|
b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),
|
|
178
179
|
]);
|
|
179
180
|
(0, ast_utils_1.setOrUpdateObjectProperty)(object, 'needle', b.stringLiteral('haystack'), 'This is a comment');
|
|
180
181
|
const property = (0, ast_utils_1.getObjectProperty)(object, 'needle');
|
|
181
|
-
expect(property?.comments).toHaveLength(1);
|
|
182
|
+
(0, vitest_1.expect)(property?.comments).toHaveLength(1);
|
|
182
183
|
// @ts-expect-error it must be defiend, otherwise we fail anyway
|
|
183
|
-
expect(property?.comments[0].value).toBe(' This is a comment');
|
|
184
|
+
(0, vitest_1.expect)(property?.comments[0].value).toBe(' This is a comment');
|
|
184
185
|
});
|
|
185
186
|
});
|
|
186
|
-
describe('parse and print JSON-C', () => {
|
|
187
|
-
it.each([
|
|
187
|
+
(0, vitest_1.describe)('parse and print JSON-C', () => {
|
|
188
|
+
vitest_1.it.each([
|
|
188
189
|
['simple JSON', "{'foo': 'bar'}"],
|
|
189
190
|
[
|
|
190
191
|
'JSON-C with inline comment',
|
|
@@ -211,18 +212,18 @@ describe('parse and print JSON-C', () => {
|
|
|
211
212
|
],
|
|
212
213
|
])(`parses and prints JSON-C (%s)`, (_, json) => {
|
|
213
214
|
const { ast, jsonObject } = (0, ast_utils_1.parseJsonC)(json);
|
|
214
|
-
expect(ast?.type).toBe('Program');
|
|
215
|
-
expect(jsonObject).toBeDefined();
|
|
216
|
-
expect(jsonObject?.type).toBe('ObjectExpression');
|
|
215
|
+
(0, vitest_1.expect)(ast?.type).toBe('Program');
|
|
216
|
+
(0, vitest_1.expect)(jsonObject).toBeDefined();
|
|
217
|
+
(0, vitest_1.expect)(jsonObject?.type).toBe('ObjectExpression');
|
|
217
218
|
// @ts-expect-error we know it's defined due to the expect above
|
|
218
|
-
expect((0, ast_utils_1.printJsonC)(ast)).toEqual(json);
|
|
219
|
+
(0, vitest_1.expect)((0, ast_utils_1.printJsonC)(ast)).toEqual(json);
|
|
219
220
|
});
|
|
220
|
-
it('returns undefined if the input is not valid JSON-C', () => {
|
|
221
|
+
(0, vitest_1.it)('returns undefined if the input is not valid JSON-C', () => {
|
|
221
222
|
const { ast, jsonObject } = (0, ast_utils_1.parseJsonC)(`{
|
|
222
223
|
"invalid": // "json"
|
|
223
224
|
}`);
|
|
224
|
-
expect(ast).toBeUndefined();
|
|
225
|
-
expect(jsonObject).toBeUndefined();
|
|
225
|
+
(0, vitest_1.expect)(ast).toBeUndefined();
|
|
226
|
+
(0, vitest_1.expect)(jsonObject).toBeUndefined();
|
|
226
227
|
});
|
|
227
228
|
});
|
|
228
229
|
//# sourceMappingURL=ast-utils.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ast-utils.test.js","sourceRoot":"","sources":["../../../test/utils/ast-utils.test.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n getObjectProperty,\n getOrSetObjectProperty,\n hasSentryContent,\n parseJsonC,\n printJsonC,\n setOrUpdateObjectProperty,\n} from '../../src/utils/ast-utils';\n\nimport * as recast from 'recast';\nconst b = recast.types.builders;\n\ndescribe('hasSentryContent', () => {\n it.each([\n `\n const { sentryVitePlugin } = require(\"@sentry/vite-plugin\");\n const somethingelse = require('gs');\n `,\n `\n import { sentryVitePlugin } from \"@sentry/vite-plugin\";\n import * as somethingelse from 'gs';\n\n export default {\n plugins: [sentryVitePlugin()]\n }\n `,\n ])(\n \"returns true if a require('@sentry/') call was found in the parsed module\",\n (code) => {\n // recast.parse returns a Program node (or fails) but it's badly typed as any\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const program = recast.parse(code)\n .program as recast.types.namedTypes.Program;\n expect(hasSentryContent(program)).toBe(true);\n },\n );\n\n it.each([\n `const whatever = require('something')`,\n `// const {sentryWebpackPlugin} = require('@sentry/webpack-plugin')`,\n `const {sAntryWebpackPlugin} = require('webpack-plugin-@sentry')`,\n `\n import * as somethingelse from 'gs';\n export default {\n plugins: []\n }\n `,\n `import * as somethingelse from 'gs';\n // import { sentryVitePlugin } from \"@sentry/vite-plugin\"\n export default {\n plugins: []\n }\n `,\n `import * as thirdPartyVitePlugin from \"vite-plugin-@sentry\"\n export default {\n plugins: [thirdPartyVitePlugin()]\n }\n `,\n ])(\n \"returns false if the file doesn't contain any require('@sentry/') calls\",\n (code) => {\n // recast.parse returns a Program node (or fails) but it's badly typed as any\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const program = recast.parse(code)\n .program as recast.types.namedTypes.Program;\n expect(hasSentryContent(program)).toBe(false);\n },\n );\n});\n\ndescribe('getObjectProperty', () => {\n it.each([\n [\n 'literal',\n b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n b.objectProperty(\n b.stringLiteral('needle'),\n b.stringLiteral('haystack'),\n ),\n ]),\n ],\n [\n 'stringLiteral',\n b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n b.objectProperty(b.literal('needle'), b.stringLiteral('haystack')),\n ]),\n ],\n [\n 'identifier',\n b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n b.objectProperty(b.identifier('needle'), b.stringLiteral('haystack')),\n ]),\n ],\n ])('returns the poperty (%s) if it exists', (_, object) => {\n const property = getObjectProperty(object, 'needle');\n expect(property).toBeDefined();\n // @ts-expect-error we know it's defined due to the expect above\n expect(recast.print(property).code).toEqual(\n expect.stringContaining('needle'),\n );\n });\n\n it('returns undefined if the property does not exist', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n const property = getObjectProperty(object, 'needle');\n expect(property).toBeUndefined();\n });\n\n it('handles objects without simple properties', () => {\n const object = b.objectExpression([b.spreadElement(b.identifier('foo'))]);\n const property = getObjectProperty(object, 'needle');\n expect(property).toBeUndefined();\n });\n});\n\ndescribe('getOrSetObjectProperty', () => {\n it('returns the property if it exists', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('needle'), b.stringLiteral('haystack')),\n ]);\n\n const property = getOrSetObjectProperty(\n object,\n 'needle',\n b.stringLiteral('nope'),\n );\n\n expect(property).toBeDefined();\n expect(property.type).toBe('ObjectProperty');\n // @ts-expect-error we know its type\n expect(property.key.name).toBe('needle');\n // @ts-expect-error we know its type\n expect(property.value.value).toBe('haystack');\n });\n\n it('adds the property if it does not exist', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n\n const property = getOrSetObjectProperty(\n object,\n 'needle',\n b.stringLiteral('haystack'),\n );\n\n expect(property).toBeDefined();\n expect(property.type).toBe('Property');\n // @ts-expect-error we know its type\n expect(property.key.value).toBe('needle');\n // @ts-expect-error we know its type\n expect(property.value.value).toBe('haystack');\n });\n});\n\ndescribe('setOrUpdateObjectProperty', () => {\n it('sets a new property if it does not exist yet', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n\n setOrUpdateObjectProperty(object, 'needle', b.stringLiteral('haystack'));\n\n expect(getObjectProperty(object, 'needle')).toBeDefined();\n });\n\n it('updates an existing property if it exists', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n b.objectProperty(b.identifier('needle'), b.stringLiteral('haystack')),\n ]);\n\n setOrUpdateObjectProperty(object, 'needle', b.stringLiteral('haystack2'));\n\n const property = getObjectProperty(object, 'needle');\n // @ts-expect-error it must be defiend, otherwise we fail anyway\n expect(property?.value.value).toBe('haystack2');\n });\n\n it('adds a comment to the existing property if provided', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n\n setOrUpdateObjectProperty(\n object,\n 'needle',\n b.stringLiteral('haystack'),\n 'This is a comment',\n );\n\n const property = getObjectProperty(object, 'needle');\n expect(property?.comments).toHaveLength(1);\n // @ts-expect-error it must be defiend, otherwise we fail anyway\n expect(property?.comments[0].value).toBe(' This is a comment');\n });\n\n it('adds a comment to the new property if provided', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n\n setOrUpdateObjectProperty(\n object,\n 'needle',\n b.stringLiteral('haystack'),\n 'This is a comment',\n );\n\n const property = getObjectProperty(object, 'needle');\n expect(property?.comments).toHaveLength(1);\n // @ts-expect-error it must be defiend, otherwise we fail anyway\n expect(property?.comments[0].value).toBe(' This is a comment');\n });\n});\n\ndescribe('parse and print JSON-C', () => {\n it.each([\n ['simple JSON', \"{'foo': 'bar'}\"],\n [\n 'JSON-C with inline comment',\n `\n {\n \"foo\": \"bar\" // with an inline comment\n }\n `,\n ],\n [\n 'JSON-C with multiple comments',\n `\n /*\n * let's throw in a block comment for good measure\n */ \n {\n // one line comment\n \"foo\": \"bar\", // another inline comment\n /* one more here */\n \"dogs\": /* and here */ \"awesome\",\n }\n /* and here */\n `,\n ],\n ])(`parses and prints JSON-C (%s)`, (_, json) => {\n const { ast, jsonObject } = parseJsonC(json);\n expect(ast?.type).toBe('Program');\n expect(jsonObject).toBeDefined();\n expect(jsonObject?.type).toBe('ObjectExpression');\n // @ts-expect-error we know it's defined due to the expect above\n expect(printJsonC(ast)).toEqual(json);\n });\n\n it('returns undefined if the input is not valid JSON-C', () => {\n const { ast, jsonObject } = parseJsonC(`{\n \"invalid\": // \"json\"\n }`);\n expect(ast).toBeUndefined();\n expect(jsonObject).toBeUndefined();\n });\n});\n"]}
|
|
1
|
+
{"version":3,"file":"ast-utils.test.js","sourceRoot":"","sources":["../../../test/utils/ast-utils.test.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n getObjectProperty,\n getOrSetObjectProperty,\n hasSentryContent,\n parseJsonC,\n printJsonC,\n setOrUpdateObjectProperty,\n} from '../../src/utils/ast-utils';\n\nimport * as recast from 'recast';\nconst b = recast.types.builders;\n\nimport { describe, it, expect } from 'vitest';\n\ndescribe('hasSentryContent', () => {\n it.each([\n `\n const { sentryVitePlugin } = require(\"@sentry/vite-plugin\");\n const somethingelse = require('gs');\n `,\n `\n import { sentryVitePlugin } from \"@sentry/vite-plugin\";\n import * as somethingelse from 'gs';\n\n export default {\n plugins: [sentryVitePlugin()]\n }\n `,\n ])(\n \"returns true if a require('@sentry/') call was found in the parsed module\",\n (code) => {\n // recast.parse returns a Program node (or fails) but it's badly typed as any\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const program = recast.parse(code)\n .program as recast.types.namedTypes.Program;\n expect(hasSentryContent(program)).toBe(true);\n },\n );\n\n it.each([\n `const whatever = require('something')`,\n `// const {sentryWebpackPlugin} = require('@sentry/webpack-plugin')`,\n `const {sAntryWebpackPlugin} = require('webpack-plugin-@sentry')`,\n `\n import * as somethingelse from 'gs';\n export default {\n plugins: []\n }\n `,\n `import * as somethingelse from 'gs';\n // import { sentryVitePlugin } from \"@sentry/vite-plugin\"\n export default {\n plugins: []\n }\n `,\n `import * as thirdPartyVitePlugin from \"vite-plugin-@sentry\"\n export default {\n plugins: [thirdPartyVitePlugin()]\n }\n `,\n ])(\n \"returns false if the file doesn't contain any require('@sentry/') calls\",\n (code) => {\n // recast.parse returns a Program node (or fails) but it's badly typed as any\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const program = recast.parse(code)\n .program as recast.types.namedTypes.Program;\n expect(hasSentryContent(program)).toBe(false);\n },\n );\n});\n\ndescribe('getObjectProperty', () => {\n it.each([\n [\n 'literal',\n b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n b.objectProperty(\n b.stringLiteral('needle'),\n b.stringLiteral('haystack'),\n ),\n ]),\n ],\n [\n 'stringLiteral',\n b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n b.objectProperty(b.literal('needle'), b.stringLiteral('haystack')),\n ]),\n ],\n [\n 'identifier',\n b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n b.objectProperty(b.identifier('needle'), b.stringLiteral('haystack')),\n ]),\n ],\n ])('returns the poperty (%s) if it exists', (_, object) => {\n const property = getObjectProperty(object, 'needle');\n expect(property).toBeDefined();\n // @ts-expect-error we know it's defined due to the expect above\n expect(recast.print(property).code).toEqual(\n expect.stringContaining('needle'),\n );\n });\n\n it('returns undefined if the property does not exist', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n const property = getObjectProperty(object, 'needle');\n expect(property).toBeUndefined();\n });\n\n it('handles objects without simple properties', () => {\n const object = b.objectExpression([b.spreadElement(b.identifier('foo'))]);\n const property = getObjectProperty(object, 'needle');\n expect(property).toBeUndefined();\n });\n});\n\ndescribe('getOrSetObjectProperty', () => {\n it('returns the property if it exists', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('needle'), b.stringLiteral('haystack')),\n ]);\n\n const property = getOrSetObjectProperty(\n object,\n 'needle',\n b.stringLiteral('nope'),\n );\n\n expect(property).toBeDefined();\n expect(property.type).toBe('ObjectProperty');\n // @ts-expect-error we know its type\n expect(property.key.name).toBe('needle');\n // @ts-expect-error we know its type\n expect(property.value.value).toBe('haystack');\n });\n\n it('adds the property if it does not exist', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n\n const property = getOrSetObjectProperty(\n object,\n 'needle',\n b.stringLiteral('haystack'),\n );\n\n expect(property).toBeDefined();\n expect(property.type).toBe('Property');\n // @ts-expect-error we know its type\n expect(property.key.value).toBe('needle');\n // @ts-expect-error we know its type\n expect(property.value.value).toBe('haystack');\n });\n});\n\ndescribe('setOrUpdateObjectProperty', () => {\n it('sets a new property if it does not exist yet', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n\n setOrUpdateObjectProperty(object, 'needle', b.stringLiteral('haystack'));\n\n expect(getObjectProperty(object, 'needle')).toBeDefined();\n });\n\n it('updates an existing property if it exists', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n b.objectProperty(b.identifier('needle'), b.stringLiteral('haystack')),\n ]);\n\n setOrUpdateObjectProperty(object, 'needle', b.stringLiteral('haystack2'));\n\n const property = getObjectProperty(object, 'needle');\n // @ts-expect-error it must be defiend, otherwise we fail anyway\n expect(property?.value.value).toBe('haystack2');\n });\n\n it('adds a comment to the existing property if provided', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n\n setOrUpdateObjectProperty(\n object,\n 'needle',\n b.stringLiteral('haystack'),\n 'This is a comment',\n );\n\n const property = getObjectProperty(object, 'needle');\n expect(property?.comments).toHaveLength(1);\n // @ts-expect-error it must be defiend, otherwise we fail anyway\n expect(property?.comments[0].value).toBe(' This is a comment');\n });\n\n it('adds a comment to the new property if provided', () => {\n const object = b.objectExpression([\n b.objectProperty(b.identifier('foo'), b.stringLiteral('bar')),\n ]);\n\n setOrUpdateObjectProperty(\n object,\n 'needle',\n b.stringLiteral('haystack'),\n 'This is a comment',\n );\n\n const property = getObjectProperty(object, 'needle');\n expect(property?.comments).toHaveLength(1);\n // @ts-expect-error it must be defiend, otherwise we fail anyway\n expect(property?.comments[0].value).toBe(' This is a comment');\n });\n});\n\ndescribe('parse and print JSON-C', () => {\n it.each([\n ['simple JSON', \"{'foo': 'bar'}\"],\n [\n 'JSON-C with inline comment',\n `\n {\n \"foo\": \"bar\" // with an inline comment\n }\n `,\n ],\n [\n 'JSON-C with multiple comments',\n `\n /*\n * let's throw in a block comment for good measure\n */ \n {\n // one line comment\n \"foo\": \"bar\", // another inline comment\n /* one more here */\n \"dogs\": /* and here */ \"awesome\",\n }\n /* and here */\n `,\n ],\n ])(`parses and prints JSON-C (%s)`, (_, json) => {\n const { ast, jsonObject } = parseJsonC(json);\n expect(ast?.type).toBe('Program');\n expect(jsonObject).toBeDefined();\n expect(jsonObject?.type).toBe('ObjectExpression');\n // @ts-expect-error we know it's defined due to the expect above\n expect(printJsonC(ast)).toEqual(json);\n });\n\n it('returns undefined if the input is not valid JSON-C', () => {\n const { ast, jsonObject } = parseJsonC(`{\n \"invalid\": // \"json\"\n }`);\n expect(ast).toBeUndefined();\n expect(jsonObject).toBeUndefined();\n });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,375 @@
|
|
|
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
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const clack_1 = require("../../../src/utils/clack/");
|
|
30
|
+
const fs = __importStar(require("node:fs"));
|
|
31
|
+
const ChildProcess = __importStar(require("node:child_process"));
|
|
32
|
+
const PackageManagerUtils = __importStar(require("../../../src/utils/package-manager"));
|
|
33
|
+
const package_manager_1 = require("../../../src/utils/package-manager");
|
|
34
|
+
const axios_1 = __importDefault(require("axios"));
|
|
35
|
+
// @ts-expect-error - clack is ESM and TS complains about that. It works though
|
|
36
|
+
const clack = __importStar(require("@clack/prompts"));
|
|
37
|
+
const Sentry = __importStar(require("@sentry/node"));
|
|
38
|
+
const vitest_1 = require("vitest");
|
|
39
|
+
vitest_1.vi.mock('node:child_process', async () => ({
|
|
40
|
+
__esModule: true,
|
|
41
|
+
...(await vitest_1.vi.importActual('node:child_process')),
|
|
42
|
+
}));
|
|
43
|
+
vitest_1.vi.mock('@clack/prompts', () => ({
|
|
44
|
+
log: {
|
|
45
|
+
info: vitest_1.vi.fn(),
|
|
46
|
+
success: vitest_1.vi.fn(),
|
|
47
|
+
warn: vitest_1.vi.fn(),
|
|
48
|
+
error: vitest_1.vi.fn(),
|
|
49
|
+
},
|
|
50
|
+
outro: vitest_1.vi.fn(),
|
|
51
|
+
text: vitest_1.vi.fn(),
|
|
52
|
+
confirm: vitest_1.vi.fn(),
|
|
53
|
+
cancel: vitest_1.vi.fn(),
|
|
54
|
+
// passthrough for abortIfCancelled
|
|
55
|
+
isCancel: vitest_1.vi.fn().mockReturnValue(false),
|
|
56
|
+
spinner: vitest_1.vi
|
|
57
|
+
.fn()
|
|
58
|
+
.mockImplementation(() => ({ start: vitest_1.vi.fn(), stop: vitest_1.vi.fn() })),
|
|
59
|
+
select: vitest_1.vi.fn(),
|
|
60
|
+
}));
|
|
61
|
+
const clackMock = clack;
|
|
62
|
+
vitest_1.vi.mock('axios');
|
|
63
|
+
const mockedAxios = axios_1.default;
|
|
64
|
+
vitest_1.vi.mock('opn', () => ({
|
|
65
|
+
default: vitest_1.vi.fn(() => Promise.resolve({ on: vitest_1.vi.fn() })),
|
|
66
|
+
}));
|
|
67
|
+
function mockUserResponse(fn, response) {
|
|
68
|
+
fn.mockReturnValueOnce(response);
|
|
69
|
+
}
|
|
70
|
+
(0, vitest_1.describe)('askForToolConfigPath', () => {
|
|
71
|
+
(0, vitest_1.afterEach)(() => {
|
|
72
|
+
vitest_1.vi.clearAllMocks();
|
|
73
|
+
});
|
|
74
|
+
(0, vitest_1.it)('returns undefined if users have no config file', async () => {
|
|
75
|
+
mockUserResponse(clack.confirm, false);
|
|
76
|
+
const result = await (0, clack_1.askForToolConfigPath)('Webpack', 'webpack.config.js');
|
|
77
|
+
(0, vitest_1.expect)(clack.confirm).toHaveBeenCalledWith(vitest_1.expect.objectContaining({
|
|
78
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
79
|
+
message: vitest_1.expect.stringContaining('have a Webpack config file'),
|
|
80
|
+
}));
|
|
81
|
+
(0, vitest_1.expect)(result).toBeUndefined();
|
|
82
|
+
});
|
|
83
|
+
(0, vitest_1.it)('returns the path if users have a config file and the entered path is valid', async () => {
|
|
84
|
+
mockUserResponse(clack.confirm, true);
|
|
85
|
+
mockUserResponse(clack.text, 'my.webpack.config.js');
|
|
86
|
+
const result = await (0, clack_1.askForToolConfigPath)('Webpack', 'webpack.config.js');
|
|
87
|
+
(0, vitest_1.expect)(clack.confirm).toHaveBeenCalledWith(vitest_1.expect.objectContaining({
|
|
88
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
89
|
+
message: vitest_1.expect.stringContaining('have a Webpack config file'),
|
|
90
|
+
}));
|
|
91
|
+
(0, vitest_1.expect)(clack.text).toHaveBeenCalledWith(vitest_1.expect.objectContaining({
|
|
92
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
93
|
+
message: vitest_1.expect.stringContaining('enter the path to your Webpack config file'),
|
|
94
|
+
}));
|
|
95
|
+
(0, vitest_1.expect)(result).toBe('my.webpack.config.js');
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
(0, vitest_1.describe)('createNewConfigFile', () => {
|
|
99
|
+
(0, vitest_1.afterEach)(() => {
|
|
100
|
+
vitest_1.vi.clearAllMocks();
|
|
101
|
+
});
|
|
102
|
+
(0, vitest_1.it)('writes the file to disk and returns true if the file was created successfully', async () => {
|
|
103
|
+
const writeFileSpy = vitest_1.vi
|
|
104
|
+
.spyOn(fs.promises, 'writeFile')
|
|
105
|
+
.mockImplementation(vitest_1.vi.fn());
|
|
106
|
+
const filename = '/webpack.config.js';
|
|
107
|
+
const code = 'module.exports = {/*config...*/}';
|
|
108
|
+
const result = await (0, clack_1.createNewConfigFile)(filename, code);
|
|
109
|
+
(0, vitest_1.expect)(result).toBe(true);
|
|
110
|
+
(0, vitest_1.expect)(writeFileSpy).toHaveBeenCalledWith(filename, code);
|
|
111
|
+
});
|
|
112
|
+
(0, vitest_1.it)('logs more information if provided as an argument', async () => {
|
|
113
|
+
vitest_1.vi.spyOn(fs.promises, 'writeFile').mockImplementation(vitest_1.vi.fn());
|
|
114
|
+
const filename = '/webpack.config.js';
|
|
115
|
+
const code = 'module.exports = {/*config...*/}';
|
|
116
|
+
const moreInfo = 'More information...';
|
|
117
|
+
await (0, clack_1.createNewConfigFile)(filename, code, moreInfo);
|
|
118
|
+
(0, vitest_1.expect)(clack.log.info).toHaveBeenCalledTimes(1);
|
|
119
|
+
(0, vitest_1.expect)(clack.log.info).toHaveBeenCalledWith(vitest_1.expect.stringContaining(moreInfo));
|
|
120
|
+
});
|
|
121
|
+
(0, vitest_1.it)('returns false and logs a warning if the file could not be created', async () => {
|
|
122
|
+
const writeFileSpy = vitest_1.vi
|
|
123
|
+
.spyOn(fs.promises, 'writeFile')
|
|
124
|
+
.mockImplementation(() => Promise.reject(new Error('Could not write')));
|
|
125
|
+
const filename = '/webpack.config.js';
|
|
126
|
+
const code = 'module.exports = {/*config...*/}';
|
|
127
|
+
const result = await (0, clack_1.createNewConfigFile)(filename, code);
|
|
128
|
+
(0, vitest_1.expect)(result).toBe(false);
|
|
129
|
+
(0, vitest_1.expect)(writeFileSpy).toHaveBeenCalledWith(filename, code);
|
|
130
|
+
(0, vitest_1.expect)(clack.log.warn).toHaveBeenCalledTimes(1);
|
|
131
|
+
});
|
|
132
|
+
(0, vitest_1.it)('returns false if the passed path is not absolute', async () => {
|
|
133
|
+
const result = await (0, clack_1.createNewConfigFile)('./relative/webpack.config.js', '');
|
|
134
|
+
(0, vitest_1.expect)(result).toBe(false);
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
(0, vitest_1.describe)('installPackage', () => {
|
|
138
|
+
(0, vitest_1.afterEach)(() => {
|
|
139
|
+
vitest_1.vi.clearAllMocks();
|
|
140
|
+
});
|
|
141
|
+
const spawnSpy = vitest_1.vi.spyOn(ChildProcess, 'spawn').mockImplementation(() => ({
|
|
142
|
+
// @ts-expect-error - not passing the full object but directly resolving
|
|
143
|
+
// to simulate a successful install
|
|
144
|
+
on: vitest_1.vi.fn((evt, cb) => {
|
|
145
|
+
if (evt === 'close') {
|
|
146
|
+
cb(0);
|
|
147
|
+
}
|
|
148
|
+
}),
|
|
149
|
+
// @ts-expect-error - this is fine
|
|
150
|
+
stderr: { on: vitest_1.vi.fn() },
|
|
151
|
+
}));
|
|
152
|
+
(0, vitest_1.it)('force-installs a package if the forceInstall flag is set', async () => {
|
|
153
|
+
const packageManagerMock = {
|
|
154
|
+
name: 'npm',
|
|
155
|
+
label: 'NPM',
|
|
156
|
+
installCommand: 'install',
|
|
157
|
+
buildCommand: 'npm run build',
|
|
158
|
+
runScriptCommand: 'npm run',
|
|
159
|
+
flags: '',
|
|
160
|
+
forceInstallFlag: '--force',
|
|
161
|
+
detect: vitest_1.vi.fn(),
|
|
162
|
+
addOverride: vitest_1.vi.fn(),
|
|
163
|
+
};
|
|
164
|
+
await (0, clack_1.installPackage)({
|
|
165
|
+
alreadyInstalled: false,
|
|
166
|
+
packageName: '@some/package',
|
|
167
|
+
packageNameDisplayLabel: '@some/package',
|
|
168
|
+
forceInstall: true,
|
|
169
|
+
askBeforeUpdating: false,
|
|
170
|
+
packageManager: packageManagerMock,
|
|
171
|
+
});
|
|
172
|
+
(0, vitest_1.expect)(spawnSpy).toHaveBeenCalledWith('npm', ['install', '@some/package', '--force'], { shell: true, stdio: ['pipe', 'ignore', 'pipe'] });
|
|
173
|
+
});
|
|
174
|
+
vitest_1.it.each([false, undefined])("doesn't force-install a package if the forceInstall flag is %s", async (flag) => {
|
|
175
|
+
const packageManagerMock = {
|
|
176
|
+
name: 'npm',
|
|
177
|
+
label: 'NPM',
|
|
178
|
+
installCommand: 'install',
|
|
179
|
+
buildCommand: 'npm run build',
|
|
180
|
+
runScriptCommand: 'npm run',
|
|
181
|
+
flags: '',
|
|
182
|
+
forceInstallFlag: '--force',
|
|
183
|
+
detect: vitest_1.vi.fn(),
|
|
184
|
+
addOverride: vitest_1.vi.fn(),
|
|
185
|
+
};
|
|
186
|
+
await (0, clack_1.installPackage)({
|
|
187
|
+
alreadyInstalled: false,
|
|
188
|
+
packageName: '@sentry/sveltekit',
|
|
189
|
+
packageNameDisplayLabel: '@sentry/sveltekit',
|
|
190
|
+
forceInstall: flag,
|
|
191
|
+
askBeforeUpdating: false,
|
|
192
|
+
packageManager: packageManagerMock,
|
|
193
|
+
});
|
|
194
|
+
(0, vitest_1.expect)(spawnSpy).toHaveBeenCalledWith('npm', ['install', '@sentry/sveltekit'], { shell: true, stdio: ['pipe', 'ignore', 'pipe'] });
|
|
195
|
+
});
|
|
196
|
+
(0, vitest_1.it)('adds install flags if defined', async () => {
|
|
197
|
+
const packageManagerMock = {
|
|
198
|
+
name: 'npm',
|
|
199
|
+
label: 'NPM',
|
|
200
|
+
installCommand: 'install',
|
|
201
|
+
buildCommand: 'npm run build',
|
|
202
|
+
runScriptCommand: 'npm run',
|
|
203
|
+
flags: '--ignore-workspace-root-check',
|
|
204
|
+
forceInstallFlag: '--force',
|
|
205
|
+
detect: vitest_1.vi.fn(),
|
|
206
|
+
addOverride: vitest_1.vi.fn(),
|
|
207
|
+
};
|
|
208
|
+
await (0, clack_1.installPackage)({
|
|
209
|
+
alreadyInstalled: false,
|
|
210
|
+
packageName: '@some/package',
|
|
211
|
+
packageNameDisplayLabel: '@some/package',
|
|
212
|
+
forceInstall: true,
|
|
213
|
+
askBeforeUpdating: false,
|
|
214
|
+
packageManager: packageManagerMock,
|
|
215
|
+
});
|
|
216
|
+
(0, vitest_1.expect)(spawnSpy).toHaveBeenCalledWith('npm', ['install', '@some/package', '--ignore-workspace-root-check', '--force'], { shell: true, stdio: ['pipe', 'ignore', 'pipe'] });
|
|
217
|
+
});
|
|
218
|
+
});
|
|
219
|
+
(0, vitest_1.describe)('askForWizardLogin', () => {
|
|
220
|
+
(0, vitest_1.beforeEach)(() => {
|
|
221
|
+
vitest_1.vi.clearAllMocks();
|
|
222
|
+
mockedAxios.get.mockClear();
|
|
223
|
+
clackMock.confirm.mockClear();
|
|
224
|
+
clackMock.confirm.mockReset();
|
|
225
|
+
mockUserResponse(clack.confirm, undefined);
|
|
226
|
+
});
|
|
227
|
+
(0, vitest_1.it)('asks if a user already has a Sentry account by default', async () => {
|
|
228
|
+
mockUserResponse(clack.confirm, Promise.resolve(true));
|
|
229
|
+
// Provide the data object to be returned
|
|
230
|
+
mockedAxios.get.mockResolvedValue({
|
|
231
|
+
data: {
|
|
232
|
+
hash: 'mockedHash',
|
|
233
|
+
},
|
|
234
|
+
});
|
|
235
|
+
await (0, clack_1.askForWizardLogin)({ url: 'https://santry.io/' });
|
|
236
|
+
(0, vitest_1.expect)(clack.confirm).toHaveBeenCalledWith(vitest_1.expect.objectContaining({
|
|
237
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
238
|
+
message: vitest_1.expect.stringContaining('already have a Sentry account'),
|
|
239
|
+
}));
|
|
240
|
+
});
|
|
241
|
+
(0, vitest_1.it)('skips asking for if a user already has a Sentry account if org and project are pre-selected', async () => {
|
|
242
|
+
mockUserResponse(clackMock.confirm, Promise.resolve(true));
|
|
243
|
+
// Provide the data object to be returned
|
|
244
|
+
mockedAxios.get.mockResolvedValue({
|
|
245
|
+
data: {
|
|
246
|
+
hash: 'mockedHash',
|
|
247
|
+
},
|
|
248
|
+
});
|
|
249
|
+
await (0, clack_1.askForWizardLogin)({
|
|
250
|
+
url: 'https://santry.io/',
|
|
251
|
+
orgSlug: 'my-org',
|
|
252
|
+
projectSlug: 'my-project',
|
|
253
|
+
});
|
|
254
|
+
(0, vitest_1.expect)(clack.confirm).not.toHaveBeenCalled();
|
|
255
|
+
});
|
|
256
|
+
});
|
|
257
|
+
(0, vitest_1.describe)('abort', () => {
|
|
258
|
+
const sentryTxn = {
|
|
259
|
+
setStatus: vitest_1.vi.fn(),
|
|
260
|
+
finish: vitest_1.vi.fn(),
|
|
261
|
+
};
|
|
262
|
+
let sentrySession = {
|
|
263
|
+
status: 999,
|
|
264
|
+
};
|
|
265
|
+
(0, vitest_1.beforeEach)(() => {
|
|
266
|
+
vitest_1.vi.clearAllMocks();
|
|
267
|
+
sentrySession = {
|
|
268
|
+
status: 999,
|
|
269
|
+
};
|
|
270
|
+
});
|
|
271
|
+
vitest_1.vi.spyOn(Sentry, 'getCurrentHub').mockReturnValue({
|
|
272
|
+
getScope: () => ({
|
|
273
|
+
// @ts-expect-error - don't care about the rest of the required props value
|
|
274
|
+
getTransaction: () => sentryTxn,
|
|
275
|
+
// @ts-expect-error - don't care about the rest of the required props value
|
|
276
|
+
getSession: () => sentrySession,
|
|
277
|
+
}),
|
|
278
|
+
captureSession: vitest_1.vi.fn(),
|
|
279
|
+
});
|
|
280
|
+
const flushSpy = vitest_1.vi.fn();
|
|
281
|
+
vitest_1.vi.spyOn(Sentry, 'flush').mockImplementation(flushSpy);
|
|
282
|
+
(0, vitest_1.it)('ends the process with an error exit code by default', async () => {
|
|
283
|
+
// @ts-expect-error - vitest doesn't like the empty function
|
|
284
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
285
|
+
const exitSpy = vitest_1.vi.spyOn(process, 'exit').mockImplementation(() => { });
|
|
286
|
+
await (0, clack_1.abort)();
|
|
287
|
+
(0, vitest_1.expect)(exitSpy).toHaveBeenCalledWith(1);
|
|
288
|
+
(0, vitest_1.expect)(clackMock.outro).toHaveBeenCalledTimes(1);
|
|
289
|
+
(0, vitest_1.expect)(clackMock.outro).toHaveBeenCalledWith('Wizard setup cancelled.');
|
|
290
|
+
(0, vitest_1.expect)(sentryTxn.setStatus).toHaveBeenLastCalledWith('aborted');
|
|
291
|
+
(0, vitest_1.expect)(sentryTxn.finish).toHaveBeenCalledTimes(1);
|
|
292
|
+
(0, vitest_1.expect)(sentrySession.status).toBe('crashed');
|
|
293
|
+
(0, vitest_1.expect)(flushSpy).toHaveBeenLastCalledWith(3000);
|
|
294
|
+
});
|
|
295
|
+
(0, vitest_1.it)('ends the process with a custom exit code and message if provided', async () => {
|
|
296
|
+
// @ts-expect-error - vitest doesn't like the empty function
|
|
297
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
298
|
+
const exitSpy = vitest_1.vi.spyOn(process, 'exit').mockImplementation(() => { });
|
|
299
|
+
await (0, clack_1.abort)('Bye', 0);
|
|
300
|
+
(0, vitest_1.expect)(exitSpy).toHaveBeenCalledWith(0);
|
|
301
|
+
(0, vitest_1.expect)(clackMock.outro).toHaveBeenCalledTimes(1);
|
|
302
|
+
(0, vitest_1.expect)(clackMock.outro).toHaveBeenCalledWith('Bye');
|
|
303
|
+
(0, vitest_1.expect)(sentryTxn.setStatus).toHaveBeenLastCalledWith('cancelled');
|
|
304
|
+
(0, vitest_1.expect)(sentryTxn.finish).toHaveBeenCalledTimes(1);
|
|
305
|
+
(0, vitest_1.expect)(sentrySession.status).toBe('abnormal');
|
|
306
|
+
(0, vitest_1.expect)(flushSpy).toHaveBeenLastCalledWith(3000);
|
|
307
|
+
});
|
|
308
|
+
});
|
|
309
|
+
(0, vitest_1.describe)('getPackageManager', () => {
|
|
310
|
+
(0, vitest_1.afterEach)(() => {
|
|
311
|
+
vitest_1.vi.clearAllMocks();
|
|
312
|
+
// @ts-expect-error - this variable is set by the wizard
|
|
313
|
+
delete global.__sentry_wizard_cached_package_manager;
|
|
314
|
+
});
|
|
315
|
+
(0, vitest_1.it)('returns the auto-detected package manager', async () => {
|
|
316
|
+
const detectPacManSpy = vitest_1.vi
|
|
317
|
+
.spyOn(PackageManagerUtils, '_detectPackageManger')
|
|
318
|
+
.mockReturnValueOnce(package_manager_1.YARN_V1);
|
|
319
|
+
const packageManager = await (0, clack_1.getPackageManager)();
|
|
320
|
+
(0, vitest_1.expect)(detectPacManSpy).toHaveBeenCalledTimes(1);
|
|
321
|
+
(0, vitest_1.expect)(packageManager).toBe(package_manager_1.YARN_V1);
|
|
322
|
+
});
|
|
323
|
+
(0, vitest_1.it)('caches the auto-detected package manager', async () => {
|
|
324
|
+
const detectPacManSpy = vitest_1.vi
|
|
325
|
+
.spyOn(PackageManagerUtils, '_detectPackageManger')
|
|
326
|
+
.mockReturnValueOnce(package_manager_1.YARN_V1);
|
|
327
|
+
const packageManager1 = await (0, clack_1.getPackageManager)();
|
|
328
|
+
const packageManager2 = await (0, clack_1.getPackageManager)();
|
|
329
|
+
(0, vitest_1.expect)(detectPacManSpy).toHaveBeenCalledTimes(1);
|
|
330
|
+
(0, vitest_1.expect)(packageManager1).toBe(package_manager_1.YARN_V1);
|
|
331
|
+
(0, vitest_1.expect)(packageManager2).toBe(package_manager_1.YARN_V1);
|
|
332
|
+
});
|
|
333
|
+
(0, vitest_1.describe)('when auto detection fails', () => {
|
|
334
|
+
(0, vitest_1.it)('returns a fallback package manager if fallback is specified', async () => {
|
|
335
|
+
const detectPacManSpy = vitest_1.vi
|
|
336
|
+
.spyOn(PackageManagerUtils, '_detectPackageManger')
|
|
337
|
+
.mockReturnValueOnce(null);
|
|
338
|
+
const packageManager = await (0, clack_1.getPackageManager)(package_manager_1.YARN_V2);
|
|
339
|
+
(0, vitest_1.expect)(detectPacManSpy).toHaveBeenCalledTimes(1);
|
|
340
|
+
(0, vitest_1.expect)(packageManager).toBe(package_manager_1.YARN_V2);
|
|
341
|
+
});
|
|
342
|
+
(0, vitest_1.it)("doesn't cache the fallback package manager", async () => {
|
|
343
|
+
const detectPacManSpy = vitest_1.vi
|
|
344
|
+
.spyOn(PackageManagerUtils, '_detectPackageManger')
|
|
345
|
+
.mockReturnValue(null);
|
|
346
|
+
const packageManager1 = await (0, clack_1.getPackageManager)(package_manager_1.YARN_V2);
|
|
347
|
+
const packageManager2 = await (0, clack_1.getPackageManager)(package_manager_1.NPM);
|
|
348
|
+
(0, vitest_1.expect)(detectPacManSpy).toHaveBeenCalledTimes(2);
|
|
349
|
+
(0, vitest_1.expect)(packageManager1).toBe(package_manager_1.YARN_V2);
|
|
350
|
+
(0, vitest_1.expect)(packageManager2).toBe(package_manager_1.NPM);
|
|
351
|
+
});
|
|
352
|
+
(0, vitest_1.it)('returns the user-selected package manager if no fallback is provided', async () => {
|
|
353
|
+
const detectPacManSpy = vitest_1.vi
|
|
354
|
+
.spyOn(PackageManagerUtils, '_detectPackageManger')
|
|
355
|
+
.mockReturnValueOnce(null);
|
|
356
|
+
clackMock.select.mockReturnValueOnce(Promise.resolve(package_manager_1.PNPM));
|
|
357
|
+
const packageManager = await (0, clack_1.getPackageManager)();
|
|
358
|
+
(0, vitest_1.expect)(detectPacManSpy).toHaveBeenCalledTimes(1);
|
|
359
|
+
(0, vitest_1.expect)(packageManager).toBe(package_manager_1.PNPM);
|
|
360
|
+
});
|
|
361
|
+
(0, vitest_1.it)('caches the user-selected package manager', async () => {
|
|
362
|
+
const detectPacManSpy = vitest_1.vi
|
|
363
|
+
.spyOn(PackageManagerUtils, '_detectPackageManger')
|
|
364
|
+
.mockReturnValueOnce(null);
|
|
365
|
+
clackMock.select.mockReturnValueOnce(Promise.resolve(package_manager_1.PNPM));
|
|
366
|
+
const packageManager1 = await (0, clack_1.getPackageManager)();
|
|
367
|
+
const packageManager2 = await (0, clack_1.getPackageManager)();
|
|
368
|
+
(0, vitest_1.expect)(detectPacManSpy).toHaveBeenCalledTimes(1);
|
|
369
|
+
(0, vitest_1.expect)(clackMock.select).toHaveBeenCalledTimes(1);
|
|
370
|
+
(0, vitest_1.expect)(packageManager1).toBe(package_manager_1.PNPM);
|
|
371
|
+
(0, vitest_1.expect)(packageManager2).toBe(package_manager_1.PNPM);
|
|
372
|
+
});
|
|
373
|
+
});
|
|
374
|
+
});
|
|
375
|
+
//# sourceMappingURL=index.test.js.map
|