-
-
Notifications
You must be signed in to change notification settings - Fork 334
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
meta: split decision log into separate file (#2940)
- Loading branch information
1 parent
5de0a56
commit dcec216
Showing
2 changed files
with
129 additions
and
130 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,129 @@ | ||
# Decision Log | ||
|
||
## Not capturing screenshots for crashes | ||
|
||
Date: April 21st 2022 | ||
Contributors: @philipphofmann, @brustolin | ||
|
||
We decided against capturing screenshots for crashes because we must only call [async-safe functions](https://man7.org/linux/man-pages/man7/signal-safety.7.html) in signal handlers. Capturing a screenshot requires Objcetive-C code, which is not async safe. | ||
We could create the crash report first, write it to disk and then call Objective-C to get the screenshot. The outcome in such a scenario would be undefined, potentially breaking other signal handlers. We decided against this approach because we don't want to break the contract of signal handlers only calling async-safe functions. | ||
|
||
Related links: | ||
|
||
- https://github.com/getsentry/sentry-cocoa/pull/1751 | ||
|
||
## Custom SentryHttpStatusCodeRange type instead of NSRange | ||
|
||
Date: October 24th 2022 | ||
Contributors: @marandaneto, @brustolin and @philipphofmann | ||
|
||
We decided not to use the `NSRange` type for the `failedRequestStatusCodes` property of the `SentryNetworkTracker` class because it's not compatible with the specification, which requires the type to be a range of `from` -> `to` integers. The `NSRange` type is a range of `location` -> `length` integers. We decided to use a custom type instead of `NSRange` to avoid confusion. The custom type is called `SentryHttpStatusCodeRange`. | ||
|
||
## Manually installing iOS 12 simulators <a name="ios-12-simulators"></a> | ||
|
||
Date: October 21st 2022 | ||
Contributors: @philipphofmann | ||
|
||
We reverted this decision with [remove running unit tests on iOS 12 simulators](#remove-ios-12-simulators). | ||
|
||
GH actions will remove the macOS-10.15 image, which contains an iOS 12 simulator on 12/1/22; see https://github.com/actions/runner-images/issues/5583. | ||
Neither the [macOS-11](https://github.com/actions/runner-images/blob/main/images/macos/macos-11-Readme.md#installed-sdks) nor the | ||
[macOS-12](https://github.com/actions/runner-images/blob/main/images/macos/macos-12-Readme.md#installed-sdks) image contains an iOS 12 simulator. GH | ||
[concluded](https://github.com/actions/runner-images/issues/551#issuecomment-788822538) to not add more pre-installed simulators. SauceLabs doesn't | ||
support running unit tests and adding another cloud solution as Firebase TestLab would increase the complexity of CI. Not running the unit tests on | ||
iOS 12 opens a risk of introducing bugs, which has already happened in the past, especially with swizzling. Therefore, we give manually installing | ||
the iOS 12 simulator a try. | ||
|
||
Related to [GH-2218](https://github.com/getsentry/sentry-cocoa/issues/2218) | ||
|
||
## Adding Swift code in the project | ||
|
||
Date: October 1st 2022 | ||
Contributors: @brustolin | ||
|
||
A Sentry SDK started to be [written in Swift once,](https://github.com/getsentry/raven-swift) but due to ABI not being stable at that time, it got dropped. Since then Swift 5.0 landed and we got ABI stability. We’ve considered adding Swift to our sentry.cocoa SDK since then, but because of some of the trade offs, we’ve postponed that decision. | ||
This changed with our goal to better support SwiftUI. It’s growing in popularity and we need to write code in Swift in order to support it. | ||
SwiftUI support will be available through an additional library, but to support it, we need to be able to demangle Swift class names in Sentry SDK, which can be done by using Swift API. | ||
Since we support SPM, and SPM doesn't support multi-language projects, we need to create two different targets, one with Swift and another with Objective-C code. Because of that, our swift code needs to be public, so we're creating a second module called SentryPrivate, where all swift code will be, and we need an extra cocoapod library. | ||
With this approach, classes from SentryPrivate will not be available when users import Sentry. | ||
We don't mind breaking changes in SentryPrivate, because this is not meant to be use by the user, we going to point this out in the docs. | ||
|
||
|
||
## Writing breadcrumbs to disk in the main thread | ||
|
||
Date: November 15, 2022 | ||
Contributors: @kevinrenskers, @brustolin and @philipphofmann | ||
|
||
For the benefit of OOM crashes, we write breadcrumbs to disk; see https://github.com/getsentry/sentry-cocoa/pull/2347. We have decided to do this in the main thread to ensure we're not missing out on any breadcrumbs. It's mainly the last breadcrumb(s) that are important to figure out what is causing an OOM. And since we're only appending to an open file stream, the overhead is acceptable compared to the benefit of having accurate breadcrumbs. | ||
|
||
## Bump min Xcode version to 13 | ||
|
||
With adding the [MetricKit integration](https://github.com/getsentry/sentry-cocoa/issues/1661), we need to bump the min Xcode version to 13, | ||
as MetricKit is unavailable on previous Xcode versions. As Xcode 12 doesn't run on macOS 12, and the current Xcode version is 14, we are OK | ||
with that change. With that change, we also have to drop support for | ||
[building platform-specific framework bundles](https://github.com/Carthage/Carthage/tree/a91d086ceaffef65c4a4a761108f3f32c519940c#building-platform-specific-framework-bundles-default-for-xcode-11-and-below) | ||
with Carthage, which was the default for Xcode 11 and below, because the | ||
[workaround](https://github.com/Carthage/Carthage/blob/a91d086ceaffef65c4a4a761108f3f32c519940c/Documentation/Xcode12Workaround.md) for creating a | ||
platform-specific framework bundles only works with Xcode 12. | ||
Carthage has encouraged its users [to use XCFrameworks](https://github.com/Carthage/Carthage/tree/a91d086ceaffef65c4a4a761108f3f32c519940c#getting-started) | ||
since version 0.37.0, released in January 2021. Therefore, it's acceptable to use XCFrameworks for Carthage users. | ||
|
||
## Remove the permissions feature | ||
|
||
Date: December 14, 2022 | ||
|
||
We [removed](https://github.com/getsentry/sentry-cocoa/pull/2529) the permissions feature that we added in [7.24.0](https://github.com/getsentry/sentry-cocoa/releases/tag/7.24.0). Multiple people reported getting denied in app review because of permission access without the corresponding Info.plist entry: see [#2528](https://github.com/getsentry/sentry-cocoa/issues/2528) and [2065](https://github.com/getsentry/sentry-cocoa/issues/2065). | ||
|
||
## Rename master to main | ||
|
||
Date: January 16th, 2023 | ||
Contributors: @kahest, @brustolin and @philipphofmann | ||
|
||
With 8.0.0, we rename the default branch from `master` to `main`. We will keep the `master` branch for backwards compatibility for package managers pointing to the `master` branch. | ||
|
||
## SentrySwiftUI version | ||
|
||
Date: January 18th, 2023 | ||
Contributors: @brustolin and @philipphofmann | ||
|
||
We release experimental SentrySwiftUI cocoa package with the version 8.0.0 because all podspecs file in a repo need to have the same version. | ||
|
||
## Tracking package managers | ||
|
||
To be able to identify the package manager(PM) being used by the user, we need that the PM identify itself. | ||
Luckily all of the 3 PMs we support do this in some way, mostly by exposing a compiler directive (SPM, COCOA) | ||
or a build setting (CARTHAGE). With this information we can create a conditional compilation that injects the name of | ||
the PM. You can find this in `SentrySDKInfo.m`. | ||
|
||
## Usage of `__has_include` | ||
|
||
Some private headers add a dependency of a public header, when those private headers are used in a sample project, or referenced from a hybrid SDK, it is treated as part of the project using it, therefore, if it points to a header that is not part of said project, a compilation error will occur. To solve this we make use of `__has_include` to try to point to the SDK version of the header, or to fallback to the direct reference when compiling the SDK. | ||
|
||
## Remove running unit tests on iOS 12 simulators <a name="remove-ios-12-simulators"></a> | ||
|
||
Date: April 12th 2023 | ||
Contributors: @philipphofmann | ||
|
||
We use [`xcode-install`](https://github.com/xcpretty/xcode-install) to install some older iOS simulators for test runs [here](https://github.com/getsentry/sentry-cocoa/blob/ff5c1d83bf601bbcd0f5f1070c3abf05310881bd/.github/workflows/test.yml#L174) and [here](https://github.com/getsentry/sentry-cocoa/blob/ff5c1d83bf601bbcd0f5f1070c3abf05310881bd/.github/workflows/test.yml#L343). That project is being sunset, so we would have to find an alternative. | ||
|
||
Installing the simulator can take up to 15 minutes, so the current solution slows CI and sometimes leads to timeouts. | ||
We want our CI to be fast and reliable. Instead of running the unit tests on iOS 12, we run UI tests on an iPhone with iOS 12, | ||
which reduces the risk of breaking users on iOS 12. Our unit tests should primarily focus on business logic and shouldn't depend | ||
on specific iOS versions. If we have functionality that risks breaking on older iOS versions, we should write UI tests instead. | ||
For the swizzling of UIViewControllers and NSURLSession, we have UI tests running on iOS 12. Therefore, dropping running unit | ||
tests on iOS 12 simulators is acceptable. This decision reverts [manually installing iOS 12 simulators](#ios-12-simulators). | ||
|
||
Related to [GH-2862](https://github.com/getsentry/sentry-cocoa/issues/2862) and | ||
|
||
## Remove integration tests from CI <a name="remove-integration-tests-from-ci"></a> | ||
|
||
Date: April 17th 2023 | ||
Contributors: @brustolin @philipphofmann | ||
|
||
Both Alamofire and Home Assistance integration tests are no longer reliable as they keep failing and causing more problems than adding value. | ||
These tests used to work for a while, and we know that the Sentry SDK was not breaking these projects. | ||
Therefore, we have decided to remove the tests and add some key files to our list of risk files. | ||
This way, if these files are changed, we will be reminded to test the changes with other projects. | ||
Additionally, two new 'make' commands(test-alamofire, test-homekit) are being added to the project to assist in testing the Sentry SDK in third-party projects. | ||
|
||
Related to [GH-2916](https://github.com/getsentry/sentry-cocoa/pull/2916) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters