@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.
Files changed (307) hide show
  1. package/CHANGELOG.md +6 -2
  2. package/dist/lib/Steps/Integrations/Electron.js +1 -1
  3. package/dist/lib/Steps/Integrations/Electron.js.map +1 -1
  4. package/package.json +5 -2
  5. package/.node-cache/node-v22.14.0-darwin-arm64 +0 -0
  6. package/.node-cache/node-v22.14.0-darwin-x64 +0 -0
  7. package/.node-cache/node-v22.14.0-linux-arm64 +0 -0
  8. package/.node-cache/node-v22.14.0-linux-x64 +0 -0
  9. package/.node-cache/node-v22.14.0-win-x64.exe +0 -0
  10. package/COPYING +0 -3575
  11. package/bin.ts +0 -143
  12. package/codecov.yml +0 -15
  13. package/e2e-tests/.env.example +0 -11
  14. package/e2e-tests/README.md +0 -63
  15. package/e2e-tests/jest.config.ts +0 -22
  16. package/e2e-tests/package.json +0 -14
  17. package/e2e-tests/run.sh +0 -15
  18. package/e2e-tests/test-applications/apple/damaged-missing-configuration-list/Project.xcodeproj/project.pbxproj +0 -52
  19. package/e2e-tests/test-applications/apple/damaged-missing-configuration-list/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
  20. package/e2e-tests/test-applications/apple/no-targets/Project.xcodeproj/project.pbxproj +0 -62
  21. package/e2e-tests/test-applications/apple/no-targets/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
  22. package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project.xcodeproj/project.pbxproj +0 -470
  23. package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
  24. package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project1/ContentView.swift +0 -7
  25. package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project1/Project1App.swift +0 -10
  26. package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project2/ContentView.swift +0 -7
  27. package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project2/Project2App.swift +0 -10
  28. package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Project.xcodeproj/project.pbxproj +0 -382
  29. package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Project.xcodeproj/xcshareddata/xcschemes/Project.xcscheme +0 -78
  30. package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Sources/ContentView.swift +0 -7
  31. package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Sources/MainApp.swift +0 -10
  32. package/e2e-tests/test-applications/flutter-test-app/.metadata +0 -45
  33. package/e2e-tests/test-applications/flutter-test-app/README.md +0 -16
  34. package/e2e-tests/test-applications/flutter-test-app/analysis_options.yaml +0 -28
  35. package/e2e-tests/test-applications/flutter-test-app/android/app/build.gradle +0 -44
  36. package/e2e-tests/test-applications/flutter-test-app/android/app/src/debug/AndroidManifest.xml +0 -7
  37. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/AndroidManifest.xml +0 -45
  38. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/kotlin/com/example/flutter_magic/MainActivity.kt +0 -5
  39. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/drawable/launch_background.xml +0 -12
  40. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/drawable-v21/launch_background.xml +0 -12
  41. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-hdpi/ic_launcher.png +0 -0
  42. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-mdpi/ic_launcher.png +0 -0
  43. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png +0 -0
  44. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png +0 -0
  45. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png +0 -0
  46. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/values/styles.xml +0 -18
  47. package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/values-night/styles.xml +0 -18
  48. package/e2e-tests/test-applications/flutter-test-app/android/app/src/profile/AndroidManifest.xml +0 -7
  49. package/e2e-tests/test-applications/flutter-test-app/android/build.gradle +0 -18
  50. package/e2e-tests/test-applications/flutter-test-app/android/gradle/wrapper/gradle-wrapper.properties +0 -5
  51. package/e2e-tests/test-applications/flutter-test-app/android/gradle.properties +0 -3
  52. package/e2e-tests/test-applications/flutter-test-app/android/settings.gradle +0 -25
  53. package/e2e-tests/test-applications/flutter-test-app/lib/main.dart +0 -125
  54. package/e2e-tests/test-applications/flutter-test-app/linux/CMakeLists.txt +0 -145
  55. package/e2e-tests/test-applications/flutter-test-app/linux/flutter/CMakeLists.txt +0 -88
  56. package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugin_registrant.cc +0 -11
  57. package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugin_registrant.h +0 -15
  58. package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugins.cmake +0 -23
  59. package/e2e-tests/test-applications/flutter-test-app/linux/main.cc +0 -6
  60. package/e2e-tests/test-applications/flutter-test-app/linux/my_application.cc +0 -124
  61. package/e2e-tests/test-applications/flutter-test-app/linux/my_application.h +0 -18
  62. package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/Flutter-Debug.xcconfig +0 -2
  63. package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/Flutter-Release.xcconfig +0 -2
  64. package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/GeneratedPluginRegistrant.swift +0 -10
  65. package/e2e-tests/test-applications/flutter-test-app/macos/Podfile +0 -43
  66. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/AppDelegate.swift +0 -9
  67. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json +0 -68
  68. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png +0 -0
  69. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png +0 -0
  70. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png +0 -0
  71. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png +0 -0
  72. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png +0 -0
  73. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png +0 -0
  74. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png +0 -0
  75. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Base.lproj/MainMenu.xib +0 -343
  76. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/AppInfo.xcconfig +0 -14
  77. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Debug.xcconfig +0 -2
  78. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Release.xcconfig +0 -2
  79. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Warnings.xcconfig +0 -13
  80. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/DebugProfile.entitlements +0 -12
  81. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Info.plist +0 -32
  82. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/MainFlutterWindow.swift +0 -15
  83. package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Release.entitlements +0 -8
  84. package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/project.pbxproj +0 -705
  85. package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
  86. package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme +0 -98
  87. package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcworkspace/contents.xcworkspacedata +0 -7
  88. package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
  89. package/e2e-tests/test-applications/flutter-test-app/macos/RunnerTests/RunnerTests.swift +0 -12
  90. package/e2e-tests/test-applications/flutter-test-app/pubspec.lock +0 -213
  91. package/e2e-tests/test-applications/flutter-test-app/pubspec.yaml +0 -89
  92. package/e2e-tests/test-applications/flutter-test-app/test/widget_test.dart +0 -30
  93. package/e2e-tests/test-applications/flutter-test-app/web/favicon.png +0 -0
  94. package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-192.png +0 -0
  95. package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-512.png +0 -0
  96. package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-maskable-192.png +0 -0
  97. package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-maskable-512.png +0 -0
  98. package/e2e-tests/test-applications/flutter-test-app/web/index.html +0 -38
  99. package/e2e-tests/test-applications/flutter-test-app/web/manifest.json +0 -35
  100. package/e2e-tests/test-applications/flutter-test-app/windows/CMakeLists.txt +0 -108
  101. package/e2e-tests/test-applications/flutter-test-app/windows/flutter/CMakeLists.txt +0 -109
  102. package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugin_registrant.cc +0 -11
  103. package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugin_registrant.h +0 -15
  104. package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugins.cmake +0 -23
  105. package/e2e-tests/test-applications/flutter-test-app/windows/runner/CMakeLists.txt +0 -40
  106. package/e2e-tests/test-applications/flutter-test-app/windows/runner/Runner.rc +0 -121
  107. package/e2e-tests/test-applications/flutter-test-app/windows/runner/flutter_window.cpp +0 -71
  108. package/e2e-tests/test-applications/flutter-test-app/windows/runner/flutter_window.h +0 -33
  109. package/e2e-tests/test-applications/flutter-test-app/windows/runner/main.cpp +0 -43
  110. package/e2e-tests/test-applications/flutter-test-app/windows/runner/resource.h +0 -16
  111. package/e2e-tests/test-applications/flutter-test-app/windows/runner/resources/app_icon.ico +0 -0
  112. package/e2e-tests/test-applications/flutter-test-app/windows/runner/runner.exe.manifest +0 -14
  113. package/e2e-tests/test-applications/flutter-test-app/windows/runner/utils.cpp +0 -65
  114. package/e2e-tests/test-applications/flutter-test-app/windows/runner/utils.h +0 -19
  115. package/e2e-tests/test-applications/flutter-test-app/windows/runner/win32_window.cpp +0 -288
  116. package/e2e-tests/test-applications/flutter-test-app/windows/runner/win32_window.h +0 -102
  117. package/e2e-tests/test-applications/nextjs-test-app/next.config.mjs +0 -4
  118. package/e2e-tests/test-applications/nextjs-test-app/package.json +0 -22
  119. package/e2e-tests/test-applications/nextjs-test-app/src/app/layout.tsx +0 -20
  120. package/e2e-tests/test-applications/nextjs-test-app/src/app/page.tsx +0 -90
  121. package/e2e-tests/test-applications/nuxt-3-test-app/README.md +0 -75
  122. package/e2e-tests/test-applications/nuxt-3-test-app/nuxt.config.ts +0 -5
  123. package/e2e-tests/test-applications/nuxt-3-test-app/package.json +0 -18
  124. package/e2e-tests/test-applications/nuxt-3-test-app/public/favicon.ico +0 -0
  125. package/e2e-tests/test-applications/nuxt-3-test-app/public/robots.txt +0 -1
  126. package/e2e-tests/test-applications/nuxt-4-test-app/README.md +0 -75
  127. package/e2e-tests/test-applications/nuxt-4-test-app/nuxt.config.ts +0 -6
  128. package/e2e-tests/test-applications/nuxt-4-test-app/package.json +0 -18
  129. package/e2e-tests/test-applications/nuxt-4-test-app/public/favicon.ico +0 -0
  130. package/e2e-tests/test-applications/nuxt-4-test-app/public/robots.txt +0 -1
  131. package/e2e-tests/test-applications/remix-test-app/app/entry.client.tsx +0 -18
  132. package/e2e-tests/test-applications/remix-test-app/app/entry.server.tsx +0 -140
  133. package/e2e-tests/test-applications/remix-test-app/app/root.tsx +0 -30
  134. package/e2e-tests/test-applications/remix-test-app/app/routes/_index.tsx +0 -48
  135. package/e2e-tests/test-applications/remix-test-app/app/tailwind.css +0 -3
  136. package/e2e-tests/test-applications/remix-test-app/package.json +0 -37
  137. package/e2e-tests/test-applications/remix-test-app/postcss.config.js +0 -6
  138. package/e2e-tests/test-applications/remix-test-app/tailwind.config.ts +0 -9
  139. package/e2e-tests/test-applications/remix-test-app/vite.config.ts +0 -16
  140. package/e2e-tests/test-applications/sveltekit-test-app/package.json +0 -21
  141. package/e2e-tests/test-applications/sveltekit-test-app/src/app.d.ts +0 -13
  142. package/e2e-tests/test-applications/sveltekit-test-app/src/app.html +0 -11
  143. package/e2e-tests/test-applications/sveltekit-test-app/src/lib/index.ts +0 -1
  144. package/e2e-tests/test-applications/sveltekit-test-app/src/routes/+page.svelte +0 -2
  145. package/e2e-tests/test-applications/sveltekit-test-app/svelte.config.js +0 -18
  146. package/e2e-tests/test-applications/sveltekit-test-app/vite.config.ts +0 -6
  147. package/e2e-tests/tests/flutter.test.ts +0 -127
  148. package/e2e-tests/tests/nextjs.test.ts +0 -161
  149. package/e2e-tests/tests/nuxt-3.test.ts +0 -189
  150. package/e2e-tests/tests/nuxt-4.test.ts +0 -188
  151. package/e2e-tests/tests/remix.test.ts +0 -277
  152. package/e2e-tests/tests/sveltekit.test.ts +0 -284
  153. package/e2e-tests/utils/index.ts +0 -456
  154. package/index.ts +0 -2
  155. package/lib/Constants.ts +0 -118
  156. package/lib/Helper/BottomBar.ts +0 -28
  157. package/lib/Helper/Env.ts +0 -7
  158. package/lib/Helper/File.ts +0 -65
  159. package/lib/Helper/Git.ts +0 -39
  160. package/lib/Helper/Logging.ts +0 -44
  161. package/lib/Helper/MergeConfig.ts +0 -19
  162. package/lib/Helper/Package.ts +0 -80
  163. package/lib/Helper/SentryCli.ts +0 -139
  164. package/lib/Helper/Wizard.ts +0 -58
  165. package/lib/Helper/__tests__/File.ts +0 -15
  166. package/lib/Helper/__tests__/MergeConfig.ts +0 -98
  167. package/lib/Helper/__tests__/SentryCli.ts +0 -86
  168. package/lib/Helper/test-fixtures/next.config.1-merged.js +0 -18
  169. package/lib/Helper/test-fixtures/next.config.1.js +0 -6
  170. package/lib/Helper/test-fixtures/next.config.2.js +0 -8
  171. package/lib/Helper/test-fixtures/next.config.3-merged.js +0 -21
  172. package/lib/Helper/test-fixtures/next.config.3.js +0 -9
  173. package/lib/Helper/test-fixtures/next.config.4-merged.js +0 -21
  174. package/lib/Helper/test-fixtures/next.config.4.js +0 -9
  175. package/lib/Setup.ts +0 -40
  176. package/lib/Steps/BaseStep.ts +0 -25
  177. package/lib/Steps/ChooseIntegration.ts +0 -144
  178. package/lib/Steps/ConfigureProject.ts +0 -10
  179. package/lib/Steps/Initial.ts +0 -35
  180. package/lib/Steps/Integrations/BaseIntegration.ts +0 -42
  181. package/lib/Steps/Integrations/Cordova.ts +0 -283
  182. package/lib/Steps/Integrations/Electron.ts +0 -164
  183. package/lib/Steps/Integrations/MobileProject.ts +0 -72
  184. package/lib/Steps/OpenSentry.ts +0 -80
  185. package/lib/Steps/PromptForParameters.ts +0 -200
  186. package/lib/Steps/Result.ts +0 -22
  187. package/lib/Steps/SentryProjectSelector.ts +0 -83
  188. package/lib/Steps/ShouldConfigure.ts +0 -10
  189. package/lib/Steps/WaitForSentry.ts +0 -56
  190. package/lib/Steps/Welcome.ts +0 -21
  191. package/lib/Steps/index.ts +0 -10
  192. package/lib/__tests__/Env.ts +0 -29
  193. package/scripts/NextJs/configs/_error.js +0 -39
  194. package/scripts/NextJs/configs/next.config.js +0 -36
  195. package/scripts/NextJs/configs/next.config.template.js +0 -12
  196. package/scripts/NextJs/configs/sentry.client.config.js +0 -17
  197. package/scripts/NextJs/configs/sentry.edge.config.js +0 -17
  198. package/scripts/NextJs/configs/sentry.server.config.js +0 -17
  199. package/scripts/NextJs/sentry_sample_error.js +0 -47
  200. package/scripts/craft-pre-release.sh +0 -10
  201. package/src/android/android-wizard.ts +0 -192
  202. package/src/android/code-tools.ts +0 -170
  203. package/src/android/gradle.ts +0 -250
  204. package/src/android/manifest.ts +0 -180
  205. package/src/android/templates.ts +0 -86
  206. package/src/apple/apple-wizard.ts +0 -269
  207. package/src/apple/cocoapod.ts +0 -73
  208. package/src/apple/code-tools.ts +0 -147
  209. package/src/apple/fastlane.ts +0 -170
  210. package/src/apple/templates.ts +0 -65
  211. package/src/apple/xcode-manager.ts +0 -404
  212. package/src/flutter/code-tools.ts +0 -284
  213. package/src/flutter/flutter-wizard.ts +0 -164
  214. package/src/flutter/templates.ts +0 -90
  215. package/src/nextjs/nextjs-wizard.ts +0 -1007
  216. package/src/nextjs/templates.ts +0 -525
  217. package/src/nextjs/utils.ts +0 -21
  218. package/src/nuxt/nuxt-wizard.ts +0 -188
  219. package/src/nuxt/sdk-example.ts +0 -135
  220. package/src/nuxt/sdk-setup.ts +0 -352
  221. package/src/nuxt/templates.ts +0 -303
  222. package/src/nuxt/types.ts +0 -8
  223. package/src/nuxt/utils.ts +0 -42
  224. package/src/react-native/expo-env-file.ts +0 -55
  225. package/src/react-native/expo-metro.ts +0 -212
  226. package/src/react-native/expo.ts +0 -175
  227. package/src/react-native/git.ts +0 -25
  228. package/src/react-native/glob.ts +0 -13
  229. package/src/react-native/gradle.ts +0 -26
  230. package/src/react-native/javascript.ts +0 -103
  231. package/src/react-native/metro.ts +0 -599
  232. package/src/react-native/options.ts +0 -5
  233. package/src/react-native/react-native-wizard.ts +0 -512
  234. package/src/react-native/uninstall.ts +0 -109
  235. package/src/react-native/xcode.ts +0 -302
  236. package/src/remix/codemods/express-server.ts +0 -44
  237. package/src/remix/codemods/handle-error.ts +0 -118
  238. package/src/remix/codemods/root-common.ts +0 -63
  239. package/src/remix/codemods/root-v1.ts +0 -41
  240. package/src/remix/codemods/root-v2.ts +0 -153
  241. package/src/remix/remix-wizard.ts +0 -261
  242. package/src/remix/sdk-example.ts +0 -120
  243. package/src/remix/sdk-setup.ts +0 -546
  244. package/src/remix/templates.ts +0 -11
  245. package/src/remix/utils.ts +0 -96
  246. package/src/run.ts +0 -211
  247. package/src/sourcemaps/sourcemaps-wizard.ts +0 -364
  248. package/src/sourcemaps/tools/angular.ts +0 -42
  249. package/src/sourcemaps/tools/create-react-app.ts +0 -19
  250. package/src/sourcemaps/tools/esbuild.ts +0 -65
  251. package/src/sourcemaps/tools/nextjs.ts +0 -114
  252. package/src/sourcemaps/tools/remix.ts +0 -90
  253. package/src/sourcemaps/tools/rollup.ts +0 -67
  254. package/src/sourcemaps/tools/sentry-cli.ts +0 -287
  255. package/src/sourcemaps/tools/tsc.ts +0 -144
  256. package/src/sourcemaps/tools/types.ts +0 -11
  257. package/src/sourcemaps/tools/vite.ts +0 -300
  258. package/src/sourcemaps/tools/webpack.ts +0 -383
  259. package/src/sourcemaps/utils/detect-tool.ts +0 -46
  260. package/src/sourcemaps/utils/other-wizards.ts +0 -167
  261. package/src/sourcemaps/utils/sdk-version.ts +0 -266
  262. package/src/sveltekit/sdk-example.ts +0 -56
  263. package/src/sveltekit/sdk-setup.ts +0 -667
  264. package/src/sveltekit/sveltekit-wizard.ts +0 -192
  265. package/src/sveltekit/templates.ts +0 -185
  266. package/src/sveltekit/utils.ts +0 -50
  267. package/src/telemetry.ts +0 -144
  268. package/src/utils/ast-utils.ts +0 -270
  269. package/src/utils/bash.ts +0 -57
  270. package/src/utils/clack-utils.ts +0 -1536
  271. package/src/utils/debug.ts +0 -20
  272. package/src/utils/package-json.ts +0 -51
  273. package/src/utils/package-manager.ts +0 -172
  274. package/src/utils/release-registry.ts +0 -19
  275. package/src/utils/semver.ts +0 -33
  276. package/src/utils/sentrycli-utils.ts +0 -24
  277. package/src/utils/string.ts +0 -7
  278. package/src/utils/types.ts +0 -77
  279. package/src/utils/url.ts +0 -27
  280. package/src/utils/vendor/is-unicorn-supported.ts +0 -29
  281. package/test/android/code-tools.test.ts +0 -49
  282. package/test/apple/cocoapod.test.ts +0 -310
  283. package/test/apple/code-tools.test.ts +0 -1042
  284. package/test/apple/fastfile.test.ts +0 -555
  285. package/test/apple/templates.test.ts +0 -191
  286. package/test/apple/xcode-manager.test.ts +0 -1068
  287. package/test/flutter/code-tools.test.ts +0 -212
  288. package/test/flutter/templates.test.ts +0 -100
  289. package/test/nextjs/templates.test.ts +0 -429
  290. package/test/nuxt/templates.test.ts +0 -255
  291. package/test/react-native/expo-metro.test.ts +0 -81
  292. package/test/react-native/expo.test.ts +0 -86
  293. package/test/react-native/gradle.test.ts +0 -310
  294. package/test/react-native/javascript.test.ts +0 -134
  295. package/test/react-native/metro.test.ts +0 -396
  296. package/test/react-native/xcode.test.ts +0 -401
  297. package/test/remix/client-entry.test.ts +0 -122
  298. package/test/remix/server-instrumentation.test.ts +0 -36
  299. package/test/sourcemaps/tools/sentry-cli.test.ts +0 -57
  300. package/test/sourcemaps/tools/tsc.test.ts +0 -181
  301. package/test/sourcemaps/tools/vite.test.ts +0 -149
  302. package/test/sourcemaps/tools/webpack.test.ts +0 -303
  303. package/test/sveltekit/templates.test.ts +0 -152
  304. package/test/utils/ast-utils.test.ts +0 -264
  305. package/test/utils/clack-utils.test.ts +0 -224
  306. package/types/read-env.d.ts +0 -3
  307. package/types/xcode.d.ts +0 -527
