iOSアプリ開発においてよくある環境ごとにアプリ名やアイコンを切り替える方法をいっつも忘れてググるので備忘録としてまとめてみました
前提
環境別
- Develop(開発用サーバ)
- Staging(ステージングサーバ)
- Production(本番サーバ)
状況別
- Debug(デバッグビルド、デバッグ情報などを付与する)
- Release(本番ビルド)
の合計6種類となる組み合わせを前提とします
各自の状況に合わせてここは好みで変更するとよろしです(これで十分なプロダクトが多いと思うけど)
分岐させるところ
Configurations
[PROJECT] -> [Info] -> [Configurations]から以下の6つを作成します
作成時はDebugのものは元からあるDebugスキーマから複製して作成し、ReleaseのものはReleaseスキーマから複製すること
Configuration名 | 用途 | 運用方針 |
---|---|---|
Develop_Debug | 個人環境での開発用 | 開発用サーバへアクセスしつつデバッグ情報などを表示させる |
Develop_Release | 個人環境でのテスト用 | 開発用サーバへアクセスしつつデバッグ情報などは表示させない |
Staging_Debug | ステージング環境での開発用 | ステージングサーバへアクセスしつつデバッグ情報などを表示させる |
Staging_Release | ステージング環境でのテストや社内配布用 | ステージングサーバへアクセスしつつデバッグ情報などは表示させない |
Production_Debug | 本番環境でデバッグしたい時に | 本番サーバへアクセスしつつデバッグ情報などを表示させる |
Production_Release | 本番リリース用 | 本番サーバへアクセスしつつデバッグ情報などは表示させない |
![スクリーンショット 2017-12-12 22.27.54.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F129872%2F7719ab65-b10a-f29b-de1d-07da86c2329d.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=f56fbff8efa6cb3d8c6c5d187effe0f5)
Scheme
スキーマは環境別分(今回は3種類)用意します。
種類 | 環境割当て |
---|---|
[APP_NAME]_Develop | develop版 |
[APP_NAME]_Staging | staging版 |
[APP_NAME]_Production | production版 |
![スクリーンショット 2017-12-12 22.55.37.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F129872%2F39a318c1-3b07-3b8c-f990-c7a0fbd0d9ee.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=6921b7e4383f09a4f226b95d95bbb4e7)
さらにスキーマ編集からRun時はDebug版、Archive時はRelease版を必ず生成するようにしておくことで変更する手間が殆どいらず、リリース版に誤ってデバッグ情報が含まれてしまうなどの事故が防げると思います。
種類 | 状況割当て |
---|---|
Run | debug版 |
Test | Release版 |
Profile | Release版 |
Analyze | Debug版 |
Archive | Release版 |
![スクリーンショット 2017-12-12 22.57.36.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F129872%2F9a659ce6-e7eb-b55c-dfb1-ed8d2051edd3.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=32cd4251dbf52a8304321e3f927aad5a)
この設定を3つすべてのスキーマに対してそれぞれ行います。
なお、余談ですがスキーマ編集画面ののSharedチェックボックスはつけておくのがおすすめです。Sharedをつけることでリポジトリに含めることができるので、開発PCが変わったときや複数人での開発においてスキーマ設定を共有できるため効果を発揮します
Product Bundle Identifier
Configuration別にBundle IDを変更して異なるアプリとしてそれぞれ並列にインストールできるようにすると捗ります。
[TARGET] -> [Build Settings] -> [Product Bundle Identifier]からプルダウンを開いてConfiguration別に異なるBundle IDを割り当てます。
特にこだわりがなければSuffix形式にConfiguration名を付与するのがオススメ
Configuration | Bundle ID |
---|---|
Develop_Debug | [ORIGINAL_BUNDLE_ID].develop.debug |
Develop_Release | [ORIGINAL_BUNDLE_ID].develop |
Staging_Debug | [ORIGINAL_BUNDLE_ID].staging.debug |
Staging_Release | [ORIGINAL_BUNDLE_ID].staging |
Production_Debug | [ORIGINAL_BUNDLE_ID].debug |
Production_Release | [ORIGINAL_BUNDLE_ID] |
![スクリーンショット 2017-12-12 22.40.29.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F129872%2F1cb6b027-a740-2717-060b-8a81d96460b2.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=75b50ac4d795cd3786f3905caeb6f9f9)
Product Name
アプリをインストールする際に紛らわしくならないように名前を替えておいたほうがいいでしょう
[TARGET] -> [Build Settings] -> [Product Name]からプルダウンを開いてConfiguration別に異なる名前を割り当てて下さい
![スクリーンショット 2017-12-12 22.40.51.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F129872%2Fedc9bbb8-15ed-a583-1051-30da9124d6e8.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=c7b18b39f187d48e1c97931737cefe56)
Asset Catalog App Icon Set Name
Product Nameと同様にアプリアイコンも変更するとわかりやすいかもです
[TARGET] -> [Build Settings] -> [Asset Catalog App Icon Set Name]からプルダウンを開いてConfiguration別に異なるアイコンを用意して割り当てて下さい
![スクリーンショット 2017-12-12 23.02.05.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F129872%2Fac3676fa-a0a0-2441-614c-9b3fe478ff40.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=a6ebc7c54321c61e7fd81c33e9d4f087)
アイコンはひと目でStagingやDebugだとわかるものがよいかと。(スクショのはサンプルなのであんまわかりやすくないですがw)
![スクリーンショット 2017-12-12 22.50.26.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F129872%2Fddb07bea-5f70-b119-1cd8-866e411f6d86.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=d3f882c03a1569228a4e36a6ade1370f)
コード上でのConfigurations別分岐
コード上でConfigurations別に条件分岐する場合はマクロを設定します。
[PROJECT] -> [Build Settings] -> [Other Swift Flags]からプルダウンを開いてConfiguration別に-D PRODUCTION_RELEASE
等の異なる値を入力しておきます。
Configuration | 設定値 |
---|---|
Develop_Debug | -D DEVELOP_DEBUG |
Develop_Release | -D DEVELOP_RELEASE |
Staging_Debug | -D STAGING_DEBUG |
Staging_Release | -D STAGING_RELEASE |
Production_Debug | -D PRODUCTION_DEBUG |
Production_Release | -D PRODUCTION_RELEASE |
![スクリーンショット 2017-12-12 22.52.54.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F129872%2Fd3c61e6d-c9c8-b708-f402-8ebb8702f5fd.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=7eed66efcfe06098d9b8efa6cedd60e7)
そしたら以下のような条件分岐を記載したクラスを作ります。
class Environment {
enum FlaverType {
case develop
case staging
case production
}
enum BuildType {
case debug
case release
}
static func getFlaverType() -> FlaverType {
#if DEVELOP_DEBUG
return .develop
#elseif DEVELOP_RELEASE
return .develop
#elseif STAGING_DEBUG
return .staging
#elseif STAGING_RELEASE
return .staging
#elseif PRODUCTION_DEBUG
return .production
#elseif PRODUCTION_RELEASE
return .production
#endif
}
static func getBuildType() -> BuildType {
#if DEVELOP_DEBUG
return .debug
#elseif DEVELOP_RELEASE
return .release
#elseif STAGING_DEBUG
return .debug
#elseif STAGING_RELEASE
return .release
#elseif PRODUCTION_DEBUG
return .debug
#elseif PRODUCTION_RELEASE
return .release
#endif
}
}
こうしておくことで環境別、状況別にコード分岐させやすくなります。
Targetは分けてない理由
Targetを分けるとアプリに含めるファイルを分離できたりして便利な面もある分、Build Settingsが2つになり、管理が面倒になるうえ、ぱっと見そのファイルがどのTargetに含まれるのか網羅的にみることができないのでヒューマンエラーの温床になるリスクのほうが高いと判断したためTargetは分けてないです。
ただ、依存関係の整理手段としてTargetを分離したり、コードを共有した別アプリとしてリリースしたりするのにはTarget切り替えは有効だと思います。