Building Firefox for Android
As a first step, you need to set up your development environment using the instruction here.
Before building, set the paths to your Java installation and Android SDK
macOS
export JAVA_HOME=$HOME/.mozbuild/jdk/jdk-<latest-version>/Contents/Home
export ANDROID_HOME=$HOME/.mozbuild/android-sdk-<os_name>
non-macOS
export JAVA_HOME=$HOME/.mozbuild/jdk/jdk-<latest-version>
export ANDROID_HOME=$HOME/.mozbuild/android-sdk-<os_name>
Build Fenix using command line
From the root mozilla-central directory, build Fenix:
./mach gradle clean fenix:assembleDebug
You can then find the generated debug apks in objdir under
gradle/build/mobile/android/fenix/outputs/apk/fenix/debug
To sign your release builds with your debug key automatically, add the following to <proj-root>/local.properties:
autosignReleaseWithDebugKey
Run Fenix or other Android projects using command line
You can run the following command to launch an emulator and install and run Fenix:
./mach run --app=fenix
Run Fenix tests
You can run tests via all the normal routes from within Android Studio:
For individual test files, click the little green play button at the top
For a module/component:
Right click in project explorer → run all tests
Select from gradle tasks window
If you see the error “Test events were not received”, check your top level folder - this happens if you try and run tests in Android Components from mozilla-unified/mobile/android/fenix/
.
To build tests for Android Components you need to be using the build.gradle
in mozilla-unified/mobile/android/android-components/
.
Alternatively, you can run tests from command line using:
./mach test <file-name>
to run all tests in the file
./mach test <directory-name>
to run all tests in the directory
./mach test {fenix,focus,ac,android-components,geckoview}
to run all tests in the specific project
If after running tests on your Android device, you can no longer long press, this is because the connected Android tests mess around with your phone’s accessibility settings. They set the long press delay to 3 seconds, which is an uncomfortably long time. To fix this, go to Settings → Accessibility → Touch and hold delay, and reset this to default or short (depends on manufacturer).
Lint
You can run the following commands to verify that your code is formatted correctly:
./mach lint -l android-fenix
to lint changes made in fenix directory
./mach lint -l android-focus
to lint changes made in focus directory
./mach lint -l android-ac
to lint changes made in android-components directory
You can find more linters by running ./mach lint --list
You can pass an extra argument --fix
to autofix certain types of reported issues.
Preset Try
It is advisable to run your tests before submitting your patch. You can do this using Mozilla’s try
server.
The following commands will ensure that all the required tests are run based on the changes made:
./mach try --preset fenix
- will run Fenix test suites
./mach try --preset firefox-android
- will run AC and Fenix test suites
./mach try --preset android-geckoview
- will run GeckoView test suites
Failures on try
will show up with the test name highlighted in orange. Select the test to find out more.
Intermittent failures occasionally occur due to issues with the test harness. Retriggering the test is a good way to confirm it is an intermittent failure and not due to the patch.
Usually there will also be a bug number with a portion of the stack trace as well for documented intermittent failures.
Speed Up the CI
Currently, the CI builds GeckoView even if your commit doesn’t impact it.
If you know your changes don’t impact GeckoView, you can try using the following option: --use-existing-tasks
or -E
. For example:
./mach try --preset firefox-android -E
This will try to reuse a GeckoView build from a previous CI job, and thus reduce the CI time.