@@ -1,269 +0,0 @@
1
- /* eslint-disable max-lines */
2
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
3
- /* eslint-disable @typescript-eslint/no-unsafe-assignment */
4
- /* eslint-disable @typescript-eslint/no-unsafe-call */
5
- /* eslint-disable @typescript-eslint/no-unused-vars */
6
- // @ts-ignore - clack is ESM and TS complains about that. It works though
7
- import clack from '@clack/prompts';
8
- import * as fs from 'fs';
9
- import * as path from 'path';
10
- import { XcodeProject } from './xcode-manager';
11
- import * as codeTools from './code-tools';
12
- import * as bash from '../utils/bash';
13
- import * as SentryUtils from '../utils/sentrycli-utils';
14
- import { SentryProjectData, WizardOptions } from '../utils/types';
15
- import * as Sentry from '@sentry/node';
16
- import { traceStep, withTelemetry } from '../telemetry';
17
- import * as cocoapod from './cocoapod';
18
- import * as fastlane from './fastlane';
19
-
20
- /* eslint-enable @typescript-eslint/no-unused-vars */
21
-
22
- import {
23
- askToInstallSentryCLI,
24
- printWelcome,
25
- abort,
26
- askForItemSelection,
27
- confirmContinueIfNoOrDirtyGitRepo,
28
- getOrAskForProjectData,
29
- } from '../utils/clack-utils';
30
-
31
- export async function runAppleWizard(options: WizardOptions): Promise<void> {
32
- return withTelemetry(
33
- {
34
- enabled: options.telemetryEnabled,
35
- integration: 'ios',
36
- wizardOptions: options,
37
- },
38
- () => runAppleWizardWithTelementry(options),
39
- );
40
- }
41
-
42
- async function runAppleWizardWithTelementry(
43
- options: WizardOptions,
44
- ): Promise<void> {
45
- printWelcome({
46
- wizardName: 'Sentry Apple Wizard',
47
- promoCode: options.promoCode,
48
- });
49
-
50
- await confirmContinueIfNoOrDirtyGitRepo();
51
-
52
- const hasCli = bash.hasSentryCLI();
53
- Sentry.setTag('has-cli', hasCli);
54
- if (!hasCli) {
55
- if (
56
- !(await traceStep('Ask for SentryCLI', () => askToInstallSentryCLI()))
57
- ) {
58
- clack.log.warn(
59
- "Without sentry-cli, you won't be able to upload debug symbols to Sentry. You can install it later by following the instructions at https://docs.sentry.io/cli/",
60
- );
61
- Sentry.setTag('CLI-Installed', false);
62
- } else {
63
- await bash.installSentryCLI();
64
- Sentry.setTag('CLI-Installed', true);
65
- }
66
- }
67
-
68
- const projectDir = process.cwd();
69
- const xcodeProjFiles = searchXcodeProject(projectDir);
70
-
71
- if (!xcodeProjFiles || xcodeProjFiles.length === 0) {
72
- clack.log.error(
73
- 'No Xcode project found. Please run this command from the root of your project.',
74
- );
75
- await abort();
76
- return;
77
- }
78
-
79
- let xcodeProjFile;
80
-
81
- if (xcodeProjFiles.length === 1) {
82
- xcodeProjFile = xcodeProjFiles[0];
83
- Sentry.setTag('multiple-projects', false);
84
- } else {
85
- Sentry.setTag('multiple-projects', true);
86
- xcodeProjFile = (
87
- await traceStep('Choose Xcode project', () =>
88
- askForItemSelection(
89
- xcodeProjFiles,
90
- 'Which project do you want to add Sentry to?',
91
- ),
92
- )
93
- ).value;
94
- }
95
-
96
- const pbxproj = path.join(projectDir, xcodeProjFile, 'project.pbxproj');
97
-
98
- if (!fs.existsSync(pbxproj)) {
99
- clack.log.error(`No pbxproj found at ${xcodeProjFile}`);
100
- await abort();
101
- return;
102
- }
103
-
104
- const { project, apiKey } = await getSentryProjectAndApiKey(options);
105
-
106
- const xcProject = new XcodeProject(pbxproj);
107
-
108
- const availableTargets = xcProject.getAllTargets();
109
-
110
- if (availableTargets.length == 0) {
111
- clack.log.error(`No suitable target found in ${xcodeProjFile}`);
112
- Sentry.setTag('No-Target', true);
113
- await abort();
114
- return;
115
- }
116
-
117
- const target =
118
- availableTargets.length == 1
119
- ? availableTargets[0]
120
- : (
121
- await traceStep('Choose target', () =>
122
- askForItemSelection(
123
- availableTargets,
124
- 'Which target do you want to add Sentry to?',
125
- ),
126
- )
127
- ).value;
128
-
129
- SentryUtils.createSentryCLIRC(projectDir, { auth_token: apiKey.token });
130
- clack.log.info(
131
- 'We created a ".sentryclirc" file in your project directory in order to provide an auth token for Sentry CLI.\nIt was also added to your ".gitignore" file.\nAt your CI enviroment, you can set the SENTRY_AUTH_TOKEN environment variable instead. See https://docs.sentry.io/cli/configuration/#auth-token for more information.',
132
- );
133
-
134
- let hasCocoa = cocoapod.usesCocoaPod(projectDir);
135
- Sentry.setTag('cocoapod-exists', hasCocoa);
136
-
137
- if (hasCocoa) {
138
- const pm = (
139
- await traceStep('Choose a package manager', () =>
140
- askForItemSelection(
141
- ['Swift Package Manager', 'CocoaPods'],
142
- 'Which package manager would you like to use to add Sentry?',
143
- ),
144
- )
145
- ).value;
146
-
147
- hasCocoa = pm === 'CocoaPods';
148
- if (hasCocoa) {
149
- const podAdded = await traceStep('Add CocoaPods reference', () =>
150
- cocoapod.addCocoaPods(projectDir),
151
- );
152
- Sentry.setTag('cocoapod-added', podAdded);
153
- if (!podAdded) {
154
- clack.log.warn(
155
- "Could not add Sentry pod to your Podfile. You'll have to add it manually.\nPlease follow the instructions at https://docs.sentry.io/platforms/apple/guides/ios/#install",
156
- );
157
- }
158
- }
159
- }
160
-
161
- Sentry.setTag('package-manager', hasCocoa ? 'cocoapods' : 'SPM');
162
- traceStep('Update Xcode project', () => {
163
- xcProject.updateXcodeProject(project, target, !hasCocoa, true);
164
- });
165
-
166
- const codeAdded = traceStep('Add code snippet', () => {
167
- const files = xcProject.filesForTarget(target);
168
- if (files === undefined || files.length == 0) return false;
169
-
170
- return codeTools.addCodeSnippetToProject(
171
- projectDir,
172
- files,
173
- project.keys[0].dsn.public,
174
- );
175
- });
176
-
177
- Sentry.setTag('Snippet-Added', codeAdded);
178
-
179
- if (!codeAdded) {
180
- clack.log.warn(
181
- 'Added the Sentry dependency to your project but could not add the Sentry code snippet. Please add the code snipped manually by following the docs: https://docs.sentry.io/platforms/apple/guides/ios/#configure',
182
- );
183
- }
184
-
185
- const hasFastlane = fastlane.fastFile(projectDir);
186
- Sentry.setTag('fastlane-exists', hasFastlane);
187
- if (hasFastlane) {
188
- const addLane = await clack.confirm({
189
- message:
190
- 'Found a Fastfile in your project. Do you want to configure a lane to upload debug symbols to Sentry?',
191
- });
192
- Sentry.setTag('fastlane-desired', addLane);
193
- if (addLane) {
194
- const added = await traceStep('Configure fastlane', () =>
195
- fastlane.addSentryToFastlane(
196
- projectDir,
197
- project.organization.slug,
198
- project.slug,
199
- ),
200
- );
201
- Sentry.setTag('fastlane-added', added);
202
- if (added) {
203
- clack.log.step(
204
- 'A new step was added to your fastlane file. Now and you build your project with fastlane, debug symbols and source context will be uploaded to Sentry.',
205
- );
206
- } else {
207
- clack.log.warn(
208
- 'Could not edit your fastlane file to upload debug symbols to Sentry. Please follow the instructions at https://docs.sentry.io/platforms/apple/guides/ios/dsym/#fastlane',
209
- );
210
- }
211
- }
212
- }
213
-
214
- clack.log.success(
215
- 'Sentry was successfully added to your project! Run your project to send your first event to Sentry. Go to Sentry.io to see whether everything is working fine.',
216
- );
217
- }
218
-
219
- //Prompt for Sentry project and API key
220
- async function getSentryProjectAndApiKey(
221
- options: WizardOptions,
222
- ): Promise<{ project: SentryProjectData; apiKey: { token: string } }> {
223
- const { selectedProject, authToken } = await getOrAskForProjectData(options);
224
- return { project: selectedProject, apiKey: { token: authToken } };
225
- }
226
-
227
- function searchXcodeProject(at: string): string[] {
228
- const projs = findFilesWithExtension(at, '.xcodeproj');
229
- if (projs.length > 0) {
230
- return projs;
231
- }
232
-
233
- const workspace = findFilesWithExtension(at, '.xcworkspace');
234
- if (workspace.length == 0) {
235
- return [];
236
- }
237
-
238
- const xsworkspacedata = path.join(
239
- at,
240
- workspace[0],
241
- 'contents.xcworkspacedata',
242
- );
243
- if (!fs.existsSync(xsworkspacedata)) {
244
- return [];
245
- }
246
- const groupRegex = /location *= *"group:([^"]+)"/gim;
247
- const content = fs.readFileSync(xsworkspacedata, 'utf8');
248
- let matches = groupRegex.exec(content);
249
-
250
- while (matches) {
251
- const group = matches[1];
252
- const groupPath = path.join(at, group);
253
- if (
254
- !group.endsWith('Pods.xcodeproj') &&
255
- group.endsWith('.xcodeproj') &&
256
- fs.existsSync(groupPath)
257
- ) {
258
- projs.push(group);
259
- }
260
- matches = groupRegex.exec(content);
261
- }
262
- return projs;
263
- }
264
-
265
- //find files with the given extension
266
- function findFilesWithExtension(dir: string, extension: string): string[] {
267
- const files = fs.readdirSync(dir);
268
- return files.filter((file) => file.endsWith(extension));
269
- }
@@ -1,73 +0,0 @@
1
- import * as fs from 'fs';
2
- import * as path from 'path';
3
- import * as bash from '../utils/bash';
4
- import * as Sentry from '@sentry/node';
5
- // @ts-ignore - clack is ESM and TS complains about that. It works though
6
- import * as clack from '@clack/prompts';
7
- import chalk from 'chalk';
8
-
9
- export function usesCocoaPod(projPath: string): boolean {
10
- return fs.existsSync(path.join(projPath, 'Podfile'));
11
- }
12
-
13
- export async function addCocoaPods(projPath: string): Promise<boolean> {
14
- const podfile = path.join(projPath, 'Podfile');
15
-
16
- const podContent = fs.readFileSync(podfile, 'utf8');
17
-
18
- if (
19
- /^\s*pod\s+(['"]Sentry['"]|['"]SentrySwiftUI['"])\s*$/im.test(podContent)
20
- ) {
21
- // Already have Sentry pod
22
- return true;
23
- }
24
-
25
- let podMatch = /^( *)pod\s+['"](\w+)['"] *$/im.exec(podContent);
26
- if (!podMatch) {
27
- // No Podfile is empty, will try to add Sentry pod after "use_frameworks!"
28
- const frameworkMatch = /^( *)use_frameworks![^\n]* *$/im.exec(podContent);
29
- if (!frameworkMatch) {
30
- return false;
31
- }
32
- podMatch = frameworkMatch;
33
- }
34
-
35
- const insertIndex = podMatch.index + podMatch[0].length;
36
- const newFileContent =
37
- podContent.slice(0, insertIndex) +
38
- '\n' +
39
- podMatch[1] +
40
- "pod 'Sentry'\n" +
41
- podContent.slice(insertIndex);
42
- fs.writeFileSync(podfile, newFileContent, 'utf8');
43
-
44
- clack.log.step('Sentry pod added to the project podFile.');
45
-
46
- await podInstall();
47
-
48
- return true;
49
- }
50
-
51
- export async function podInstall(dir = '.') {
52
- const installSpinner = clack.spinner();
53
- installSpinner.start("Running 'pod install'. This may take a few minutes...");
54
-
55
- try {
56
- await bash.execute(`cd ${dir} && pod repo update`);
57
- await bash.execute(`cd ${dir} && pod install --silent`);
58
- installSpinner.stop('Pods installed.');
59
- Sentry.setTag('pods-installed', true);
60
- } catch (e) {
61
- installSpinner.stop('Failed to install pods.');
62
- Sentry.setTag('pods-installed', false);
63
- clack.log.error(
64
- `${chalk.red(
65
- 'Encountered the following error during pods installation:',
66
- // eslint-disable-next-line @typescript-eslint/restrict-template-expressions
67
- )}\n\n${e}\n\n${chalk.dim(
68
- 'If you think this issue is caused by the Sentry wizard, let us know here:\nhttps://github.com/getsentry/sentry-wizard/issues',
69
- )}`,
70
- );
71
- Sentry.captureException('Sentry pod install failed.');
72
- }
73
- }
@@ -1,147 +0,0 @@
1
- import * as Sentry from '@sentry/node';
2
- import * as fs from 'fs';
3
- import * as path from 'path';
4
- import * as templates from './templates';
5
- // @ts-ignore - clack is ESM and TS complains about that. It works though
6
- import * as clack from '@clack/prompts';
7
-
8
- const swiftAppLaunchRegex =
9
- /(func\s+application\s*\(\s*_\s+application:\s*[^,]+,\s*didFinishLaunchingWithOptions[^,]+:\s*[^)]+\s*\)\s+->\s+Bool\s+{)|func\s+applicationDidFinishLaunching\s*\(\s*_\s+aNotification:\s+Notification\s*\)\s*{/im;
10
- const objcAppLaunchRegex =
11
- /-\s*\(\s*BOOL\s*\)\s*application:\s*\(\s*UIApplication\s*\*\s*\)\s*application\s+didFinishLaunchingWithOptions:\s*\(\s*NSDictionary\s*\*\s*\)\s*launchOptions\s*{/im;
12
- const swiftUIRegex = /@main\s+struct[^:]+:\s*(SwiftUI\.)?App\s*{/im;
13
-
14
- function isAppDelegateFile(filePath: string): boolean {
15
- const appLaunchRegex = filePath.toLowerCase().endsWith('.swift')
16
- ? swiftAppLaunchRegex
17
- : objcAppLaunchRegex;
18
-
19
- const fileContent = fs.readFileSync(filePath, 'utf8');
20
- return appLaunchRegex.test(fileContent) || swiftUIRegex.test(fileContent);
21
- }
22
-
23
- function findAppDidFinishLaunchingWithOptions(
24
- dir: string,
25
- files: string[] | undefined = undefined,
26
- ): string | null {
27
- if (!files) {
28
- files = fs.readdirSync(dir);
29
- files = files.map((f) => path.join(dir, f));
30
- }
31
-
32
- //iterate over subdirectories later,
33
- //the appdelegate usually is in the top level
34
- const dirs: string[] = [];
35
-
36
- for (const filePath of files) {
37
- if (
38
- filePath.endsWith('.swift') ||
39
- filePath.endsWith('.m') ||
40
- filePath.endsWith('.mm')
41
- ) {
42
- if (fs.existsSync(filePath) && isAppDelegateFile(filePath)) {
43
- return filePath;
44
- }
45
- } else if (
46
- !path.basename(filePath).startsWith('.') &&
47
- !filePath.endsWith('.xcodeproj') &&
48
- !filePath.endsWith('.xcassets') &&
49
- fs.existsSync(filePath) &&
50
- fs.lstatSync(filePath).isDirectory()
51
- ) {
52
- dirs.push(filePath);
53
- }
54
- }
55
-
56
- for (const dr of dirs) {
57
- const result = findAppDidFinishLaunchingWithOptions(dr);
58
- if (result) return result;
59
- }
60
- return null;
61
- }
62
-
63
- export function addCodeSnippetToProject(
64
- projPath: string,
65
- files: string[],
66
- dsn: string,
67
- ): boolean {
68
- const appDelegate = findAppDidFinishLaunchingWithOptions(projPath, files);
69
- if (!appDelegate) {
70
- return false;
71
- }
72
-
73
- const fileContent = fs.readFileSync(appDelegate, 'utf8');
74
- const isSwift = appDelegate.toLowerCase().endsWith('.swift');
75
- const appLaunchRegex = isSwift ? swiftAppLaunchRegex : objcAppLaunchRegex;
76
- const importStatement = isSwift ? 'import Sentry\n' : '@import Sentry;\n';
77
- const checkForSentryInit = isSwift ? 'SentrySDK.start' : '[SentrySDK start';
78
- let codeSnippet = isSwift
79
- ? templates.getSwiftSnippet(dsn)
80
- : templates.getObjcSnippet(dsn);
81
-
82
- Sentry.setTag('code-language', isSwift ? 'swift' : 'objc');
83
- Sentry.setTag(
84
- 'ui-engine',
85
- swiftUIRegex.test(fileContent) ? 'swiftui' : 'uikit',
86
- );
87
-
88
- if (fileContent.includes(checkForSentryInit)) {
89
- //already initialized
90
- clack.log.info(
91
- 'Sentry is already initialized in your AppDelegate. Skipping adding the code snippet.',
92
- );
93
- return true;
94
- }
95
-
96
- let match = appLaunchRegex.exec(fileContent);
97
- if (!match) {
98
- const swiftUIMatch = swiftUIRegex.exec(fileContent);
99
- if (!swiftUIMatch) {
100
- // This branch is not reached, because we already checked for SwiftUI in isAppDelegateFile
101
- return false;
102
- }
103
- //Is SwiftUI with no init
104
- match = swiftUIMatch;
105
- codeSnippet = ` init() {\n${codeSnippet} }`;
106
- }
107
-
108
- const insertIndex = match.index + match[0].length;
109
- let newFileContent =
110
- fileContent.slice(0, insertIndex) +
111
- '\n' +
112
- codeSnippet +
113
- fileContent.slice(insertIndex);
114
-
115
- if (newFileContent.indexOf(importStatement) < 0) {
116
- const firstImport = /^[ \t]*import +\w+.*$/m.exec(newFileContent);
117
- if (firstImport) {
118
- const importIndex = firstImport.index + firstImport[0].length;
119
- newFileContent =
120
- newFileContent.slice(0, importIndex) +
121
- '\n' +
122
- importStatement +
123
- newFileContent.slice(importIndex);
124
- } else {
125
- newFileContent = importStatement + newFileContent;
126
- }
127
- }
128
-
129
- fs.writeFileSync(appDelegate, newFileContent, 'utf8');
130
-
131
- clack.log.step('Added Sentry initialization code snippet to ' + appDelegate);
132
- return true;
133
- }
134
-
135
- /**
136
- * Exported for testing purposes, but should not be used in other modules.
137
- */
138
- export let exportForTesting: {
139
- isAppDelegateFile: typeof isAppDelegateFile;
140
- findAppDidFinishLaunchingWithOptions: typeof findAppDidFinishLaunchingWithOptions;
141
- };
142
- if (process.env.NODE_ENV === 'test') {
143
- exportForTesting = {
144
- isAppDelegateFile,
145
- findAppDidFinishLaunchingWithOptions,
146
- };
147
- }
@@ -1,170 +0,0 @@
1
- import * as fs from 'fs';
2
- import * as path from 'path';
3
- import { askForItemSelection } from '../utils/clack-utils';
4
- import * as templates from './templates';
5
- // @ts-ignore - clack is ESM and TS complains about that. It works though
6
- import * as clack from '@clack/prompts';
7
-
8
- export function fastFile(projectPath: string): string | null {
9
- const fastlanePath = path.join(projectPath, 'fastlane', 'Fastfile');
10
- return fs.existsSync(fastlanePath) ? fastlanePath : null;
11
- }
12
-
13
- function findIOSPlatform(
14
- content: string,
15
- ): { index: number; length: number } | null {
16
- const platformRegex = /^ *platform\s+:([^ ]+)[^\n]*\n/gim;
17
- let match = platformRegex.exec(content);
18
- if (!match) {
19
- // No platform found, treat whole file as one platform.
20
- return { index: 0, length: content.length };
21
- }
22
-
23
- let index = -1;
24
- while (match) {
25
- if (match[1] === 'ios') {
26
- index = match.index + match[0].length;
27
- break;
28
- }
29
- match = platformRegex.exec(content);
30
- }
31
-
32
- if (index === -1) {
33
- return null;
34
- }
35
-
36
- //After finding the platform, we need to find the end of the platform block.
37
- //This solution has the assumption that the file is well formed,
38
- //which is not a perfect solution, but it's good enough assumption.
39
- const platformEndRegex = /^end[^\n]*/gim;
40
- match = platformEndRegex.exec(content.slice(index));
41
- if (!match) {
42
- return null;
43
- }
44
-
45
- return { index, length: match.index };
46
- }
47
-
48
- function findLanes(
49
- content: string,
50
- ): { index: number; length: number; name: string }[] | null {
51
- const laneRegex = /^ {2}lane\s+:([^ ]+)[^\n]*\n/gim;
52
- let match = laneRegex.exec(content);
53
- if (!match) {
54
- return null;
55
- }
56
-
57
- const lanes: { index: number; length: number; name: string }[] = [];
58
- while (match) {
59
- const laneEnd = /^ {2}end/m.exec(
60
- content.slice(match.index + match[0].length),
61
- );
62
- if (laneEnd === null) {
63
- return null;
64
- }
65
- lanes.push({
66
- index: match.index + match[0].length,
67
- length: laneEnd.index,
68
- name: match[1],
69
- });
70
- match = laneRegex.exec(content);
71
- }
72
- return lanes;
73
- }
74
-
75
- function addSentryToLane(
76
- content: string,
77
- lane: { index: number; length: number; name: string },
78
- org: string,
79
- project: string,
80
- ): string {
81
- const laneContent = content.slice(lane.index, lane.index + lane.length);
82
- const sentryCLIMatch = /sentry_cli\s*\([^)]+\)/gim.exec(laneContent);
83
- if (sentryCLIMatch) {
84
- // Sentry already added to lane. Update it.
85
- return (
86
- content.slice(0, sentryCLIMatch.index + lane.index) +
87
- templates.getFastlaneSnippet(org, project).trim() +
88
- content.slice(
89
- sentryCLIMatch.index + sentryCLIMatch[0].length + lane.index,
90
- )
91
- );
92
- }
93
-
94
- // Sentry not added to lane. Add it.
95
- return (
96
- content.slice(0, lane.index + lane.length) +
97
- '\n' +
98
- templates.getFastlaneSnippet(org, project) +
99
- '\n' +
100
- content.slice(lane.index + lane.length)
101
- );
102
- }
103
-
104
- export async function addSentryToFastlane(
105
- projectPath: string,
106
- org: string,
107
- project: string,
108
- ): Promise<boolean> {
109
- const fastFilePath = fastFile(projectPath);
110
- if (!fastFilePath) {
111
- return false;
112
- }
113
-
114
- const fileContent = fs.readFileSync(fastFilePath, 'utf8');
115
- const platform = findIOSPlatform(fileContent);
116
- if (!platform) {
117
- return false;
118
- }
119
-
120
- const platformContent = fileContent.slice(
121
- platform.index,
122
- platform.index + platform.length,
123
- );
124
- const lanes = findLanes(platformContent);
125
- lanes?.forEach((l) => (l.index += platform.index));
126
-
127
- if (!lanes || lanes.length === 0) {
128
- clack.log.warn('No suitable lanes in your Fastfile.');
129
- return false;
130
- }
131
-
132
- let newFileContent: string | undefined;
133
- if (lanes.length === 1) {
134
- newFileContent = addSentryToLane(fileContent, lanes[0], org, project);
135
- } else {
136
- const laneNames = lanes.map((l) => l.name);
137
- const selectedLane = await askForItemSelection(
138
- laneNames,
139
- 'Select lane to add Sentry to:',
140
- );
141
- if (selectedLane === undefined) {
142
- return false;
143
- }
144
- newFileContent = addSentryToLane(
145
- fileContent,
146
- lanes[selectedLane.index],
147
- org,
148
- project,
149
- );
150
- }
151
-
152
- fs.writeFileSync(fastFilePath, newFileContent, 'utf8');
153
- return true;
154
- }
155
-
156
- /**
157
- * Exported for testing purposes, but should not be used in other modules.
158
- */
159
- export let exportForTesting: {
160
- findIOSPlatform: typeof findIOSPlatform;
161
- findLanes: typeof findLanes;
162
- addSentryToLane: typeof addSentryToLane;
163
- };
164
- if (process.env.NODE_ENV === 'test') {
165
- exportForTesting = {
166
- findIOSPlatform,
167
- findLanes,
168
- addSentryToLane,
169
- };
170
- }