@sentry/wizard 4.0.0 → 4.0.2
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 +11 -2
- package/dist/NextJs/configs/next.config.js +1 -1
- package/dist/bin.js +2 -1
- package/dist/bin.js.map +1 -1
- package/dist/bump-version.js +28 -0
- package/dist/craft-pre-release.sh +2 -0
- package/dist/lib/Steps/Initial.js +2 -12
- package/dist/lib/Steps/Initial.js.map +1 -1
- package/dist/lib/Steps/Integrations/Electron.js +1 -1
- package/dist/lib/Steps/Integrations/Electron.js.map +1 -1
- package/dist/src/nextjs/templates.js +1 -1
- package/dist/src/nextjs/templates.js.map +1 -1
- package/dist/src/run.js +2 -18
- package/dist/src/run.js.map +1 -1
- package/dist/src/telemetry.js +2 -16
- package/dist/src/telemetry.js.map +1 -1
- package/dist/src/utils/clack-utils.d.ts +16 -0
- package/dist/src/utils/clack-utils.js +53 -45
- package/dist/src/utils/clack-utils.js.map +1 -1
- package/dist/src/version.d.ts +1 -0
- package/dist/src/version.js +7 -0
- package/dist/src/version.js.map +1 -0
- package/dist/test/nextjs/templates.test.js +4 -4
- package/dist/test/nextjs/templates.test.js.map +1 -1
- package/dist/test/utils/clack-utils.test.js +52 -0
- package/dist/test/utils/clack-utils.test.js.map +1 -1
- package/package.json +5 -2
- package/.node-cache/node-v22.14.0-darwin-arm64 +0 -0
- package/.node-cache/node-v22.14.0-darwin-x64 +0 -0
- package/.node-cache/node-v22.14.0-linux-arm64 +0 -0
- package/.node-cache/node-v22.14.0-linux-x64 +0 -0
- package/.node-cache/node-v22.14.0-win-x64.exe +0 -0
- package/COPYING +0 -3575
- package/bin.ts +0 -143
- package/codecov.yml +0 -15
- package/e2e-tests/.env.example +0 -11
- package/e2e-tests/README.md +0 -63
- package/e2e-tests/jest.config.ts +0 -22
- package/e2e-tests/package.json +0 -14
- package/e2e-tests/run.sh +0 -15
- package/e2e-tests/test-applications/apple/damaged-missing-configuration-list/Project.xcodeproj/project.pbxproj +0 -52
- package/e2e-tests/test-applications/apple/damaged-missing-configuration-list/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
- package/e2e-tests/test-applications/apple/no-targets/Project.xcodeproj/project.pbxproj +0 -62
- package/e2e-tests/test-applications/apple/no-targets/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project.xcodeproj/project.pbxproj +0 -470
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project1/ContentView.swift +0 -7
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project1/Project1App.swift +0 -10
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project2/ContentView.swift +0 -7
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project2/Project2App.swift +0 -10
- package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Project.xcodeproj/project.pbxproj +0 -382
- package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Project.xcodeproj/xcshareddata/xcschemes/Project.xcscheme +0 -78
- package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Sources/ContentView.swift +0 -7
- package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Sources/MainApp.swift +0 -10
- package/e2e-tests/test-applications/flutter-test-app/.metadata +0 -45
- package/e2e-tests/test-applications/flutter-test-app/README.md +0 -16
- package/e2e-tests/test-applications/flutter-test-app/analysis_options.yaml +0 -28
- package/e2e-tests/test-applications/flutter-test-app/android/app/build.gradle +0 -44
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/debug/AndroidManifest.xml +0 -7
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/AndroidManifest.xml +0 -45
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/kotlin/com/example/flutter_magic/MainActivity.kt +0 -5
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/drawable/launch_background.xml +0 -12
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/drawable-v21/launch_background.xml +0 -12
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-hdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-mdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/values/styles.xml +0 -18
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/values-night/styles.xml +0 -18
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/profile/AndroidManifest.xml +0 -7
- package/e2e-tests/test-applications/flutter-test-app/android/build.gradle +0 -18
- package/e2e-tests/test-applications/flutter-test-app/android/gradle/wrapper/gradle-wrapper.properties +0 -5
- package/e2e-tests/test-applications/flutter-test-app/android/gradle.properties +0 -3
- package/e2e-tests/test-applications/flutter-test-app/android/settings.gradle +0 -25
- package/e2e-tests/test-applications/flutter-test-app/lib/main.dart +0 -125
- package/e2e-tests/test-applications/flutter-test-app/linux/CMakeLists.txt +0 -145
- package/e2e-tests/test-applications/flutter-test-app/linux/flutter/CMakeLists.txt +0 -88
- package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugin_registrant.cc +0 -11
- package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugin_registrant.h +0 -15
- package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugins.cmake +0 -23
- package/e2e-tests/test-applications/flutter-test-app/linux/main.cc +0 -6
- package/e2e-tests/test-applications/flutter-test-app/linux/my_application.cc +0 -124
- package/e2e-tests/test-applications/flutter-test-app/linux/my_application.h +0 -18
- package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/Flutter-Debug.xcconfig +0 -2
- package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/Flutter-Release.xcconfig +0 -2
- package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/GeneratedPluginRegistrant.swift +0 -10
- package/e2e-tests/test-applications/flutter-test-app/macos/Podfile +0 -43
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/AppDelegate.swift +0 -9
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json +0 -68
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Base.lproj/MainMenu.xib +0 -343
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/AppInfo.xcconfig +0 -14
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Debug.xcconfig +0 -2
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Release.xcconfig +0 -2
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Warnings.xcconfig +0 -13
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/DebugProfile.entitlements +0 -12
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Info.plist +0 -32
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/MainFlutterWindow.swift +0 -15
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Release.entitlements +0 -8
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/project.pbxproj +0 -705
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme +0 -98
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcworkspace/contents.xcworkspacedata +0 -7
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
- package/e2e-tests/test-applications/flutter-test-app/macos/RunnerTests/RunnerTests.swift +0 -12
- package/e2e-tests/test-applications/flutter-test-app/pubspec.lock +0 -213
- package/e2e-tests/test-applications/flutter-test-app/pubspec.yaml +0 -89
- package/e2e-tests/test-applications/flutter-test-app/test/widget_test.dart +0 -30
- package/e2e-tests/test-applications/flutter-test-app/web/favicon.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-192.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-512.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-maskable-192.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-maskable-512.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/index.html +0 -38
- package/e2e-tests/test-applications/flutter-test-app/web/manifest.json +0 -35
- package/e2e-tests/test-applications/flutter-test-app/windows/CMakeLists.txt +0 -108
- package/e2e-tests/test-applications/flutter-test-app/windows/flutter/CMakeLists.txt +0 -109
- package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugin_registrant.cc +0 -11
- package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugin_registrant.h +0 -15
- package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugins.cmake +0 -23
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/CMakeLists.txt +0 -40
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/Runner.rc +0 -121
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/flutter_window.cpp +0 -71
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/flutter_window.h +0 -33
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/main.cpp +0 -43
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/resource.h +0 -16
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/resources/app_icon.ico +0 -0
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/runner.exe.manifest +0 -14
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/utils.cpp +0 -65
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/utils.h +0 -19
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/win32_window.cpp +0 -288
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/win32_window.h +0 -102
- package/e2e-tests/test-applications/nextjs-test-app/next.config.mjs +0 -4
- package/e2e-tests/test-applications/nextjs-test-app/package.json +0 -22
- package/e2e-tests/test-applications/nextjs-test-app/src/app/layout.tsx +0 -20
- package/e2e-tests/test-applications/nextjs-test-app/src/app/page.tsx +0 -90
- package/e2e-tests/test-applications/nuxt-3-test-app/README.md +0 -75
- package/e2e-tests/test-applications/nuxt-3-test-app/nuxt.config.ts +0 -5
- package/e2e-tests/test-applications/nuxt-3-test-app/package.json +0 -18
- package/e2e-tests/test-applications/nuxt-3-test-app/public/favicon.ico +0 -0
- package/e2e-tests/test-applications/nuxt-3-test-app/public/robots.txt +0 -1
- package/e2e-tests/test-applications/nuxt-4-test-app/README.md +0 -75
- package/e2e-tests/test-applications/nuxt-4-test-app/nuxt.config.ts +0 -6
- package/e2e-tests/test-applications/nuxt-4-test-app/package.json +0 -18
- package/e2e-tests/test-applications/nuxt-4-test-app/public/favicon.ico +0 -0
- package/e2e-tests/test-applications/nuxt-4-test-app/public/robots.txt +0 -1
- package/e2e-tests/test-applications/remix-test-app/app/entry.client.tsx +0 -18
- package/e2e-tests/test-applications/remix-test-app/app/entry.server.tsx +0 -140
- package/e2e-tests/test-applications/remix-test-app/app/root.tsx +0 -30
- package/e2e-tests/test-applications/remix-test-app/app/routes/_index.tsx +0 -48
- package/e2e-tests/test-applications/remix-test-app/app/tailwind.css +0 -3
- package/e2e-tests/test-applications/remix-test-app/package.json +0 -37
- package/e2e-tests/test-applications/remix-test-app/postcss.config.js +0 -6
- package/e2e-tests/test-applications/remix-test-app/tailwind.config.ts +0 -9
- package/e2e-tests/test-applications/remix-test-app/vite.config.ts +0 -16
- package/e2e-tests/test-applications/sveltekit-test-app/package.json +0 -21
- package/e2e-tests/test-applications/sveltekit-test-app/src/app.d.ts +0 -13
- package/e2e-tests/test-applications/sveltekit-test-app/src/app.html +0 -11
- package/e2e-tests/test-applications/sveltekit-test-app/src/lib/index.ts +0 -1
- package/e2e-tests/test-applications/sveltekit-test-app/src/routes/+page.svelte +0 -2
- package/e2e-tests/test-applications/sveltekit-test-app/svelte.config.js +0 -18
- package/e2e-tests/test-applications/sveltekit-test-app/vite.config.ts +0 -6
- package/e2e-tests/tests/flutter.test.ts +0 -127
- package/e2e-tests/tests/nextjs.test.ts +0 -161
- package/e2e-tests/tests/nuxt-3.test.ts +0 -189
- package/e2e-tests/tests/nuxt-4.test.ts +0 -188
- package/e2e-tests/tests/remix.test.ts +0 -277
- package/e2e-tests/tests/sveltekit.test.ts +0 -284
- package/e2e-tests/utils/index.ts +0 -456
- package/index.ts +0 -2
- package/lib/Constants.ts +0 -118
- package/lib/Helper/BottomBar.ts +0 -28
- package/lib/Helper/Env.ts +0 -7
- package/lib/Helper/File.ts +0 -65
- package/lib/Helper/Git.ts +0 -39
- package/lib/Helper/Logging.ts +0 -44
- package/lib/Helper/MergeConfig.ts +0 -19
- package/lib/Helper/Package.ts +0 -80
- package/lib/Helper/SentryCli.ts +0 -139
- package/lib/Helper/Wizard.ts +0 -58
- package/lib/Helper/__tests__/File.ts +0 -15
- package/lib/Helper/__tests__/MergeConfig.ts +0 -98
- package/lib/Helper/__tests__/SentryCli.ts +0 -86
- package/lib/Helper/test-fixtures/next.config.1-merged.js +0 -18
- package/lib/Helper/test-fixtures/next.config.1.js +0 -6
- package/lib/Helper/test-fixtures/next.config.2.js +0 -8
- package/lib/Helper/test-fixtures/next.config.3-merged.js +0 -21
- package/lib/Helper/test-fixtures/next.config.3.js +0 -9
- package/lib/Helper/test-fixtures/next.config.4-merged.js +0 -21
- package/lib/Helper/test-fixtures/next.config.4.js +0 -9
- package/lib/Setup.ts +0 -40
- package/lib/Steps/BaseStep.ts +0 -25
- package/lib/Steps/ChooseIntegration.ts +0 -144
- package/lib/Steps/ConfigureProject.ts +0 -10
- package/lib/Steps/Initial.ts +0 -35
- package/lib/Steps/Integrations/BaseIntegration.ts +0 -42
- package/lib/Steps/Integrations/Cordova.ts +0 -283
- package/lib/Steps/Integrations/Electron.ts +0 -164
- package/lib/Steps/Integrations/MobileProject.ts +0 -72
- package/lib/Steps/OpenSentry.ts +0 -80
- package/lib/Steps/PromptForParameters.ts +0 -200
- package/lib/Steps/Result.ts +0 -22
- package/lib/Steps/SentryProjectSelector.ts +0 -83
- package/lib/Steps/ShouldConfigure.ts +0 -10
- package/lib/Steps/WaitForSentry.ts +0 -56
- package/lib/Steps/Welcome.ts +0 -21
- package/lib/Steps/index.ts +0 -10
- package/lib/__tests__/Env.ts +0 -29
- package/scripts/NextJs/configs/_error.js +0 -39
- package/scripts/NextJs/configs/next.config.js +0 -36
- package/scripts/NextJs/configs/next.config.template.js +0 -12
- package/scripts/NextJs/configs/sentry.client.config.js +0 -17
- package/scripts/NextJs/configs/sentry.edge.config.js +0 -17
- package/scripts/NextJs/configs/sentry.server.config.js +0 -17
- package/scripts/NextJs/sentry_sample_error.js +0 -47
- package/scripts/craft-pre-release.sh +0 -10
- package/src/android/android-wizard.ts +0 -192
- package/src/android/code-tools.ts +0 -170
- package/src/android/gradle.ts +0 -250
- package/src/android/manifest.ts +0 -180
- package/src/android/templates.ts +0 -86
- package/src/apple/apple-wizard.ts +0 -269
- package/src/apple/cocoapod.ts +0 -73
- package/src/apple/code-tools.ts +0 -147
- package/src/apple/fastlane.ts +0 -170
- package/src/apple/templates.ts +0 -65
- package/src/apple/xcode-manager.ts +0 -404
- package/src/flutter/code-tools.ts +0 -284
- package/src/flutter/flutter-wizard.ts +0 -164
- package/src/flutter/templates.ts +0 -90
- package/src/nextjs/nextjs-wizard.ts +0 -1007
- package/src/nextjs/templates.ts +0 -525
- package/src/nextjs/utils.ts +0 -21
- package/src/nuxt/nuxt-wizard.ts +0 -188
- package/src/nuxt/sdk-example.ts +0 -135
- package/src/nuxt/sdk-setup.ts +0 -352
- package/src/nuxt/templates.ts +0 -303
- package/src/nuxt/types.ts +0 -8
- package/src/nuxt/utils.ts +0 -42
- package/src/react-native/expo-env-file.ts +0 -55
- package/src/react-native/expo-metro.ts +0 -212
- package/src/react-native/expo.ts +0 -175
- package/src/react-native/git.ts +0 -25
- package/src/react-native/glob.ts +0 -13
- package/src/react-native/gradle.ts +0 -26
- package/src/react-native/javascript.ts +0 -103
- package/src/react-native/metro.ts +0 -599
- package/src/react-native/options.ts +0 -5
- package/src/react-native/react-native-wizard.ts +0 -512
- package/src/react-native/uninstall.ts +0 -109
- package/src/react-native/xcode.ts +0 -302
- package/src/remix/codemods/express-server.ts +0 -44
- package/src/remix/codemods/handle-error.ts +0 -118
- package/src/remix/codemods/root-common.ts +0 -63
- package/src/remix/codemods/root-v1.ts +0 -41
- package/src/remix/codemods/root-v2.ts +0 -153
- package/src/remix/remix-wizard.ts +0 -261
- package/src/remix/sdk-example.ts +0 -120
- package/src/remix/sdk-setup.ts +0 -546
- package/src/remix/templates.ts +0 -11
- package/src/remix/utils.ts +0 -96
- package/src/run.ts +0 -211
- package/src/sourcemaps/sourcemaps-wizard.ts +0 -364
- package/src/sourcemaps/tools/angular.ts +0 -42
- package/src/sourcemaps/tools/create-react-app.ts +0 -19
- package/src/sourcemaps/tools/esbuild.ts +0 -65
- package/src/sourcemaps/tools/nextjs.ts +0 -114
- package/src/sourcemaps/tools/remix.ts +0 -90
- package/src/sourcemaps/tools/rollup.ts +0 -67
- package/src/sourcemaps/tools/sentry-cli.ts +0 -287
- package/src/sourcemaps/tools/tsc.ts +0 -144
- package/src/sourcemaps/tools/types.ts +0 -11
- package/src/sourcemaps/tools/vite.ts +0 -300
- package/src/sourcemaps/tools/webpack.ts +0 -383
- package/src/sourcemaps/utils/detect-tool.ts +0 -46
- package/src/sourcemaps/utils/other-wizards.ts +0 -167
- package/src/sourcemaps/utils/sdk-version.ts +0 -266
- package/src/sveltekit/sdk-example.ts +0 -56
- package/src/sveltekit/sdk-setup.ts +0 -667
- package/src/sveltekit/sveltekit-wizard.ts +0 -192
- package/src/sveltekit/templates.ts +0 -185
- package/src/sveltekit/utils.ts +0 -50
- package/src/telemetry.ts +0 -144
- package/src/utils/ast-utils.ts +0 -270
- package/src/utils/bash.ts +0 -57
- package/src/utils/clack-utils.ts +0 -1536
- package/src/utils/debug.ts +0 -20
- package/src/utils/package-json.ts +0 -51
- package/src/utils/package-manager.ts +0 -172
- package/src/utils/release-registry.ts +0 -19
- package/src/utils/semver.ts +0 -33
- package/src/utils/sentrycli-utils.ts +0 -24
- package/src/utils/string.ts +0 -7
- package/src/utils/types.ts +0 -77
- package/src/utils/url.ts +0 -27
- package/src/utils/vendor/is-unicorn-supported.ts +0 -29
- package/test/android/code-tools.test.ts +0 -49
- package/test/apple/cocoapod.test.ts +0 -310
- package/test/apple/code-tools.test.ts +0 -1042
- package/test/apple/fastfile.test.ts +0 -555
- package/test/apple/templates.test.ts +0 -191
- package/test/apple/xcode-manager.test.ts +0 -1068
- package/test/flutter/code-tools.test.ts +0 -212
- package/test/flutter/templates.test.ts +0 -100
- package/test/nextjs/templates.test.ts +0 -429
- package/test/nuxt/templates.test.ts +0 -255
- package/test/react-native/expo-metro.test.ts +0 -81
- package/test/react-native/expo.test.ts +0 -86
- package/test/react-native/gradle.test.ts +0 -310
- package/test/react-native/javascript.test.ts +0 -134
- package/test/react-native/metro.test.ts +0 -396
- package/test/react-native/xcode.test.ts +0 -401
- package/test/remix/client-entry.test.ts +0 -122
- package/test/remix/server-instrumentation.test.ts +0 -36
- package/test/sourcemaps/tools/sentry-cli.test.ts +0 -57
- package/test/sourcemaps/tools/tsc.test.ts +0 -181
- package/test/sourcemaps/tools/vite.test.ts +0 -149
- package/test/sourcemaps/tools/webpack.test.ts +0 -303
- package/test/sveltekit/templates.test.ts +0 -152
- package/test/utils/ast-utils.test.ts +0 -264
- package/test/utils/clack-utils.test.ts +0 -224
- package/types/read-env.d.ts +0 -3
- package/types/xcode.d.ts +0 -527
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
/* eslint-disable jest/expect-expect */
|
|
2
|
-
import * as path from 'node:path';
|
|
3
|
-
import { Integration } from '../../lib/Constants';
|
|
4
|
-
import {
|
|
5
|
-
KEYS,
|
|
6
|
-
checkEnvBuildPlugin,
|
|
7
|
-
cleanupGit,
|
|
8
|
-
revertLocalChanges,
|
|
9
|
-
} from '../utils';
|
|
10
|
-
import { startWizardInstance } from '../utils';
|
|
11
|
-
import {
|
|
12
|
-
checkFileContents,
|
|
13
|
-
checkFileExists,
|
|
14
|
-
checkIfBuilds,
|
|
15
|
-
checkIfRunsOnDevMode,
|
|
16
|
-
checkIfRunsOnProdMode,
|
|
17
|
-
checkPackageJson,
|
|
18
|
-
} from '../utils';
|
|
19
|
-
|
|
20
|
-
describe('NextJS', () => {
|
|
21
|
-
const integration = Integration.nextjs;
|
|
22
|
-
const projectDir = path.resolve(
|
|
23
|
-
__dirname,
|
|
24
|
-
'../test-applications/nextjs-test-app',
|
|
25
|
-
);
|
|
26
|
-
|
|
27
|
-
beforeAll(async () => {
|
|
28
|
-
const wizardInstance = startWizardInstance(integration, projectDir);
|
|
29
|
-
const packageManagerPrompted = await wizardInstance.waitForOutput(
|
|
30
|
-
'Please select your package manager.',
|
|
31
|
-
);
|
|
32
|
-
|
|
33
|
-
const routeThroughNextJsPrompted =
|
|
34
|
-
packageManagerPrompted &&
|
|
35
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
36
|
-
// Selecting `yarn` as the package manager
|
|
37
|
-
[KEYS.DOWN, KEYS.ENTER],
|
|
38
|
-
'Do you want to route Sentry requests in the browser through your Next.js server',
|
|
39
|
-
{
|
|
40
|
-
timeout: 240_000,
|
|
41
|
-
},
|
|
42
|
-
));
|
|
43
|
-
|
|
44
|
-
const reactComponentAnnotationsPrompted =
|
|
45
|
-
routeThroughNextJsPrompted &&
|
|
46
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
47
|
-
[KEYS.ENTER],
|
|
48
|
-
'Do you want to enable React component annotations',
|
|
49
|
-
));
|
|
50
|
-
|
|
51
|
-
const tracingOptionPrompted =
|
|
52
|
-
reactComponentAnnotationsPrompted &&
|
|
53
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
54
|
-
[KEYS.ENTER],
|
|
55
|
-
// "Do you want to enable Tracing", sometimes doesn't work as `Tracing` can be printed in bold.
|
|
56
|
-
'to track the performance of your application?',
|
|
57
|
-
));
|
|
58
|
-
|
|
59
|
-
const replayOptionPrompted =
|
|
60
|
-
tracingOptionPrompted &&
|
|
61
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
62
|
-
[KEYS.ENTER],
|
|
63
|
-
// "Do you want to enable Sentry Session Replay", sometimes doesn't work as `Sentry Session Replay` can be printed in bold.
|
|
64
|
-
'to get a video-like reproduction of errors during a user session?',
|
|
65
|
-
));
|
|
66
|
-
|
|
67
|
-
const examplePagePrompted =
|
|
68
|
-
replayOptionPrompted &&
|
|
69
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
70
|
-
[KEYS.ENTER],
|
|
71
|
-
'Do you want to create an example page',
|
|
72
|
-
{
|
|
73
|
-
optional: true,
|
|
74
|
-
},
|
|
75
|
-
));
|
|
76
|
-
|
|
77
|
-
const ciCdPrompted =
|
|
78
|
-
examplePagePrompted &&
|
|
79
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
80
|
-
[KEYS.ENTER],
|
|
81
|
-
'Are you using a CI/CD tool',
|
|
82
|
-
));
|
|
83
|
-
|
|
84
|
-
ciCdPrompted &&
|
|
85
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
86
|
-
// Selecting `No` for CI/CD tool
|
|
87
|
-
[KEYS.DOWN, KEYS.ENTER],
|
|
88
|
-
'Successfully installed the Sentry Next.js SDK!',
|
|
89
|
-
));
|
|
90
|
-
|
|
91
|
-
wizardInstance.kill();
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
afterAll(() => {
|
|
95
|
-
revertLocalChanges(projectDir);
|
|
96
|
-
cleanupGit(projectDir);
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
test('package.json is updated correctly', () => {
|
|
100
|
-
checkPackageJson(projectDir, integration);
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
test('.env-sentry-build-plugin is created and contains the auth token', () => {
|
|
104
|
-
checkEnvBuildPlugin(projectDir);
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
test('example page exists', () => {
|
|
108
|
-
checkFileExists(`${projectDir}/src/app/sentry-example-page/page.tsx`);
|
|
109
|
-
checkFileExists(`${projectDir}/src/app/api/sentry-example-api/route.ts`);
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
test('config files created', () => {
|
|
113
|
-
checkFileExists(`${projectDir}/sentry.server.config.ts`);
|
|
114
|
-
checkFileExists(`${projectDir}/sentry.client.config.ts`);
|
|
115
|
-
checkFileExists(`${projectDir}/sentry.edge.config.ts`);
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
test('global error file exists', () => {
|
|
119
|
-
checkFileExists(`${projectDir}/src/app/global-error.tsx`);
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
test('instrumentation file exists', () => {
|
|
123
|
-
checkFileExists(`${projectDir}/src/instrumentation.ts`);
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
test('instrumentation file contains Sentry initialization', () => {
|
|
127
|
-
checkFileContents(`${projectDir}/src/instrumentation.ts`, [
|
|
128
|
-
"import * as Sentry from '@sentry/nextjs';",
|
|
129
|
-
`export async function register() {
|
|
130
|
-
if (process.env.NEXT_RUNTIME === 'nodejs') {
|
|
131
|
-
await import('../sentry.server.config');
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
if (process.env.NEXT_RUNTIME === 'edge') {
|
|
135
|
-
await import('../sentry.edge.config');
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
export const onRequestError = Sentry.captureRequestError;`,
|
|
140
|
-
]);
|
|
141
|
-
});
|
|
142
|
-
|
|
143
|
-
test('next.config file contains Sentry wrapper', () => {
|
|
144
|
-
checkFileContents(`${projectDir}/next.config.mjs`, [
|
|
145
|
-
"import {withSentryConfig} from '@sentry/nextjs'",
|
|
146
|
-
'export default withSentryConfig(nextConfig, {',
|
|
147
|
-
]);
|
|
148
|
-
});
|
|
149
|
-
|
|
150
|
-
test('runs on dev mode correctly', async () => {
|
|
151
|
-
await checkIfRunsOnDevMode(projectDir, 'Ready in');
|
|
152
|
-
});
|
|
153
|
-
|
|
154
|
-
test('builds correctly', async () => {
|
|
155
|
-
await checkIfBuilds(projectDir);
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
test('runs on prod mode correctly', async () => {
|
|
159
|
-
await checkIfRunsOnProdMode(projectDir, 'Ready in');
|
|
160
|
-
});
|
|
161
|
-
});
|
|
@@ -1,189 +0,0 @@
|
|
|
1
|
-
import * as path from 'node:path';
|
|
2
|
-
import { Integration } from '../../lib/Constants';
|
|
3
|
-
import {
|
|
4
|
-
KEYS,
|
|
5
|
-
TEST_ARGS,
|
|
6
|
-
checkEnvBuildPlugin,
|
|
7
|
-
checkFileContents,
|
|
8
|
-
checkFileExists,
|
|
9
|
-
checkIfBuilds,
|
|
10
|
-
checkIfRunsOnProdMode,
|
|
11
|
-
checkPackageJson,
|
|
12
|
-
cleanupGit,
|
|
13
|
-
revertLocalChanges,
|
|
14
|
-
startWizardInstance,
|
|
15
|
-
} from '../utils';
|
|
16
|
-
|
|
17
|
-
describe('Nuxt-3', () => {
|
|
18
|
-
const projectDir = path.resolve(
|
|
19
|
-
__dirname,
|
|
20
|
-
'../test-applications/nuxt-3-test-app',
|
|
21
|
-
);
|
|
22
|
-
|
|
23
|
-
beforeAll(async () => {
|
|
24
|
-
await runWizardOnNuxtProject(projectDir);
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
afterAll(() => {
|
|
28
|
-
revertLocalChanges(projectDir);
|
|
29
|
-
cleanupGit(projectDir);
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
testNuxtProjectSetup(projectDir);
|
|
33
|
-
|
|
34
|
-
testNuxtProjectConfigs(projectDir);
|
|
35
|
-
|
|
36
|
-
testNuxtProjectBuildsAndRuns(projectDir);
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
async function runWizardOnNuxtProject(projectDir: string): Promise<void> {
|
|
40
|
-
const integration = Integration.nuxt;
|
|
41
|
-
|
|
42
|
-
const wizardInstance = startWizardInstance(integration, projectDir);
|
|
43
|
-
const packageManagerPrompted = await wizardInstance.waitForOutput(
|
|
44
|
-
'Please select your package manager.',
|
|
45
|
-
);
|
|
46
|
-
|
|
47
|
-
const nftOverridePrompted =
|
|
48
|
-
packageManagerPrompted &&
|
|
49
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
50
|
-
// Selecting `yarn` as the package manager
|
|
51
|
-
[KEYS.DOWN, KEYS.ENTER],
|
|
52
|
-
'Do you want to add an override for @vercel/nft version ^0.27.4?',
|
|
53
|
-
{
|
|
54
|
-
timeout: 240_000,
|
|
55
|
-
},
|
|
56
|
-
));
|
|
57
|
-
|
|
58
|
-
const deploymentPlatformPrompted =
|
|
59
|
-
nftOverridePrompted &&
|
|
60
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
61
|
-
KEYS.ENTER,
|
|
62
|
-
'Please select your deployment platform.',
|
|
63
|
-
{
|
|
64
|
-
timeout: 240_000,
|
|
65
|
-
},
|
|
66
|
-
));
|
|
67
|
-
|
|
68
|
-
const tracingOptionPrompted =
|
|
69
|
-
deploymentPlatformPrompted &&
|
|
70
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
71
|
-
KEYS.ENTER,
|
|
72
|
-
// "Do you want to enable Tracing", sometimes doesn't work as `Tracing` can be printed in bold.
|
|
73
|
-
'Do you want to enable',
|
|
74
|
-
{
|
|
75
|
-
timeout: 240_000,
|
|
76
|
-
},
|
|
77
|
-
));
|
|
78
|
-
|
|
79
|
-
const replayOptionPrompted =
|
|
80
|
-
tracingOptionPrompted &&
|
|
81
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
82
|
-
KEYS.ENTER,
|
|
83
|
-
// "Do you want to enable Sentry Session Replay", sometimes doesn't work as `Sentry Session Replay` can be printed in bold.
|
|
84
|
-
'to get a video-like reproduction of errors during a user session?',
|
|
85
|
-
));
|
|
86
|
-
|
|
87
|
-
replayOptionPrompted &&
|
|
88
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
89
|
-
[KEYS.ENTER],
|
|
90
|
-
'Do you want to create an example page',
|
|
91
|
-
{
|
|
92
|
-
optional: true,
|
|
93
|
-
},
|
|
94
|
-
));
|
|
95
|
-
|
|
96
|
-
await wizardInstance.sendStdinAndWaitForOutput(
|
|
97
|
-
[KEYS.ENTER, KEYS.ENTER],
|
|
98
|
-
'Successfully installed the Sentry Nuxt SDK!',
|
|
99
|
-
);
|
|
100
|
-
|
|
101
|
-
wizardInstance.kill();
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
function testNuxtProjectSetup(projectDir: string) {
|
|
105
|
-
const integration = Integration.nuxt;
|
|
106
|
-
|
|
107
|
-
test('package.json is updated correctly', () => {
|
|
108
|
-
checkPackageJson(projectDir, integration);
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
test('.env-sentry-build-plugin is created and contains the auth token', () => {
|
|
112
|
-
checkEnvBuildPlugin(projectDir);
|
|
113
|
-
});
|
|
114
|
-
|
|
115
|
-
test('config files created', () => {
|
|
116
|
-
checkFileExists(`${projectDir}/sentry.server.config.ts`);
|
|
117
|
-
checkFileExists(`${projectDir}/sentry.client.config.ts`);
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
test('example page exists', () => {
|
|
121
|
-
checkFileExists(`${projectDir}/pages/sentry-example-page.vue`);
|
|
122
|
-
checkFileExists(`${projectDir}/server/api/sentry-example-api.ts`);
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
function testNuxtProjectConfigs(projectDir: string) {
|
|
127
|
-
test('nuxt config contains sentry module', () => {
|
|
128
|
-
checkFileContents(path.resolve(projectDir, 'nuxt.config.ts'), [
|
|
129
|
-
"modules: ['@sentry/nuxt/module'],",
|
|
130
|
-
'sentry: {',
|
|
131
|
-
' sourceMapsUploadOptions: {',
|
|
132
|
-
` org: '${TEST_ARGS.ORG_SLUG}',`,
|
|
133
|
-
` project: '${TEST_ARGS.PROJECT_SLUG}'`,
|
|
134
|
-
' }',
|
|
135
|
-
'},',
|
|
136
|
-
'sourcemap: {',
|
|
137
|
-
" client: 'hidden'",
|
|
138
|
-
'}',
|
|
139
|
-
]);
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
test('sentry.client.config.ts contents', () => {
|
|
143
|
-
checkFileContents(path.resolve(projectDir, 'sentry.client.config.ts'), [
|
|
144
|
-
'import * as Sentry from "@sentry/nuxt";',
|
|
145
|
-
'Sentry.init({',
|
|
146
|
-
' // If set up, you can use your runtime config here',
|
|
147
|
-
' // dsn: useRuntimeConfig().public.sentry.dsn,',
|
|
148
|
-
` dsn: "${TEST_ARGS.PROJECT_DSN}",`,
|
|
149
|
-
' // We recommend adjusting this value in production, or using tracesSampler',
|
|
150
|
-
' // for finer control',
|
|
151
|
-
' tracesSampleRate: 1.0,',
|
|
152
|
-
' // This sets the sample rate to be 10%. You may want this to be 100% while',
|
|
153
|
-
' // in development and sample at a lower rate in production',
|
|
154
|
-
' replaysSessionSampleRate: 0.1,',
|
|
155
|
-
' // If the entire session is not sampled, use the below sample rate to sample',
|
|
156
|
-
' // sessions when an error occurs.',
|
|
157
|
-
' replaysOnErrorSampleRate: 1.0,',
|
|
158
|
-
" // If you don't want to use Session Replay, just remove the line below:",
|
|
159
|
-
' integrations: [Sentry.replayIntegration()],',
|
|
160
|
-
" // Setting this option to true will print useful information to the console while you're setting up Sentry.",
|
|
161
|
-
' debug: false,',
|
|
162
|
-
'});',
|
|
163
|
-
]);
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
test('sentry.server.config.ts contents', () => {
|
|
167
|
-
checkFileContents(path.resolve(projectDir, 'sentry.server.config.ts'), [
|
|
168
|
-
'import * as Sentry from "@sentry/nuxt";',
|
|
169
|
-
'Sentry.init({',
|
|
170
|
-
` dsn: "${TEST_ARGS.PROJECT_DSN}",`,
|
|
171
|
-
' // We recommend adjusting this value in production, or using tracesSampler',
|
|
172
|
-
' // for finer control',
|
|
173
|
-
' tracesSampleRate: 1.0,',
|
|
174
|
-
" // Setting this option to true will print useful information to the console while you're setting up Sentry.",
|
|
175
|
-
' debug: false,',
|
|
176
|
-
'});',
|
|
177
|
-
]);
|
|
178
|
-
});
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
function testNuxtProjectBuildsAndRuns(projectDir: string) {
|
|
182
|
-
test('builds successfully', async () => {
|
|
183
|
-
await checkIfBuilds(projectDir);
|
|
184
|
-
});
|
|
185
|
-
|
|
186
|
-
test('runs on prod mode correctly', async () => {
|
|
187
|
-
await checkIfRunsOnProdMode(projectDir, 'Listening on');
|
|
188
|
-
});
|
|
189
|
-
}
|
|
@@ -1,188 +0,0 @@
|
|
|
1
|
-
import * as path from 'node:path';
|
|
2
|
-
import { Integration } from '../../lib/Constants';
|
|
3
|
-
import { cleanupGit, revertLocalChanges } from '../utils';
|
|
4
|
-
import {
|
|
5
|
-
KEYS,
|
|
6
|
-
TEST_ARGS,
|
|
7
|
-
checkEnvBuildPlugin,
|
|
8
|
-
checkFileContents,
|
|
9
|
-
checkFileExists,
|
|
10
|
-
checkIfBuilds,
|
|
11
|
-
checkIfRunsOnProdMode,
|
|
12
|
-
checkPackageJson,
|
|
13
|
-
startWizardInstance,
|
|
14
|
-
} from '../utils';
|
|
15
|
-
|
|
16
|
-
describe('Nuxt-4', () => {
|
|
17
|
-
const projectDir = path.resolve(
|
|
18
|
-
__dirname,
|
|
19
|
-
'../test-applications/nuxt-4-test-app',
|
|
20
|
-
);
|
|
21
|
-
|
|
22
|
-
beforeAll(async () => {
|
|
23
|
-
await runWizardOnNuxtProject(projectDir);
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
afterAll(() => {
|
|
27
|
-
revertLocalChanges(projectDir);
|
|
28
|
-
cleanupGit(projectDir);
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
testNuxtProjectSetup(projectDir);
|
|
32
|
-
|
|
33
|
-
testNuxtProjectConfigs(projectDir);
|
|
34
|
-
|
|
35
|
-
testNuxtProjectBuildsAndRuns(projectDir);
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
async function runWizardOnNuxtProject(projectDir: string): Promise<void> {
|
|
39
|
-
const integration = Integration.nuxt;
|
|
40
|
-
|
|
41
|
-
const wizardInstance = startWizardInstance(integration, projectDir);
|
|
42
|
-
const packageManagerPrompted = await wizardInstance.waitForOutput(
|
|
43
|
-
'Please select your package manager.',
|
|
44
|
-
);
|
|
45
|
-
|
|
46
|
-
const nftOverridePrompted =
|
|
47
|
-
packageManagerPrompted &&
|
|
48
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
49
|
-
// Selecting `yarn` as the package manager
|
|
50
|
-
[KEYS.DOWN, KEYS.ENTER],
|
|
51
|
-
'Do you want to add an override for @vercel/nft version ^0.27.4?',
|
|
52
|
-
{
|
|
53
|
-
timeout: 240_000,
|
|
54
|
-
},
|
|
55
|
-
));
|
|
56
|
-
|
|
57
|
-
const deploymentPlatformPrompted =
|
|
58
|
-
nftOverridePrompted &&
|
|
59
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
60
|
-
KEYS.ENTER,
|
|
61
|
-
'Please select your deployment platform.',
|
|
62
|
-
{
|
|
63
|
-
timeout: 240_000,
|
|
64
|
-
},
|
|
65
|
-
));
|
|
66
|
-
|
|
67
|
-
const tracingOptionPrompted =
|
|
68
|
-
deploymentPlatformPrompted &&
|
|
69
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
70
|
-
KEYS.ENTER,
|
|
71
|
-
// "Do you want to enable Tracing", sometimes doesn't work as `Tracing` can be printed in bold.
|
|
72
|
-
'Do you want to enable',
|
|
73
|
-
{
|
|
74
|
-
timeout: 240_000,
|
|
75
|
-
},
|
|
76
|
-
));
|
|
77
|
-
|
|
78
|
-
const replayOptionPrompted =
|
|
79
|
-
tracingOptionPrompted &&
|
|
80
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
81
|
-
[KEYS.ENTER],
|
|
82
|
-
// "Do you want to enable Sentry Session Replay", sometimes doesn't work as `Sentry Session Replay` can be printed in bold.
|
|
83
|
-
'to get a video-like reproduction of errors during a user session?',
|
|
84
|
-
));
|
|
85
|
-
|
|
86
|
-
replayOptionPrompted &&
|
|
87
|
-
(await wizardInstance.sendStdinAndWaitForOutput(
|
|
88
|
-
[KEYS.ENTER],
|
|
89
|
-
'Do you want to create an example page',
|
|
90
|
-
{
|
|
91
|
-
optional: true,
|
|
92
|
-
},
|
|
93
|
-
));
|
|
94
|
-
|
|
95
|
-
await wizardInstance.sendStdinAndWaitForOutput(
|
|
96
|
-
[KEYS.ENTER, KEYS.ENTER],
|
|
97
|
-
'Successfully installed the Sentry Nuxt SDK!',
|
|
98
|
-
);
|
|
99
|
-
|
|
100
|
-
wizardInstance.kill();
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
function testNuxtProjectSetup(projectDir: string) {
|
|
104
|
-
const integration = Integration.nuxt;
|
|
105
|
-
|
|
106
|
-
test('package.json is updated correctly', () => {
|
|
107
|
-
checkPackageJson(projectDir, integration);
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
test('.env-sentry-build-plugin is created and contains the auth token', () => {
|
|
111
|
-
checkEnvBuildPlugin(projectDir);
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
test('config files created', () => {
|
|
115
|
-
checkFileExists(`${projectDir}/sentry.server.config.ts`);
|
|
116
|
-
checkFileExists(`${projectDir}/sentry.client.config.ts`);
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
test('example page exists', () => {
|
|
120
|
-
checkFileExists(`${projectDir}/app/pages/sentry-example-page.vue`);
|
|
121
|
-
checkFileExists(`${projectDir}/server/api/sentry-example-api.ts`);
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
function testNuxtProjectConfigs(projectDir: string) {
|
|
126
|
-
test('nuxt config contains sentry module', () => {
|
|
127
|
-
checkFileContents(path.resolve(projectDir, 'nuxt.config.ts'), [
|
|
128
|
-
"modules: ['@sentry/nuxt/module'],",
|
|
129
|
-
'sentry: {',
|
|
130
|
-
' sourceMapsUploadOptions: {',
|
|
131
|
-
` org: '${TEST_ARGS.ORG_SLUG}',`,
|
|
132
|
-
` project: '${TEST_ARGS.PROJECT_SLUG}'`,
|
|
133
|
-
' }',
|
|
134
|
-
'},',
|
|
135
|
-
'sourcemap: {',
|
|
136
|
-
" client: 'hidden'",
|
|
137
|
-
'}',
|
|
138
|
-
]);
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
test('sentry.client.config.ts contents', () => {
|
|
142
|
-
checkFileContents(path.resolve(projectDir, 'sentry.client.config.ts'), [
|
|
143
|
-
'import * as Sentry from "@sentry/nuxt";',
|
|
144
|
-
'Sentry.init({',
|
|
145
|
-
' // If set up, you can use your runtime config here',
|
|
146
|
-
' // dsn: useRuntimeConfig().public.sentry.dsn,',
|
|
147
|
-
` dsn: "${TEST_ARGS.PROJECT_DSN}",`,
|
|
148
|
-
' // We recommend adjusting this value in production, or using tracesSampler',
|
|
149
|
-
' // for finer control',
|
|
150
|
-
' tracesSampleRate: 1.0,',
|
|
151
|
-
' // This sets the sample rate to be 10%. You may want this to be 100% while',
|
|
152
|
-
' // in development and sample at a lower rate in production',
|
|
153
|
-
' replaysSessionSampleRate: 0.1,',
|
|
154
|
-
' // If the entire session is not sampled, use the below sample rate to sample',
|
|
155
|
-
' // sessions when an error occurs.',
|
|
156
|
-
' replaysOnErrorSampleRate: 1.0,',
|
|
157
|
-
" // If you don't want to use Session Replay, just remove the line below:",
|
|
158
|
-
' integrations: [Sentry.replayIntegration()],',
|
|
159
|
-
" // Setting this option to true will print useful information to the console while you're setting up Sentry.",
|
|
160
|
-
' debug: false,',
|
|
161
|
-
'});',
|
|
162
|
-
]);
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
test('sentry.server.config.ts contents', () => {
|
|
166
|
-
checkFileContents(path.resolve(projectDir, 'sentry.server.config.ts'), [
|
|
167
|
-
'import * as Sentry from "@sentry/nuxt";',
|
|
168
|
-
'Sentry.init({',
|
|
169
|
-
` dsn: "${TEST_ARGS.PROJECT_DSN}",`,
|
|
170
|
-
' // We recommend adjusting this value in production, or using tracesSampler',
|
|
171
|
-
' // for finer control',
|
|
172
|
-
' tracesSampleRate: 1.0,',
|
|
173
|
-
" // Setting this option to true will print useful information to the console while you're setting up Sentry.",
|
|
174
|
-
' debug: false,',
|
|
175
|
-
'});',
|
|
176
|
-
]);
|
|
177
|
-
});
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
function testNuxtProjectBuildsAndRuns(projectDir: string) {
|
|
181
|
-
test('builds successfully', async () => {
|
|
182
|
-
await checkIfBuilds(projectDir);
|
|
183
|
-
});
|
|
184
|
-
|
|
185
|
-
test('runs on prod mode correctly', async () => {
|
|
186
|
-
await checkIfRunsOnProdMode(projectDir, 'Listening on');
|
|
187
|
-
});
|
|
188
|
-
}
|