Integrate Emerge Snapshots for Android with Github Actions
Emerge's Snapshots product allows mobile teams to confidently ship UI changes in their app and be notified of regressions before they make it to production — without maintaining any extra test suites or code — by re-using the same Previews you write in Android Studio for regular feature development.
This guide shows how to get started with Emerge's Snapshots Testing for Android using Github and Github Actions so you can easily and visually see the changes you are making to your app's UI.
data:image/s3,"s3://crabby-images/091f4/091f42798a03cea8e566d77f9af32ca7dd7ce686" alt=""
Integration Steps
-
Create free account at emergetools.com
-
-
Go to your Emerge profile by clicking your email in the bottom left corner of the sidebar on emergetools.com.
-
Add the Emerge App your Github repository by clicking
Connect
underGitHub Connection
.More details on configuring the GitHub app and for GitHub enterprise.
-
Create an Emerge API key by clicking the
Generate API Key
button in the Organization Settings section of your Emerge profile. -
Add
EMERGE_API_TOKEN
as a Repository Secret to your Github repository in the repo setting.
https://github.com/<your-org>/<your-repo>/settings/secrets/actions
https://github.com/<your-org>/<your-repo>/settings/secrets/actions
-
-
Apply the Emerge Gradle Plugin to the
plugins
block of your application module'sbuild.gradle(.kts)
file:plugins { id("com.emergetools.android") version "x.y.z" }
plugins { id 'com.emergetools.android' version 'x.y.z' }
Latest Emerge Android Gradle Plugin
For more information on the Emerge Gradle Plugin, see our our documentation.
-
Execute the
emergeUploadSnapshotBundleDebug
task with theEMERGE_API_TOKEN
environment variable in your Github Actions workflow in order to run the task on both PR builds and master builds.Configure your workflow to execute this task with the
push
trigger for yourbase
branch and thepull_request
trigger for your pull request. Here is a full examplename: Upload Emerge Snapshot Bundle run: ./gradlew emergeUploadSnapshotBundleDebug env: EMERGE_API_TOKEN: ${{ secrets.EMERGE_API_TOKEN }}
-
Submit those changes as a pull request. The pull request will run a check that creates snapshots. Click on the
Checks
tab in the GitHub pull requests and click onEmerge Tools
thenSnapshot Test | Emerge
and you should see something that looks like the screenshot below. This means you have successfully integrated snapshot testing in your repository. Once the PR is merged to the main branch the automatic checks will start working on all future PRs.
data:image/s3,"s3://crabby-images/bbf08/bbf08688e313b96619e377d1d306bc9e09ae775d" alt=""
Using Snapshots
Emerge's Snapshots works by finding all the @Preview
annotated methods in your project and creating snapshots from them. These functions are called by Emerge Tools on every PR and main branch build in order to generate snapshots. Emerge Tools saves these snapshots on our servers to use for comparison.
Whenever any snapshots are added, removed or modified in a PR relative to the respective base build, you will get a comment on your PR. The comment will show you what has changed and you can click it for further details.
data:image/s3,"s3://crabby-images/e5e99/e5e99498faacb6380ada6884a52b136ba6278e36" alt=""
By default, Snapshot modifications will fail a check on the PR like below.
data:image/s3,"s3://crabby-images/42f8c/42f8c4e26076d6cde4c063d4290fc6782b8be809" alt=""
You can click details to understand what changes were made to your snapshots.
If they were accidental, you should fix them in the code. Otherwise, if the changes were intentional, you can set this check to green by clicking details and then approving the changes from within the Emerge Tools UI.
data:image/s3,"s3://crabby-images/3daf5/3daf5dc8d78893339cc2d7b83169d211eeb010c8" alt=""
You should be all set with Emerge Snapshot testing to be able to confidently ship UI changes!
For information and for more advanced configuration scenarios click here for our full Android Snapshots documentation. If you need any help, please contact our team.
Updated 1 day ago