@sentry/wizard 4.0.0 → 4.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -2
- package/dist/lib/Steps/Integrations/Electron.js +1 -1
- package/dist/lib/Steps/Integrations/Electron.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
package/lib/Helper/Logging.ts
DELETED
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import Chalk from 'chalk';
|
|
2
|
-
|
|
3
|
-
export function prepareMessage(msg: unknown): string {
|
|
4
|
-
if (typeof msg === 'string') {
|
|
5
|
-
return msg;
|
|
6
|
-
}
|
|
7
|
-
if (msg instanceof Error) {
|
|
8
|
-
return `${msg.stack || ''}`;
|
|
9
|
-
}
|
|
10
|
-
return JSON.stringify(msg, null, '\t');
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export function l(msg: string): void {
|
|
14
|
-
// eslint-disable-next-line no-console
|
|
15
|
-
console.log(msg);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export function nl(): void {
|
|
19
|
-
return l('');
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export function green(msg: string): void {
|
|
23
|
-
return l(Chalk.green(prepareMessage(msg)));
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
export function red(msg: string): void {
|
|
27
|
-
return l(Chalk.red(prepareMessage(msg)));
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
export function dim(msg: string): void {
|
|
31
|
-
return l(Chalk.dim(prepareMessage(msg)));
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
export function yellow(msg: string): void {
|
|
35
|
-
return l(Chalk.yellow(prepareMessage(msg)));
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
export function cyan(msg: string): void {
|
|
39
|
-
return l(Chalk.cyan(prepareMessage(msg)));
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
export function debug(msg: any): void {
|
|
43
|
-
return l(Chalk.italic.yellow(prepareMessage(msg)));
|
|
44
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs';
|
|
2
|
-
|
|
3
|
-
// merges the config files
|
|
4
|
-
export function mergeConfigFile(
|
|
5
|
-
sourcePath: string,
|
|
6
|
-
templatePath: string,
|
|
7
|
-
): boolean {
|
|
8
|
-
try {
|
|
9
|
-
const templateFile = fs.readFileSync(templatePath, 'utf8');
|
|
10
|
-
const sourceFile = fs.readFileSync(sourcePath, 'utf8');
|
|
11
|
-
const newText = templateFile.replace('// ORIGINAL CONFIG', sourceFile);
|
|
12
|
-
// eslint-disable-next-line @typescript-eslint/no-implied-eval
|
|
13
|
-
Function(newText); // check if the file is valid javascript
|
|
14
|
-
fs.writeFileSync(sourcePath, newText);
|
|
15
|
-
return true;
|
|
16
|
-
} catch (error) {
|
|
17
|
-
return false;
|
|
18
|
-
}
|
|
19
|
-
}
|
package/lib/Helper/Package.ts
DELETED
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import { satisfies, subset, valid, validRange } from 'semver';
|
|
2
|
-
|
|
3
|
-
import { green, red } from './Logging';
|
|
4
|
-
|
|
5
|
-
export function checkPackageVersion(
|
|
6
|
-
appPackage: {
|
|
7
|
-
dependencies?: Record<string, string>;
|
|
8
|
-
devDependencies?: Record<string, string>;
|
|
9
|
-
},
|
|
10
|
-
packageName: string,
|
|
11
|
-
acceptableVersions: string,
|
|
12
|
-
canBeLatest: boolean,
|
|
13
|
-
): boolean {
|
|
14
|
-
const depsVersion = appPackage?.dependencies?.[packageName] ?? '';
|
|
15
|
-
const devDepsVersion = appPackage?.devDependencies?.[packageName] ?? '';
|
|
16
|
-
|
|
17
|
-
if (!depsVersion && !devDepsVersion) {
|
|
18
|
-
red(`✗ ${packageName} isn't in your dependencies.`);
|
|
19
|
-
red(' Please install it with yarn/npm.');
|
|
20
|
-
return false;
|
|
21
|
-
}
|
|
22
|
-
if (
|
|
23
|
-
!fulfillsVersionRange(depsVersion, acceptableVersions, canBeLatest) &&
|
|
24
|
-
!fulfillsVersionRange(devDepsVersion, acceptableVersions, canBeLatest)
|
|
25
|
-
) {
|
|
26
|
-
red(
|
|
27
|
-
`✗ Your \`package.json\` specifies a version of \`${packageName}\` outside of the compatible version range ${acceptableVersions}.\n`,
|
|
28
|
-
);
|
|
29
|
-
return false;
|
|
30
|
-
}
|
|
31
|
-
green(
|
|
32
|
-
`✓ A compatible version of \`${packageName}\` is specified in \`package.json\`.`,
|
|
33
|
-
);
|
|
34
|
-
return true;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
function fulfillsVersionRange(
|
|
38
|
-
version: string,
|
|
39
|
-
acceptableVersions: string,
|
|
40
|
-
canBeLatest: boolean,
|
|
41
|
-
): boolean {
|
|
42
|
-
if (version === 'latest') {
|
|
43
|
-
return canBeLatest;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
let cleanedUserVersion, isRange;
|
|
47
|
-
|
|
48
|
-
if (valid(version)) {
|
|
49
|
-
cleanedUserVersion = valid(version);
|
|
50
|
-
isRange = false;
|
|
51
|
-
} else if (validRange(version)) {
|
|
52
|
-
cleanedUserVersion = validRange(version);
|
|
53
|
-
isRange = true;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return (
|
|
57
|
-
// If the given version is a bogus format, this will still be undefined and we'll automatically reject it
|
|
58
|
-
!!cleanedUserVersion &&
|
|
59
|
-
(isRange
|
|
60
|
-
? subset(cleanedUserVersion, acceptableVersions)
|
|
61
|
-
: satisfies(cleanedUserVersion, acceptableVersions))
|
|
62
|
-
);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* Determines if the passed `package.json` object has the passed package installed.
|
|
67
|
-
*
|
|
68
|
-
* @param appPackage The `package.json` object
|
|
69
|
-
* @param packageName The name of the package to check for
|
|
70
|
-
*
|
|
71
|
-
* @returns `true` if the package is installed, `false` otherwise
|
|
72
|
-
*/
|
|
73
|
-
export function hasPackageInstalled(
|
|
74
|
-
appPackage: Record<string, any>,
|
|
75
|
-
packageName: string,
|
|
76
|
-
): boolean {
|
|
77
|
-
const depsVersion = appPackage.dependencies[packageName];
|
|
78
|
-
const devDepsVersion = appPackage.devDependencies[packageName];
|
|
79
|
-
return !!depsVersion || !!devDepsVersion;
|
|
80
|
-
}
|
package/lib/Helper/SentryCli.ts
DELETED
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
import * as fs from 'node:fs';
|
|
2
|
-
import type { Answers } from 'inquirer';
|
|
3
|
-
import * as path from 'node:path';
|
|
4
|
-
|
|
5
|
-
import type { Args } from '../Constants';
|
|
6
|
-
import { addToGitignore } from './Git';
|
|
7
|
-
import { green, l, nl, red } from './Logging';
|
|
8
|
-
|
|
9
|
-
const SENTRYCLIRC_FILENAME = '.sentryclirc';
|
|
10
|
-
const GITIGNORE_FILENAME = '.gitignore';
|
|
11
|
-
const PROPERTIES_FILENAME = 'sentry.properties';
|
|
12
|
-
|
|
13
|
-
export interface SentryCliProps {
|
|
14
|
-
[s: string]: string;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
type SentryCliConfig = Record<string, SentryCliProps>;
|
|
18
|
-
|
|
19
|
-
export class SentryCli {
|
|
20
|
-
// eslint-disable-next-line @typescript-eslint/typedef
|
|
21
|
-
private _resolve = require.resolve;
|
|
22
|
-
|
|
23
|
-
public constructor(protected _argv: Args) {}
|
|
24
|
-
|
|
25
|
-
public setResolveFunction(resolve: (path: string) => string): void {
|
|
26
|
-
this._resolve = resolve as any;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
public convertAnswersToProperties(answers: Answers): SentryCliProps {
|
|
30
|
-
const props: SentryCliProps = {};
|
|
31
|
-
props['defaults/url'] = this._argv.url;
|
|
32
|
-
props['defaults/org'] = answers.config?.organization?.slug ?? null;
|
|
33
|
-
props['defaults/project'] = answers.config?.project?.slug ?? null;
|
|
34
|
-
props['auth/token'] = answers.config?.auth?.token ?? null;
|
|
35
|
-
try {
|
|
36
|
-
const cliPath = this._resolve('@sentry/cli/bin/sentry-cli', {
|
|
37
|
-
paths: [process.cwd()],
|
|
38
|
-
});
|
|
39
|
-
props['cli/executable'] = path
|
|
40
|
-
.relative(process.cwd(), cliPath)
|
|
41
|
-
.replace(/\\/g, '\\\\');
|
|
42
|
-
} catch (e) {
|
|
43
|
-
// we do nothing and leave everything as it is
|
|
44
|
-
}
|
|
45
|
-
return props;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
/** Create the contents of a `sentry.properties` file */
|
|
49
|
-
public dumpProperties(props: SentryCliProps): string {
|
|
50
|
-
const rv = [];
|
|
51
|
-
for (const [key, value] of Object.entries(props)) {
|
|
52
|
-
const normalizedKey = key.replace(/\//g, '.');
|
|
53
|
-
if (value === undefined || value === null) {
|
|
54
|
-
// comment that property out since it has no value
|
|
55
|
-
rv.push(`#${normalizedKey}=`);
|
|
56
|
-
} else {
|
|
57
|
-
rv.push(`${normalizedKey}=${value}`);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
// eslint-disable-next-line prefer-template
|
|
61
|
-
return rv.join('\n') + '\n';
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
public dumpConfig(config: SentryCliConfig): string {
|
|
65
|
-
const dumpedSections: string[] = [];
|
|
66
|
-
for (const [sectionName, val] of Object.entries(config)) {
|
|
67
|
-
const props = this.dumpProperties(val);
|
|
68
|
-
const section = `[${sectionName}]\n${props}`;
|
|
69
|
-
dumpedSections.push(section);
|
|
70
|
-
}
|
|
71
|
-
return dumpedSections.join('\n');
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
/**
|
|
75
|
-
* Creates `.sentryclirc` and `sentry.properties` files with the CLI properties
|
|
76
|
-
* obtained from the user answers (or from logging into Sentry).
|
|
77
|
-
* The `.sentryclirc` only contains the auth token and will be added to the
|
|
78
|
-
* user's `.gitignore` file. The properties file contains the rest of the
|
|
79
|
-
* properties (org, project, etc.).
|
|
80
|
-
*
|
|
81
|
-
* @param sentryCli instance of the Sentry CLI
|
|
82
|
-
* @param cliProps the properties to write to the files
|
|
83
|
-
*/
|
|
84
|
-
public async createSentryCliConfig(cliProps: SentryCliProps): Promise<void> {
|
|
85
|
-
const { 'auth/token': authToken, ...cliPropsToWrite } = cliProps;
|
|
86
|
-
|
|
87
|
-
/**
|
|
88
|
-
* To not commit the auth token to the VCS, instead of adding it to the
|
|
89
|
-
* properties file (like the rest of props), it's added to the Sentry CLI
|
|
90
|
-
* config, which is added to the gitignore. This way makes the properties
|
|
91
|
-
* file safe to commit without exposing any auth tokens.
|
|
92
|
-
*/
|
|
93
|
-
if (authToken) {
|
|
94
|
-
try {
|
|
95
|
-
await fs.promises.appendFile(
|
|
96
|
-
SENTRYCLIRC_FILENAME,
|
|
97
|
-
this.dumpConfig({ auth: { token: authToken } }),
|
|
98
|
-
);
|
|
99
|
-
green(`✓ Successfully added the auth token to ${SENTRYCLIRC_FILENAME}`);
|
|
100
|
-
} catch {
|
|
101
|
-
red(
|
|
102
|
-
`⚠ Could not add the auth token to ${SENTRYCLIRC_FILENAME}, ` +
|
|
103
|
-
`please add it to identify your user account:\n${authToken}`,
|
|
104
|
-
);
|
|
105
|
-
nl();
|
|
106
|
-
}
|
|
107
|
-
} else {
|
|
108
|
-
red(
|
|
109
|
-
`⚠ Did not find an auth token, please add your token to ${SENTRYCLIRC_FILENAME}`,
|
|
110
|
-
);
|
|
111
|
-
l(
|
|
112
|
-
'To generate an auth token, visit https://sentry.io/settings/account/api/auth-tokens/',
|
|
113
|
-
);
|
|
114
|
-
l(
|
|
115
|
-
'To learn how to configure Sentry CLI, visit ' +
|
|
116
|
-
'https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/#configure-sentry-cli',
|
|
117
|
-
);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
await addToGitignore(
|
|
121
|
-
SENTRYCLIRC_FILENAME,
|
|
122
|
-
`⚠ Could not add ${SENTRYCLIRC_FILENAME} to ${GITIGNORE_FILENAME}, please add it to not commit your auth key.`,
|
|
123
|
-
);
|
|
124
|
-
|
|
125
|
-
try {
|
|
126
|
-
await fs.promises.writeFile(
|
|
127
|
-
`./${PROPERTIES_FILENAME}`,
|
|
128
|
-
this.dumpProperties(cliPropsToWrite),
|
|
129
|
-
);
|
|
130
|
-
green('✓ Successfully created sentry.properties');
|
|
131
|
-
} catch {
|
|
132
|
-
red(`⚠ Could not add org and project data to ${PROPERTIES_FILENAME}`);
|
|
133
|
-
l(
|
|
134
|
-
'See docs for a manual setup: https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/#configure-sentry-cli',
|
|
135
|
-
);
|
|
136
|
-
}
|
|
137
|
-
nl();
|
|
138
|
-
}
|
|
139
|
-
}
|
package/lib/Helper/Wizard.ts
DELETED
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import type { Answers } from 'inquirer';
|
|
2
|
-
|
|
3
|
-
import type { Args } from '../Constants';
|
|
4
|
-
import type { IStep } from '../Steps/BaseStep';
|
|
5
|
-
import type { BaseIntegration } from '../Steps/Integrations/BaseIntegration';
|
|
6
|
-
import { BottomBar } from './BottomBar';
|
|
7
|
-
import { debug, dim, nl, red } from './Logging';
|
|
8
|
-
|
|
9
|
-
function sanitizeAndValidateArgs(argv: Args): void {
|
|
10
|
-
if (argv.quiet === undefined) {
|
|
11
|
-
argv.quiet = true;
|
|
12
|
-
dim('will activate quiet mode for you');
|
|
13
|
-
}
|
|
14
|
-
// @ts-ignore skip-connect does not exist on args
|
|
15
|
-
if (argv['skip-connect']) {
|
|
16
|
-
// @ts-ignore skip-connect does not exist on args
|
|
17
|
-
argv.skipConnect = argv['skip-connect'];
|
|
18
|
-
// @ts-ignore skip-connect does not exist on args
|
|
19
|
-
delete argv['skip-connect'];
|
|
20
|
-
}
|
|
21
|
-
// @ts-ignore skip-connect does not exist on args
|
|
22
|
-
argv.promoCode = argv['promo-code'];
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export function getCurrentIntegration(answers: Answers): BaseIntegration {
|
|
26
|
-
return answers.integration as BaseIntegration;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export async function startWizard<M extends IStep>(
|
|
30
|
-
argv: Args,
|
|
31
|
-
...steps: Array<{ new (debug: Args): M }>
|
|
32
|
-
): Promise<Answers> {
|
|
33
|
-
try {
|
|
34
|
-
sanitizeAndValidateArgs(argv);
|
|
35
|
-
if (argv.debug) {
|
|
36
|
-
debug(argv);
|
|
37
|
-
}
|
|
38
|
-
if (argv.quiet) {
|
|
39
|
-
dim("Quiet mode On, DAMA, don't ask me anything");
|
|
40
|
-
}
|
|
41
|
-
return await steps
|
|
42
|
-
.map((step) => new step(argv))
|
|
43
|
-
.reduce(async (answer, step) => {
|
|
44
|
-
const prevAnswer = await answer;
|
|
45
|
-
const answers = await step.emit(prevAnswer);
|
|
46
|
-
return { ...prevAnswer, ...answers };
|
|
47
|
-
}, Promise.resolve({}));
|
|
48
|
-
} catch (e) {
|
|
49
|
-
BottomBar.hide();
|
|
50
|
-
nl();
|
|
51
|
-
red('Sentry Wizard failed with:');
|
|
52
|
-
red(argv.debug ? e : e.message);
|
|
53
|
-
nl();
|
|
54
|
-
red('Protip: Add --debug to see whats going on');
|
|
55
|
-
red('OR use --help to see your options');
|
|
56
|
-
process.exit(1);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
/// <reference types="jest" />
|
|
2
|
-
import { exists, matchesContent } from '../File';
|
|
3
|
-
|
|
4
|
-
describe('SentryCli', () => {
|
|
5
|
-
test('exists', () => {
|
|
6
|
-
expect(exists('**/File.ts')).toBeTruthy();
|
|
7
|
-
expect(exists('Filea.ts')).toBeFalsy();
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
test('matchesContent', () => {
|
|
11
|
-
expect(matchesContent('**/File.ts', /exists/g)).toBeTruthy();
|
|
12
|
-
expect(matchesContent('**/File.ts', /blabla/g)).toBeFalsy();
|
|
13
|
-
expect(matchesContent('Filea.ts', /exists/g)).toBeFalsy();
|
|
14
|
-
});
|
|
15
|
-
});
|
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
/// <reference types="jest" />
|
|
2
|
-
import * as fs from 'fs';
|
|
3
|
-
import * as path from 'path';
|
|
4
|
-
|
|
5
|
-
import { mergeConfigFile } from '../MergeConfig';
|
|
6
|
-
|
|
7
|
-
const configPath = path.join(__dirname, '..', 'test-fixtures/next.config.js');
|
|
8
|
-
const templatePath = path.join(
|
|
9
|
-
__dirname,
|
|
10
|
-
'..',
|
|
11
|
-
'..',
|
|
12
|
-
'..',
|
|
13
|
-
'scripts/NextJs/configs/next.config.template.js',
|
|
14
|
-
);
|
|
15
|
-
|
|
16
|
-
function configFileNames(num: number): {
|
|
17
|
-
sourcePath: string;
|
|
18
|
-
mergedPath: string;
|
|
19
|
-
} {
|
|
20
|
-
const sourcePath = path.join(
|
|
21
|
-
__dirname,
|
|
22
|
-
'..',
|
|
23
|
-
`test-fixtures/next.config.${num}.js`,
|
|
24
|
-
);
|
|
25
|
-
const mergedPath = path.join(
|
|
26
|
-
__dirname,
|
|
27
|
-
'..',
|
|
28
|
-
`test-fixtures/next.config.${num}-merged.js`,
|
|
29
|
-
);
|
|
30
|
-
return { sourcePath, mergedPath };
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
describe('Merging next.config.js', () => {
|
|
34
|
-
afterEach(() => {
|
|
35
|
-
fs.unlinkSync(configPath);
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
test('merge basic next.config.js return true', () => {
|
|
39
|
-
const { sourcePath } = configFileNames(1);
|
|
40
|
-
fs.copyFileSync(sourcePath, configPath);
|
|
41
|
-
|
|
42
|
-
expect(mergeConfigFile(configPath, templatePath)).toBe(true);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
test('merge basic next.config.js', () => {
|
|
46
|
-
const { sourcePath, mergedPath } = configFileNames(1);
|
|
47
|
-
fs.copyFileSync(sourcePath, configPath);
|
|
48
|
-
|
|
49
|
-
mergeConfigFile(configPath, templatePath);
|
|
50
|
-
|
|
51
|
-
expect(fs.readFileSync(configPath, 'utf8')).toEqual(
|
|
52
|
-
fs.readFileSync(mergedPath, 'utf8'),
|
|
53
|
-
);
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
test('merge invalid javascript config return false', () => {
|
|
57
|
-
const { sourcePath } = configFileNames(2);
|
|
58
|
-
fs.copyFileSync(sourcePath, configPath);
|
|
59
|
-
|
|
60
|
-
expect(mergeConfigFile(configPath, templatePath)).toBe(false);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
test('merge more complicated next.config.js return true', () => {
|
|
64
|
-
const { sourcePath } = configFileNames(3);
|
|
65
|
-
fs.copyFileSync(sourcePath, configPath);
|
|
66
|
-
|
|
67
|
-
expect(mergeConfigFile(configPath, templatePath)).toBe(true);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
test('merge more complicated next.config.js', () => {
|
|
71
|
-
const { sourcePath, mergedPath } = configFileNames(3);
|
|
72
|
-
fs.copyFileSync(sourcePath, configPath);
|
|
73
|
-
|
|
74
|
-
mergeConfigFile(configPath, templatePath);
|
|
75
|
-
|
|
76
|
-
expect(fs.readFileSync(configPath, 'utf8')).toEqual(
|
|
77
|
-
fs.readFileSync(mergedPath, 'utf8'),
|
|
78
|
-
);
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
test('merge next.config.js with function return true', () => {
|
|
82
|
-
const { sourcePath } = configFileNames(4);
|
|
83
|
-
fs.copyFileSync(sourcePath, configPath);
|
|
84
|
-
|
|
85
|
-
expect(mergeConfigFile(configPath, templatePath)).toBe(true);
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
test('merge next.config.js with function', () => {
|
|
89
|
-
const { sourcePath, mergedPath } = configFileNames(4);
|
|
90
|
-
fs.copyFileSync(sourcePath, configPath);
|
|
91
|
-
|
|
92
|
-
mergeConfigFile(configPath, templatePath);
|
|
93
|
-
|
|
94
|
-
expect(fs.readFileSync(configPath, 'utf8')).toEqual(
|
|
95
|
-
fs.readFileSync(mergedPath, 'utf8'),
|
|
96
|
-
);
|
|
97
|
-
});
|
|
98
|
-
});
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
/// <reference types="jest" />
|
|
2
|
-
import type { Answers } from 'inquirer';
|
|
3
|
-
|
|
4
|
-
import type { Args } from '../../Constants';
|
|
5
|
-
import { Integration, Platform } from '../../Constants';
|
|
6
|
-
import { SentryCli } from '../SentryCli';
|
|
7
|
-
|
|
8
|
-
const args: Args = {
|
|
9
|
-
debug: false,
|
|
10
|
-
integration: Integration.reactNative,
|
|
11
|
-
platform: [Platform.ios],
|
|
12
|
-
quiet: false,
|
|
13
|
-
skipConnect: false,
|
|
14
|
-
uninstall: false,
|
|
15
|
-
url: 'https://localhost:1234',
|
|
16
|
-
signup: false,
|
|
17
|
-
disableTelemetry: false,
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
const demoAnswers: Answers = {
|
|
21
|
-
config: {
|
|
22
|
-
auth: {
|
|
23
|
-
token: 'abcd',
|
|
24
|
-
},
|
|
25
|
-
organization: {
|
|
26
|
-
slug: 'test_org',
|
|
27
|
-
},
|
|
28
|
-
project: {
|
|
29
|
-
slug: 'test_proj',
|
|
30
|
-
},
|
|
31
|
-
},
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
describe('SentryCli', () => {
|
|
35
|
-
test('convertAnswersToProperties', () => {
|
|
36
|
-
const resolveFunc = jest.fn().mockReturnValue('node_modules/sentry/cli');
|
|
37
|
-
const sentry = new SentryCli(args);
|
|
38
|
-
sentry.setResolveFunction(resolveFunc);
|
|
39
|
-
const props = sentry.convertAnswersToProperties(demoAnswers);
|
|
40
|
-
expect(props['defaults/url']).toBe('https://localhost:1234');
|
|
41
|
-
expect(props['defaults/org']).toBe('test_org');
|
|
42
|
-
expect(props['defaults/project']).toBe('test_proj');
|
|
43
|
-
expect(props['auth/token']).toBe('abcd');
|
|
44
|
-
expect(props['cli/executable']).toBe('node_modules/sentry/cli');
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
test('dump properties', () => {
|
|
48
|
-
const resolveFunc = jest.fn().mockReturnValue('node_modules/sentry/cli');
|
|
49
|
-
const sentry = new SentryCli(args);
|
|
50
|
-
sentry.setResolveFunction(resolveFunc);
|
|
51
|
-
const props = sentry.convertAnswersToProperties(demoAnswers);
|
|
52
|
-
expect(sentry.dumpProperties(props))
|
|
53
|
-
.toBe(`defaults.url=https://localhost:1234
|
|
54
|
-
defaults.org=test_org
|
|
55
|
-
defaults.project=test_proj
|
|
56
|
-
auth.token=abcd
|
|
57
|
-
cli.executable=node_modules/sentry/cli
|
|
58
|
-
`);
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
test('convertAnswersToProperties windows', () => {
|
|
62
|
-
const resolveFunc = jest.fn().mockReturnValue('node_modules\\sentry\\cli');
|
|
63
|
-
const sentry = new SentryCli(args);
|
|
64
|
-
sentry.setResolveFunction(resolveFunc);
|
|
65
|
-
const props = sentry.convertAnswersToProperties(demoAnswers);
|
|
66
|
-
expect(props['defaults/url']).toBe('https://localhost:1234');
|
|
67
|
-
expect(props['defaults/org']).toBe('test_org');
|
|
68
|
-
expect(props['defaults/project']).toBe('test_proj');
|
|
69
|
-
expect(props['auth/token']).toBe('abcd');
|
|
70
|
-
expect(props['cli/executable']).toBe('node_modules\\\\sentry\\\\cli');
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
test('dump properties windows', () => {
|
|
74
|
-
const resolveFunc = jest.fn().mockReturnValue('node_modules\\sentry\\cli');
|
|
75
|
-
const sentry = new SentryCli(args);
|
|
76
|
-
sentry.setResolveFunction(resolveFunc);
|
|
77
|
-
const props = sentry.convertAnswersToProperties(demoAnswers);
|
|
78
|
-
expect(sentry.dumpProperties(props))
|
|
79
|
-
.toBe(`defaults.url=https://localhost:1234
|
|
80
|
-
defaults.org=test_org
|
|
81
|
-
defaults.project=test_proj
|
|
82
|
-
auth.token=abcd
|
|
83
|
-
cli.executable=node_modules\\\\sentry\\\\cli
|
|
84
|
-
`);
|
|
85
|
-
});
|
|
86
|
-
});
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
// This file sets a custom webpack configuration to use your Next.js app
|
|
2
|
-
// with Sentry.
|
|
3
|
-
// https://nextjs.org/docs/api-reference/next.config.js/introduction
|
|
4
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/
|
|
5
|
-
const { withSentryConfig } = require('@sentry/nextjs');
|
|
6
|
-
|
|
7
|
-
/** @type {import('next').NextConfig} */
|
|
8
|
-
const nextConfig = {
|
|
9
|
-
reactStrictMode: true,
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
module.exports = nextConfig;
|
|
13
|
-
|
|
14
|
-
module.exports = withSentryConfig(
|
|
15
|
-
module.exports,
|
|
16
|
-
{ silent: true },
|
|
17
|
-
{ hideSourceMaps: true },
|
|
18
|
-
);
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
// This file sets a custom webpack configuration to use your Next.js app
|
|
2
|
-
// with Sentry.
|
|
3
|
-
// https://nextjs.org/docs/api-reference/next.config.js/introduction
|
|
4
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/
|
|
5
|
-
const { withSentryConfig } = require('@sentry/nextjs');
|
|
6
|
-
|
|
7
|
-
/** @type {import('next').NextConfig} */
|
|
8
|
-
const nextConfig = {
|
|
9
|
-
reactStrictMode: true,
|
|
10
|
-
images: {
|
|
11
|
-
domains: [],
|
|
12
|
-
},
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
module.exports = nextConfig;
|
|
16
|
-
|
|
17
|
-
module.exports = withSentryConfig(
|
|
18
|
-
module.exports,
|
|
19
|
-
{ silent: true },
|
|
20
|
-
{ hideSourceMaps: true },
|
|
21
|
-
);
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
// This file sets a custom webpack configuration to use your Next.js app
|
|
2
|
-
// with Sentry.
|
|
3
|
-
// https://nextjs.org/docs/api-reference/next.config.js/introduction
|
|
4
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/
|
|
5
|
-
const { withSentryConfig } = require('@sentry/nextjs');
|
|
6
|
-
|
|
7
|
-
module.exports = (phase, { defaultConfig }) => {
|
|
8
|
-
/**
|
|
9
|
-
* @type {import('next').NextConfig}
|
|
10
|
-
*/
|
|
11
|
-
const nextConfig = {
|
|
12
|
-
/* config options here */
|
|
13
|
-
};
|
|
14
|
-
return nextConfig;
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
module.exports = withSentryConfig(
|
|
18
|
-
module.exports,
|
|
19
|
-
{ silent: true },
|
|
20
|
-
{ hideSourceMaps: true },
|
|
21
|
-
);
|
package/lib/Setup.ts
DELETED
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { enableDebugLogs } from '../src/utils/debug';
|
|
2
|
-
|
|
3
|
-
import { readEnvironment } from './Helper/Env';
|
|
4
|
-
import { startWizard } from './Helper/Wizard';
|
|
5
|
-
import * as Step from './Steps';
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* @deprecated this function is the entry point to the old, step-based wizards located in `lib`.
|
|
9
|
-
* When creating new wizards, we now add them to clack-based wizards under `src`.
|
|
10
|
-
* Therefor, do not call this function anymore.
|
|
11
|
-
* Use `run` from {@link ../src/run.ts} instead.
|
|
12
|
-
*/
|
|
13
|
-
export async function run(argv: any): Promise<any> {
|
|
14
|
-
const args = { ...argv, ...readEnvironment() };
|
|
15
|
-
|
|
16
|
-
if (argv.debug) {
|
|
17
|
-
enableDebugLogs();
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
if (args.uninstall === undefined) {
|
|
21
|
-
args.uninstall = false;
|
|
22
|
-
}
|
|
23
|
-
const steps = [
|
|
24
|
-
Step.Initial,
|
|
25
|
-
Step.Welcome,
|
|
26
|
-
Step.ChooseIntegration,
|
|
27
|
-
Step.ShouldConfigure,
|
|
28
|
-
];
|
|
29
|
-
if (args.uninstall === false) {
|
|
30
|
-
steps.push(
|
|
31
|
-
Step.OpenSentry,
|
|
32
|
-
Step.WaitForSentry,
|
|
33
|
-
Step.SentryProjectSelector,
|
|
34
|
-
Step.PromptForParameters,
|
|
35
|
-
);
|
|
36
|
-
}
|
|
37
|
-
steps.push(Step.ConfigureProject, Step.Result);
|
|
38
|
-
|
|
39
|
-
return startWizard(args, ...steps);
|
|
40
|
-
}
|