Appwright

Appwright is a test framework for e2e testing of mobile apps. Appwright builds on top of Appium, and can
run tests on local devices, emulators, and remote device farms — for both iOS and Android.
Appwright is one integrated package that combines an automation driver, test runner and test
reporter. To achieve this, Appwright uses the Playwright test runner internally, which is
purpose-built for the e2e testing workflow.
Appwright exposes an ergonomic API to automate user actions. These actions auto-wait and auto-retry
for UI elements to be ready and interactable, which makes your tests easier to read and maintain.
import { test, expect } from "appwright";
test("User can login", async ({ device }) => {
await device.getByText("Username").fill("admin");
await device.getByText("Password").fill("password");
await device.getByText("Login").tap();
});
Links to help you get started.
Usage
Minimum requirements
Install
npm i --save-dev appwright
touch appwright.config.ts
Configure
import { defineConfig, Platform } from "appwright";
export default defineConfig({
projects: [
{
name: "android",
use: {
platform: Platform.ANDROID,
device: {
provider: "emulator",
},
buildPath: "app-release.apk",
},
},
{
name: "ios",
use: {
platform: Platform.IOS,
device: {
provider: "emulator",
},
buildPath: "app-release.app",
},
},
],
});
Configuration Options
-
platform
: The platform you want to test on, such as 'android' or 'ios'.
-
provider
: The device provider where you want to run your tests.
You can choose between browserstack
, lambdatest
, emulator
, or local-device
.
-
buildPath
: The path to your build file. For Android, it should be an APK file.
For iOS, if you are running tests on real device, it should be an .ipa
file. For running tests on an emulator, it should be a .app
file.
Run tests
To run tests, you need to specify the project name with --project
flag.
npx appwright test --project android
npx appwright test --project ios
Run tests on BrowserStack
Appwright supports BrowserStack out of the box. To run tests on BrowserStack, configure
the provider in your config.
{
name: "android",
use: {
platform: Platform.ANDROID,
device: {
provider: "browserstack",
name: "Google Pixel 8",
osVersion: "14.0",
},
buildPath: "app-release.apk",
},
},
Run tests on LambdaTest
Appwright supports LambdaTest out of the box. To run tests on LambdaTest, configure
the provider in your config.
{
name: "android",
use: {
platform: Platform.ANDROID,
device: {
provider: "lambdatest",
name: "Pixel 8",
osVersion: "14",
},
buildPath: "app-release.apk",
},
},
Run the sample project
To run the sample project:
- Navigate to the
example
directory.
cd example
npm install
Run the following command to execute tests on an Android emulator:
npx appwright test --project android
To run the tests on iOS simulator:
- Unzip the
wikipedia.zip
file
npm run extract:app
- Run the following command:
npx appwright test --project ios
Docs