Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@bam.tech/appium-helper

Package Overview
Dependencies
Maintainers
0
Versions
23
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@bam.tech/appium-helper

  • 0.5.5
  • latest
  • npm
  • Socket score

Version published
Weekly downloads
42
decreased by-33.33%
Maintainers
0
Weekly downloads
 
Created
Source

Appium Helper

Appium is a blackbox e2e testing framework, which means you can run it on any app (even production ones) with no setup required.

However, since it supports many languages and platforms, the docs can be difficult to navigate and find the precise way to do things. This package wraps a webdriverio client to expose most common e2e testing capabilities you would want to use.

  • Usage

Usage

Getting started

  1. Install the helper yarn add @bam.tech/appium-helper

  2. Write your test script

// appium.test.ts
import { AppiumDriver } from "@bam.tech/appium-helper";

test("e2e", async () => {
  const driver = await AppiumDriver.create({
    // `npx @perf-profiler/profiler getCurrentApp` will display info for the current app
    appPackage: "com.example",
    appActivity: "com.example.MainActivity",
  });

  driver.startApp();
  await driver.findElementByText("Welcome");
});
  1. Run the appium server npx appium in a terminal. If you just installed Appium, you may need to install a driver, e.g., by running npx appium driver install uiautomator2.
  2. Run your test file in a separate terminal yarn jest appium.test.ts

API

Wait for element

You can find an element by text or testID. The helper will wait for the element to exist and return it:

await driver.findElementByText("Welcome");
await driver.findElementById("welcome_text");
Click element

You can click an element by text or testID. The helper will wait for the element to exist and click it:

await driver.clickElementByText("Welcome");
await driver.clickElementById("welcome_text");
Scrolling
await driver.scrollDown();
await driver.scrollToEnd();
Start/Stop app
driver.startApp();
// You should probably add a finder to wait for the app to start
// for instance driver.findElementByText("Welcome");

driver.stopApp();
Waiting

You can also wait for a certain amount of time:

await driver.wait(<delay in ms>);
// e.g.
await driver.wait(5000);
Inputs

First find the element by its placeholder, value or test id, then use addValue:

const input = await driver.findElementByText("Email input Placeholder");
await input.addValue("My username");
Run any other webdriverio commands

AppiumDriver just wraps a webdriverio client. You can still run any webdriverio commands using:

const client = driver.client;
// run any commands
await client.$("...");

FAQs

Package last updated on 30 Sep 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc