-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
[#422] [Chore] [Wiki] Update the Fastlane page
- Loading branch information
Showing
2 changed files
with
50 additions
and
54 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 |
---|---|---|
@@ -1,150 +1,146 @@ | ||
Fastlane is a part of the automation tool for the development and release process of the project. This document will mention some crucial parts of the pipeline. | ||
Fastlane is a part of the automation tool for the development and release process of the project. By converting to Fastlane.swift, we can now write our configuration using Xcode in Swift - the language we know and love from the world of iOS development. This document will mention some crucial parts of the pipeline. | ||
|
||
<img src="assets/images/infrastructure/fastlane/fastlane.png" width=300> | ||
|
||
## Fastfile | ||
|
||
### Build and test | ||
|
||
The lane `build_and_test` helps build and test the application with the configuration of the test scheme and test target defined in the `Constants.rb` file. | ||
The lane `buildAndTest` helps build and test the application with the configuration of the test scheme and test target defined in the `Constant.swift` file. | ||
|
||
Example: | ||
|
||
``` | ||
$ bundle exec fastlane build_and_test | ||
$ bundle exec fastlane buildAndTest | ||
``` | ||
|
||
After running this lane, it is able to generate the code coverage report. | ||
After running this lane successfully, it will generate the code coverage report. | ||
|
||
> See more: | ||
> | ||
> - [Constants.rb](#constantsrb) | ||
> - [Constant.swift](#constantswift) | ||
### Synchronize the provisioning profile | ||
|
||
As the developer team has many developers, it is recommended to synchronize the certificates and profiles across the team during the development process. | ||
|
||
The `fastlane match` is here for sharing one code signing identity across the development team to simplify the codesigning setup and prevent code signing issues. | ||
|
||
To synchronize the machine with the certificate and profiles which is stored in a match repository, please use the following lanes: | ||
To synchronize the machine with the certificates and profiles, which are stored in a match repository, please use the following lanes: | ||
|
||
| `sync_development_signing` | `sync_adhoc_signing` | `sync_adhoc_production_signing` | `sync_appstore_signing` | | ||
| `syncDevelopmentCodeSigning` | `syncAdHocStagingCodeSigning` | `syncAdHocProductionCodeSigning` | `syncAppStoreCodeSigning` | | ||
|---|---|---|---| | ||
| Synchronize with the development distribution. | Synchronize with the Ad Hoc distribution for the Staging build. | Synchronize with the Ad Hoc distribution for the Production build. | Synchronize with the App Store Connect distribution. | | ||
| Synchronize the Development match signing for the Staging build. | Synchronize the Ad Hoc match signing for the Staging build. | Synchronize the Ad Hoc match signing for the Production build. | Synchronize the App Store match signing for the Production build. | | ||
|
||
|
||
Example: | ||
|
||
``` | ||
$ bundle exec fastlane sync_development_signing | ||
$ bundle exec fastlane sync_adhoc_signing | ||
$ bundle exec fastlane sync_adhoc_production_signing | ||
$ bundle exec fastlane sync_appstore_signing | ||
$ bundle exec fastlane syncDevelopmentCodeSigning | ||
$ bundle exec fastlane syncAdHocStagingCodeSigning | ||
$ bundle exec fastlane syncAdHocProductionCodeSigning | ||
$ bundle exec fastlane syncAppStoreCodeSigning | ||
``` | ||
|
||
### Register a new device | ||
|
||
To register a new device and synchronize the new device across the development team, use the lane `register_new_device` and provide the device UDID along with the device name: | ||
To register a new device and synchronize the new device across the development team, use the lane `registerNewDevice` and provide the device UDID along with the device name: | ||
|
||
Example: | ||
|
||
``` | ||
$ bundle exec fastlane register_new_device | ||
$ bundle exec fastlane registerNewDevice | ||
``` | ||
|
||
### Build and upload the application | ||
|
||
So as to build and upload the application to distribution tools, like Firebase or App Store Connect, please use these lanes: | ||
To build and upload the application to distribution platforms, like Firebase or App Store Connect, please use these lanes: | ||
|
||
| `build_and_upload_staging_app` | `build_and_upload_production_app` | `build_and_upload_appstore_app` | | ||
|---|---|---| | ||
| To upload the Staging build and Staging dSYM file to Firebase. | To upload the Production build and Production dSYM file to Firebase. | To upload the Production build to App Store and Testflight. | | ||
| `buildStagingAndUploadToFirebase` | `buildProductionAndUploadToFirebase` | `buildAndUploadToAppStore` | `buildAndUploadToTestFlight` | | ||
|---|---|---|---| | ||
| To upload the Staging build and Staging dSYM file to Firebase. | To upload the Production build and Production dSYM file to Firebase. | To upload the Production build to App Store. | To upload the Production build to TestFlight. | | ||
|
||
Example: | ||
|
||
``` | ||
$ bundle exec fastlane build_and_upload_staging_app | ||
$ bundle exec fastlane build_and_upload_production_app | ||
$ bundle exec fastlane build_and_upload_appstore_app | ||
$ bundle exec fastlane buildStagingAndUploadToFirebase | ||
$ bundle exec fastlane buildProductionAndUploadToFirebase | ||
$ bundle exec fastlane buildAndUploadToAppStore | ||
$ bundle exec fastlane buildAndUploadToTestFlight | ||
``` | ||
|
||
> See more: | ||
> | ||
> - [Gymfile](#gymfile) | ||
> - [BuildManager.rb](#buildmanagerrb) | ||
> - [DistributionManager.rb](#distributionmanagerrb) | ||
> - [Build.swift](#buildswift) | ||
> - [Distribution.swift](#distributionswift) | ||
|
||
## Matchfile | ||
|
||
Define the basic information to synchronize the certificates and profiles across the development team. | ||
Define the essential information to synchronize the certificates and profiles across the development team. | ||
|
||
> See more: | ||
> | ||
> - [MatchManager.rb](#matchmanagerrb) | ||
> - [Match.swift](#matchswift) | ||
> - [Synchronize the provisioning profile](#synchronize-the-provisioning-profile) | ||
## Gymfile | ||
|
||
Store defaults parameters when triggering a new build. | ||
|
||
## Constants folder | ||
|
||
### Constants.rb | ||
### Constant.swift | ||
|
||
Contains the key/value pairs of constants that will be used during the development and release process. | ||
Contains the key/value pairs of constants used during the development and release process. | ||
|
||
### Environments.rb | ||
### Secret.swift | ||
|
||
Contains the key/value pairs of environment variables that will be used during the development and release process. | ||
Contains the key/value pairs of environment variables used during the development and release process. | ||
|
||
## Managers folder | ||
|
||
### BuildManager.rb | ||
### Build.swift | ||
|
||
The `BuildManager` helps build and sign the application. There are two main functions: | ||
`Build.swift` helps build and sign the application. There are two main functions: | ||
|
||
| `build_ad_hoc` | `build_app_store` | | ||
| `adHoc` | `appStore` | | ||
|---|---| | ||
| Build and sign the application with the `ad-hoc` distribution. | Build and sign the application with the `app-store` distribution. | | ||
| Build and sign the application with the `adHoc` distribution and the environment parameter (`staging` or `production`) | Build and sign the application with the `appStore` distribution. | | ||
|
||
> See more: | ||
> | ||
> - [Build and upload the application](#build-and-upload-the-application) | ||
### DistributionManager.rb | ||
### Distribution.swift | ||
|
||
The `DistributionManager` is in charge of distributing the build to the distribution tools, such as Firebase, App Store Connect, and Testflight. | ||
`Distribution.swift` is in charge of distributing the build to the distribution platforms, such as Firebase, App Store Connect, and Testflight. | ||
|
||
> See more: | ||
> | ||
> - [Build and upload the application](#build-and-upload-the-application) | ||
### MatchManager.rb | ||
### Match.swift | ||
|
||
The responsibility of `MatchManager` is to synchronize the certificates and profiles across the team during the development process. | ||
The responsibility of `Match` is to synchronize the teams' certificates and profiles during the development process. | ||
|
||
> See more: | ||
> | ||
> - [Synchronize the provisioning profile](#synchronize-the-provisioning-profile) | ||
> - [Matchfile](#matchfile) | ||
### SymbolManager.rb | ||
### Symbol.swift | ||
|
||
Technically, the debug Symbol file (dSYM file) is used to de-obfuscate stack traces from crashes happening on the production app. The dSYM files store the debug symbols for the application. Then services (like Crashlytics) use the dSYM files to replace the symbols in the crash reports with the originating locations in the source code. Hence, the crash reports will be more readable and understandable. | ||
Technically, the debug Symbol file (dSYM file) is used to de-obfuscate stack traces from crashes on the production app. The dSYM files store the debug symbols for the application. Then services (like Crashlytics) use the dSYM files to replace the symbols in the crash reports with the originating locations in the source code. Hence, the crash reports will be more readable and understandable. | ||
|
||
The `SymbolManager` helps process and upload dSYM file to Firebase. There are two main functions: | ||
The `Symbol` helps process and upload dSYM file to Firebase. There is only one primary function: | ||
|
||
| `upload_built_symbol_to_firebase` | `download_processed_dsym_then_upload_to_firebase` | | ||
|---|---| | ||
| Directly upload the built dSYM file to Crashlytics. | Download the processed dSYM file from App Store Connect, then upload it to Crashlytics. | | ||
| It is recommended to use this function when the build configuration is `Release Staging`. | It is recommended to use this function when the build configuration is `Release Production`. | | ||
| See more: [Debug Symbol File](Project-Configurations.md#debug-symbol-file) | See more: [Debug Symbol File](Project-Configurations.md#debug-symbol-file) and [Enable Bitcode](Project-Configurations.md#enable-bitcode) | | ||
| `uploadToCrashlytics` | | ||
|---| | ||
| Directly upload the built dSYM file to Crashlytics with the environment parameter (`staging` or `production`). | | ||
| It is recommended to use this function when the build configuration is `Release Staging` or `Release Production`. | | ||
| See more: [Debug Symbol File](Project-Configurations.md#debug-symbol-file) | | ||
|
||
### TestManager.rb | ||
### Test.swift | ||
|
||
The `TestManager` helps build and test the application. | ||
The `Test` helps build and test the application. | ||
|
||
### VersioningManager.rb | ||
### Version.swift | ||
|
||
The `VersioningManager` manages the build number and version number of the application. | ||
The `Version` manages the application's build number and version number. |
Binary file modified
BIN
-160 KB
(16%)
.github/wiki/assets/images/infrastructure/fastlane/fastlane.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.