-
Notifications
You must be signed in to change notification settings - Fork 533
Gradle Bazel Migration Best Practices and FAQ
The following document explains best practices & provides support for the Gradle to Bazel migration. For more information on setting up Bazel, read Oppia Bazel Setup Instructions.
This is a living document that will grow as more questions get asked and answered.
Currently, the libraries in a module's BUILD.bazel file contain most of their dependencies as files in srcs dependencies. We are going to break out smaller pieces of these source files into their own libraries. Eventually, the module libraries will depend on a smaller set of these libraries as its direct dependencies.
In the following example, we have a set of dependencies that are specific to a KotlinFile.kt file. We have an ExampleLibrary that has both the Kotlin file as srcs dependency and the underlying deps dependencies as its own direct deps dependencies.
When we create a new library, we can move this set of dependencies to the new library.
This is not always possible, since there might be other files relying on the same dependencies so in our transition phase we can end up with something like this:
- Build early and build often. This will help you catch issues and Bazel can also suggest dependencies to add to your library in some cases.
- Look at other BUILD.bazel files in the codebase for an idea on how to lay out packages.
- Migrating files will always involve introducing new libraries, and then hooking those up to the top-level module libraries. There are ways of making this a bit easier:
- While performing the migration, focus on making sure the new library builds first, e.g.:
bazel build //<module>/src/main/java/org/oppia/app/<module>/<subdirectory>:all
. - After the new libraries contain all of the files they need to, their dependencies are correct, and they build, make sure the app also builds by running:
bazel build //:oppia
.
- While performing the migration, focus on making sure the new library builds first, e.g.:
- Remove all source files from the module's BUILD.bazel file that are now contained in the new BUILD.bazel file
- Add the new BUILD.bazel file libraries as dependencies for the module's top-level library (these dependencies should be changed in the same library whose source files were updated in #1).
- Try to remove the dependencies that the new BUILD.bazel file's libraries depend on from the old libraries whose source files were changed (note that these may still be needed by existing source files in those libraries). This can be done by removing each dependency one-at-a-time and trying to rebuild the library to see if the library builds.
If you are getting something similar to this:
Traceback (most recent call last):
File "/home/titan/.cache/bazel/_bazel_titan/d2121258671c00ac2cf78dbca73dac8b/external/rules_jvm_external/coursier.bzl", line 467, column 17, in _coursier_fetch_impl
fail("Error while obtaining the sha256 checksum of "
Error in fail: Error while obtaining the sha256 checksum of v1/https/maven.google.com/android/arch/core/common/1.1.1/common-1.1.1.jar: src/main/tools/process-wrapper-legacy.cc:80: "execvp(python, ...)": No such file or directory
From the error trace, we see that the tool can't find python. Make sure that you have python in your PATH.
When installing the app, I see INSTALL_FAILED_VERSION_DOWNGRADE or INSTALL_FAILED_UPDATE_INCOMPATIBLE
In the event that, when trying to install a Bazel-built version of the app, you see one of the following errors:
adb: failed to install bazel-bin/oppia.apk: Failure [INSTALL_FAILED_VERSION_DOWNGRADE]
adb: failed to install bazel-bin/oppia.apk: Failure [INSTALL_FAILED_UPDATE_INCOMPATIBLE]
You will need to uninstall the existing version of the Oppia Android app and then try the installation again. You can either uninstall through the system's package menu UI, or run the following command:
adb shell pm uninstall org.oppia.android
(If the command above works correctly, you will see 'Success' in the output).
Have an idea for how to improve the wiki? Please help make our documentation better by following our instructions for contributing to the wiki.
Core documentation
Developing Oppia
- Contributing to Oppia Android
- Bazel
- Key Workflows
- Testing
- Developing Skills
- Frequent Errors and Solutions
- RTL Guidelines
- Working on UI
- Writing Design Docs
Developer Reference
- Code style
- Background Processing
- Dark mode
- Buf Guide
- Firebase Console Guide
- Platform Parameters & Feature Flags
- Work Manager
- Dependency Injection with Dagger
- Revert & regression policy
- Upgrading target SDK version
- Spotlight Guide
- Triaging Process
- Bazel
- Internationalization
- Terminology in Oppia
- Past Events