Skip to content

Commit

Permalink
Merge pull request #424 from nimblehq/chore/#422-wiki-fastlane
Browse files Browse the repository at this point in the history
[#422] [Chore] [Wiki] Update the Fastlane page
  • Loading branch information
vnntsu authored Jan 31, 2023
2 parents 054d083 + 530e66e commit 999a6b7
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 54 deletions.
104 changes: 50 additions & 54 deletions .github/wiki/Fastlane.md
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.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 999a6b7

Please sign in to comment.