5
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

ReactNative(Android)でビルドバリアント毎にapk出力(署名つき)

Last updated at Posted at 2019-01-23

Build Variantで環境と署名を分けている時に、terminalで署名つきapkを吐き出す方法について書きます。
リリースビルドする時にbundleが更新されず、コードの差分が反映されない事があったので、その対応もしました。

##前提

Build Variantが以下の構成で、

Flavor Build Type BuildVariant
develop debug developDebug
develop release developRelease
staging debug stagingDebug
staging release stagingRelease
staging debug productionDebug
staging release productionRelease

かつ以下のように署名がフレーバー毎に分かれているとします。

    productFlavors {
        production {
            applicationId 'com.hoge'
            signingConfig signingConfigs.production
        }
        staging {
            applicationId 'com.hoge.staging'
            signingConfig signingConfigs.develop
        }
        develop {
            applicationId 'com.hoge.develop'
            signingConfig signingConfigs.develop
        }
    }

Build Variantについて、およびFlavor毎のsigningConfigの切り分け方については、以前書いたReactNativeのAndroid側でFlavorで環境を切り分けるもご参照ください。

terminalでapkを吐き出す方法

既に署名はbuilg.gradleにbuildFlavor毎に定義しているので、以下のようにコマンドを打つだけで署名つきのapkを吐き出してくれます。

developReleaseを吐き出す時

cd android
./gradlew assembleDevelop

stagingReleaseを吐き出す時

cd android
./gradlew assembleStaging

productionReleaseを吐き出す時

cd android
./gradlew assembleProduction

##吐き出されるapkの場所

android/app/build/outputs/apk...に配置されます。

developReleaseを吐き出した時

android/app/build/outputs/apk/develop/release/app-develop-release.apk

stagingReleaseを吐き出した時

android/app/build/outputs/apk/staging/release/app-staging-release.apk

productionReleaseを吐き出した時

android/app/build/outputs/apk/production/release/app-production-release.apk

##吐き出されたapkの署名を確認

[Android] apk 署名 確認などをご参照ください。

##はまったところ(bundleの更新)

今回のbuild variant云々とは関係なく、以前ビルドしようとした時に

Unable to load script from assets index.android.bundle

というエラーに悩まされ、

ReactNative Androidで 『Unable to load script from assets index.android.bundle』エラーが出た時の対処法などを参考にしながらpackage.jsonに以下のスクリプトを書いていました。

"android-reset-bundle": "react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res",

以下で実行

yarn android-reset-bundle

ただ、調査不足なのかもしれないですが、なんだかリリースビルドをするたびに上記コマンドを打たないと、ソースコードの差分が反映されないということに悩んでいました。

リリースビルドをするたびにこのbundleが自動で更新されれば良いのですが、何故かやってくれない。
だから、android-reset-bundleをし忘れると、前回作ったbundleが読み込まれてしまって、差分が反映されていないのかなと(間違っていたらご指摘ください!)
iOSだと、こういうの必要なく、アーカイブする毎に自動で最新bundleを生成してくれるようですが。

ただ毎回android-reset-bundleをしてからapk書き出すのも面倒だし保守的にも漏れの元なので、こいつらをまとめたスクリプトを書きました。

  "scripts": {
    "android-reset-bundle": "react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res",
    "android-release-develop": "yarn android-reset-bundle && cd android && ./gradlew assembleDevelop",
    "android-release-staging": "yarn android-reset-bundle && cd android && ./gradlew assembleStaging",
    "android-release-production": "yarn android-reset-bundle && cd android && ./gradlew assembleProduction",
  },

これにより、例えば

yarn android-release-develop

と打てば、bundleの再生性とapkの書き出しまでを同時にやってくれます。

以上です。

5
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?