We welcome suggested improvements and bug fixes for sentry-cocoa
, in the form of pull requests. Please follow our official Commit Guidelines and also prefix the title of your PR according to the Commit Guidelines. The guide below will help you get started, but if you have further questions, please feel free to reach out on Discord.
Run make init
to get started. This will install bundler
and Homebrew
and their managed dependencies (see Gemfile
and Brewfile
).
The tests depend on our test server. To run the automated tests, you first need to have the server running locally with
make run-test-server
Test guidelines:
- We write our tests in Swift. When touching a test file written in Objective-C consider converting it to Swift and then add your tests.
- Make use of the fixture pattern for test setup code. For examples, checkout SentryClientTest or SentryHttpTransportTests.
- Use TestData when possible to avoid setting up data classes with test values.
Test can either be ran inside from Xcode or via
make test
Please follow the convention of removing the copyright code comments at the top of files. We only keep them inside SentryCrash, as the code is based on KSCrash.
All Objective-C, C and C++ needs to be formatted with Clang Format. The configuration can be found in .clang-format
. Simply run the make task before submitting your changes for review:
make format
We use Swiftlint and Clang-Format. For Swiftlint we keep a seperate config file for the tests. To run all the linters locally execute:
make lint
Please use Sentry.xcworkspace
as the entry point when opening the project in Xcode. It also contains all samples for different environments.
To make a header public follow these steps:
- Move it into the folder Public. Both CocoaPods and Swift Package Manager make all headers in this folder public.
- Add it to the Umbrella Header Sentry.h.
- Set the target membership to public.
When contributing to the codebase, please make note of the following:
- Non-trivial PRs will not be accepted without tests (see above).
- Please do not bump version numbers yourself.