This document describes how to build and test Accessibility Insights for Android (the Electron app). Much of the information/code is shared between it and Accessibility Insights for Web (the browser extension); see Building Accessibility Insights for Web for the shared and web-specific guidance.
Throughout most of the code and build commands, Accessibility Insights for Android is referred to as "unified"; this is because we expect it may eventually serve as a client for accessibility assessments of many different platforms, not just Android. Today, Android is the only platform the "unified" app supports, and you can generally think of "unified" and "for Android" interchangeably.
All the prerequisites for building Web are also required for Unified.
# One-time build
yarn build:unified
# Continuously rebuilds as you modify files
yarn watch:build:unified
# Build all release variants (rarely necessary, only if modifying release infrastructure)
yarn build:unified:all
Most of the functionality of Unified relies on connecting to a device running the Accessibility Insights for Android Service. However, most Unified development and testing does not require an actual Android device/VM; this repository comes with a mock-service-for-android
that can be used to fake having one for most purposes.
# This is the command you'll want to use most of the time
# In the app, use port 9051 for the mock service
yarn with:mock-service-for-android start:unified:dev
# You can leave off the :dev if you don't want the "inspect" window
yarn with:mock-service-for-android start:unified
If you do need to work with an actual Android device/VM, you'll want to install Android Studio and use it to connect to a device and/or start an emulator. You'll need to install the Accessibility Insights for Android Service beforehand; see Getting Started with Accessiblity Insights for Android for instructions on how to prepare a device/emulator with the Accessibility Insights for Android Service (follow its steps up until "Install the Accessibility Insights for Android app").
# You can leave off the with:mock-service-for-android if
# you only want to test against real devices/emulators
yarn start:unified:dev
Unit tests use exactly the same commands as in Web (yarn test
, etc). See Building Accessibility Insights for Web: Unit Tests.
End-to-end tests for Unified are separated from Web's end-to-end tests. To run them:
# Run all unified E2E tests
yarn test:unified
# Update snapshots
yarn test:unified -u
To debug the built app in Code, you can run the Debug electron main process with --remote-debugging-port=9222
configuration. Once this is running, you can debug the renderer process via the Attach debugger to electron renderer process
configuration.
To debug the renderer process, you can run the application with yarn start:unified:dev
. This will start the dev flavor of the unified app with the environment variable 'DEV_MODE' set to 'true'. The app should open with a detached DevTools instance. See more info here. This allows you to inspect the DOM, programmatically set feature flags (e.g. featureFlagsController.enableFeature("logTelemetryToConsole")
), or modify persisted data in the Application tab. You can set this environment variable user/system-wide if needed for non-dev-flavor workflows.