appdriver

1.0.0-beta.2 • Public • Published

AppDriver

NPM Version GitHub License

A mobile focused test automation framework.

Get Started | API Reference | Native Demo App | Change Log

Notices

This project is currently in the Beta stages of development, meaning the framework is capable of handling general use cases but may be lacking some functionality, documentation and stability. If you're interested in the project's roadmap, feel free to check out the Projects tab.

Goal

The goal of this project is to offer a mobile focused E2E testing framework that's "batteries included". It should provide a familiar interface for running tests, an assertion library orientated around E2E testing, and first class support for common operations.

Motivation

After using WebdriverIO for over a year on a real world project, I found it frustrating to perform even basic tasks without spending hours writing helper function(s) or helplessly trying to figure out how to use the framework in the context of Appium.

The major Webdriver clients focus too heavily on the Web, giving the impression that mobile (via Appium) is an afterthought. I was frequently forced down a trial and error path as the documentation was either sparse or simply non-existent.

Initially, I started this project as a proof of concept, taking inspiration from Detox, WebdriverIO, WD.js, and Jest. I really liked the syntactic style of Detox and wanted to see how it might look when paired with the (Mobile) JSON Wire Protocol.

Unlike Webdriver clients, Detox is yet to support testing in the cloud and on real iOS devices. For me, this was a limitation I simply couldn't ignore. I feel it's critical in ensuring tests run quickly and provide the confidence that the application works as expected on a variety of real devices.

Examples

Tap interaction
(async () => {
  await element(by.label("button")).tap();
})();
Text entry
(async () => {
  const $textInput = await element(by.label("text-input"));
  
  await $textInput
    .tap()
    .typeText("Hello World!");
  
  await expect($textInput).toHaveValue("Hello World!");
})();
Swipe gesture
(async () => {
  await element(by.label("carousel-container"))
    .swipeLeft({ percentage: 0.75 });
  
  await expect(element(by.label("carousel-page-2"))).toBeVisible();
})();
Regex element matching
(async () => {
  const $items = await elements(by.label(/list-item-.*/));
  
  await expect($items).toHaveLength(3);
})();
Custom gestures
(async () => {
  const $box = await element(by.label("box"));
  const { x, y } = await $box.getLocation({ relative: true });
 
  const tap = gestures.series([
    gestures.moveTo({ x, y }),
    gestures.press(),
    gestures.wait(100),
    gestures.release()
  ]);
  
  await device.performGesture(tap);
})();

Readme

Keywords

none

Package Sidebar

Install

npm i appdriver

Weekly Downloads

22

Version

1.0.0-beta.2

License

MIT

Unpacked Size

128 kB

Total Files

30

Last publish

Collaborators

  • lewie9021