Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Fastlane android building: index.android.bundle missing

I am building an app bundle (.aab) for our react native app.

When I build via Android Studio, app builds, deploys to Play Store. I download and run - everything works.

When I build via FastLane, app builds, deploys to Play Store. But I download and run, I get the following error:

E AndroidRuntime: java.lang.RuntimeException: Unable to load script. Make sure you're either running a Metro server (run 'react-native start') or that your bundle 'index.android.bundle' is packaged correctly for release.
E AndroidRuntime:   at com.facebook.react.bridge.CatalystInstanceImpl.jniLoadScriptFromAssets(Native Method)
E AndroidRuntime:   at com.facebook.react.bridge.CatalystInstanceImpl.loadScriptFromAssets(CatalystInstanceImpl.java:2)
E AndroidRuntime:   at com.facebook.react.bridge.JSBundleLoader$1.loadScript(JSBundleLoader.java:1)
E AndroidRuntime:   at com.facebook.react.bridge.CatalystInstanceImpl.runJSBundle(CatalystInstanceImpl.java:3)
W ActivityTaskManager:   Force finishing activity com.friday.pax.dev/com.friday.pax.MainActivity
RN: 0.63.4
Gradle: 4.1.1

FastLane Logs:

https://gist.githubusercontent.com/HardlyMirage/4426e411b6ec1e8abac5e7a620d979ae/raw/37daead0b55ee77b7ef7d6ddd8631d311dbc80aa/txt

index.android.bundle appears to be correctly generated.

> Task :app:bundleDevReleaseJsAndAssets
warning: the transform cache was reset.
Welcome to React Native!
Learn once, write anywhere
info Writing bundle output to:, /home/runner/work/fridayapp-pax/fridayapp-pax/android/app/build/generated/assets/react/dev/release/index.android.bundle
info Writing sourcemap output to:, /home/runner/work/fridayapp-pax/fridayapp-pax/android/app/build/generated/sourcemaps/react/dev/release/index.android.bundle.map
info Done writing bundle output
info Done writing sourcemap output
info Copying 88 asset files
info Done copying assets

Task :app:mergeDevReleaseResources is run after Task :app:copyDevReleaseBundledJs

FastFile:


def getVersionCode
  # Instead of managing the version code manually it is simply based on a timestamp in sec
  # Any build done more recently is considered to be a higher version
  # versionCode increase every minute (aka max 1 build per minute)
  # versionCode can't be smaller than legacyVersionCode
  thirtySeptemberTwentyTwenty = 1601480940 / 60
  legacyVersionCode = 10902
  versionCode = legacyVersionCode + (Time.now.to_i / 60) - thirtySeptemberTwentyTwenty

  if versionCode > 2100000000
    raise "versionCode cannot be higher than 2100000000"
  end

  versionCode.floor()
end

platform :android do

  desc "Friday (Dev)"
  lane :playstoreDevInternal do |options|
    
    # Retrieve version of my app in package.json (React Native case)
    package = load_json(json_path: "../package.json")

    # Clean build folder
    gradle(
      task: "clean"
    )

    # Bump android.defaultConfig.versionCode
    # bump_build_number
    android_set_version_code(
      version_code: package["versionName"]
    )

    # Do the bundle of the application  
    gradle(
      # task: "assemble",
      task: 'bundle',
      flavor: "dev",
      build_type: "Release",
      properties: {
        "android.injected.signing.store.file" => Dir.pwd + "/release.keystore",
        "android.injected.signing.store.password" => options[:RELEASE_KEYSTORE_PASSWORD], # keystore password
        "android.injected.signing.key.alias" => options[:RELEASE_KEYSTORE_ALIAS], # alias
        "android.injected.signing.key.password" => options[:RELEASE_KEYSTORE_KEY_PASSWORD], # key password
        "vname" => package["version"]
      }
    )

    # Upload Android App Bundle to PlayStore like Internal testing Release
    upload_to_play_store(
      package_name: 'com.friday.pax.dev',
      track: 'internal',
      release_status: 'draft',
      skip_upload_apk: true,
      version_name: package["version"]
    )
  end
end

Can anyone point out why the aab bundle from Android Studio works, but not the one generated via FastLane? Even though index.android.bundle is clearly generated.

My only thought is that perhaps the index.android.bundle path is incorrect. But I don't see a way of modifying that path.

like image 825
HyderA Avatar asked Aug 30 '21 10:08

HyderA


1 Answers

Turns out that the gradle scripts were generating the bundle into a build variant-specific folder, but the app was looking for the bundle in the default location, regardless of the build variant:

Gradle script generated bundle location (Flavor: dev, Type: release):

android/app/build/generated/assets/react/dev/release/index.android.bundle

App looking at location:

android/app/src/main/assets/index.android.bundle

So I added a script to package.json to generate this:

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

And prior to running the build command in my runner script, I run the script to generate the build:

npm run generate:build

The app now finds the bundle.

like image 102
HyderA Avatar answered Oct 31 '22 17:10

HyderA