32

Is it possible to build the APK of an expo app locally?

The doc says:

If you haven’t used exp before, the first thing you’ll need to do is login with your Expo account using exp login.

I tried exp start, exp build:android but the commands require a login.

I don't want to build the APK using expo server. Is there a way to run this build locally? So no login and push of source code required?

If not, can I view the whole source code of the generated APK?

3
  • If you use no expo imports in your project you can create a project with react-native-cli and copy your code. But if you use expo I don't have a solution yet.
    – Piu130
    Commented Dec 5, 2017 at 19:00
  • ok, will let you know once I have found anything. Thanks mate.
    – Sujit
    Commented Dec 6, 2017 at 10:05
  • Any chance you can accept my answer below, now that it leads to the official documentation? Tnx! Commented Aug 11, 2022 at 5:37

6 Answers 6

15

New to the party, so guessing this wasn't available at the time of the post - Instructions for building expo apps locally: Building Standalone Apps on Your CI

Update Jan, 2023:

You may want to check out the updated version:

This doc was archived in August 2022 and will not receive any further updates. SDK 46 is the last SDK supported by Classic Builds and the Classic Build service will stop running for all SDK versions after January 4, 2023. Check out Running builds on your own infrastructure and Triggering builds from CI.

1
  • 2
    This doc was archived in August 2022 and will not receive any further updates. SDK 46 is the last SDK supported by Classic Builds and the Classic Build service will stop running for all SDK versions after January 4, 2023
    – Yao
    Commented Jan 21, 2023 at 3:15
11

2024 up to date answer

The new way of building locally as described in the documentation is:

eas build --platform android --local
2
  • Still needs eas login, see my answer for no internet requirement
    – Daidon
    Commented Apr 4 at 3:26
  • 1
    Unsupported platform, macOS or Linux is required to build apps for Android Commented Jun 2 at 20:40
6

if you want to generate apk eject the CRNA with npm run eject command. Then you will get android and ios folders suppurate in mac and you will get an only android folder in windows. and follow the instruction which is in a given link below

"https://facebook.github.io/react-native/docs/signed-apk-android.html"

3

If you want to build the app locally without using the turtle CLI of expo, you can build it just how you would build a normal react native app
But beware that you will have to touch some native android code (gradle only) But only one or two files....

Steps:

  1. Generate a release Keystore by keytool
  2. Link the keystore in build.gradle file
  3. Run cd android && ./gradlew assembleRelease to build the apk

Check out this post to follow these steps in detail

3
  • This also works great in CI, like GitHub actions!
    – Jankapunkt
    Commented Jul 23, 2022 at 10:03
  • The expo project doesn't have android folder.
    – Sanan Ali
    Commented Feb 9, 2023 at 10:16
  • 1
    @SananAli You have to do expo run:android once to generate the folder
    – Esh
    Commented Feb 15, 2023 at 22:09
2

I've straggled with similar issue, I managed to solve it following several steps found on the web, and tweaking a bit: https://forums.expo.io/t/expokit-full-local-build-without-publish-android/31400/2

  1. Run the https server your machine, note that the server must have a certificate since it is a HTTPS server (I used port 4443), but it does not need to be trusted by your machine - it works anyway
    (I found it easy to use: https://gist.github.com/dergachev/7028596 - Python 2.7, https://gist.github.com/dergachev/7028596#gistcomment-1989299 - Python 3.X)

  2. Go to your Expo project folder, make sure there is no dist folder in it; alternatively you can provide dist path with the --output-dir flag (the react-native bundle and assets will be generated to it).

  3. Open command line and run:
    expo export -t bare --dev --public-url https://localhost:4443/, once done you will have the android bundle and assets in the output-dir (default - dist)

  4. Copy the android bundle from dist/bundles/android-<bunch of numbers (MD5)>.js to <YourExpoProjectFolder>/android/app/src/main/assets/index.android.bundle and to <YourExpoProjectFolder>/android/app/build/generated/assets/react/release/index.android.bundle
    (note: the name of the bundle must be index.android.bundle)
    In /dist/bundles/assets you'll have your assets files, but they would be named as their MD5 value, copy each of them to <YourExpoProjectFolder>/android/app/src/main/assets/, but add the asset_ prefix and .<ext> for each.
    e.g. for a PNG image file with MD5 value of de57a0c7a3a23aabcaceaf1185b1e79e: copy <YourExpoProjectFolder>/dist/bundles/assets/de57a0c7a3a23aabcaceaf1185b1e79e <YourExpoProjectFolder>/android/app/src/main/assets/asset_de57a0c7a3a23aabcaceaf1185b1e79e.png

  5. cd android

  6. gradlew.bat assemble

    expo diagnostics output:

      Expo CLI 3.18.6 environment info:
        System:
          OS: Windows 10 10.0.18363
        Binaries:
          Node: 12.16.2
          Yarn: 1.22.0
          npm: 6.14.4
        npmPackages:
          expo: ~37.0.3 => 37.0.8
          react: ~16.9.0 => 16.9.0
          react-native: ~0.61.5 => 0.61.5
          react-navigation: ^4.3.9 => 4.3.9


1
  • Update: In case you have additional assets, build may fail (on expo bundle-assets step) due to: <br/> forums.expo.io/t/… Note - Icon and the android bundle asset does not cause failure.
    – user514949
    Commented May 30, 2020 at 9:41
1

Motivation: build local, test performance of release build on a real device.

Environment: Expo SDK 46 managed project, on AlmaLinux 8.6 (ymmv)

Caution:

I keep a copy of my entire project dir in case things get messed up:

cd <project *parent* dir>
\cp -far <project dir name> <project dir name>.bak

and update that when appropriate with

cd <project dir> # if not there
rsync -atvi --delete . ../<project dir name>.bak/

Steps to create android project dirs/files and a debug build apk :

cd <project dir>
npx expo run:android # not the same as "npm run android"

see ref in official expo docs here

release build:

cd <projectDir>/android/app
keytool -genkey -v -keystore <projectName>.keystore -alias <<projectName>> -keyalg RSA -keysize 2048 -validity 10000

ammend android/app/build.gradle file - see details here but do not use the build instructions (atow). Then ...

cd ../../ # to project dir
npx expo run:android --no-install --no-bundler --variant release

(although tbh I'm guessing for now that --no-bundler is to do with the Metro server)

You should find a release apk in

<project dir>/android/app/build/outputs/apk/release

Note this includes full expo and the build can take quite a while. It took more than 12 mins on the following:

Operating System: AlmaLinux 8.6
KDE Plasma Version: 5.23.3
KDE Frameworks Version: 5.88.0
Qt Version: 5.15.2
Kernel Version: 4.18.0-372.32.1.el8_6.x86_64 (64-bit)
Graphics Platform: X11
Processors: 12 × Intel® Xeon® CPU E5-2620 v3 @ 2.40GHz
Memory: 31.1 GiB of RAM
Graphics Processor: AMD CEDAR

You can reduce build time and the final apk size by going for an expo development build or moving your code to a porn project (plain old react-native) :-)

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Not the answer you're looking for? Browse other questions tagged or ask your own question.