Skip to content

Mobile Test framework using WebdriverIO and Appium with mocha framework

Notifications You must be signed in to change notification settings

sadabnepal/WebdriverIOAppiumMochaJS

Repository files navigation

Mobile Test Automation Framework | WebdriverIO | Appium

Requirements:

NodeJs Appium-Inspector AppiumDriver AndroidStudio Java VSCode

Getting Started:

Installing Appium on a local machine

There are several documents and instructions on the internet to install Appium on your local machine. This is just one of the many ;-)

To setup the local test environment the following needs to be installed:

Setup Android SDK path environment variable

- ANDROID_HOME = <path to Sdk folder>
- %ANDROID_HOME%\tools [path variable]
- %ANDROID_HOME%\tools\bin  [path variable]
- %ANDROID_HOME%\platform-tools  [path variable]

Setup/Create virtual device on Android studio:

1] Open Android Studio
2] Click on More Actions 
   --> AVD Manager 
   --> Create Virtual Device 
   --> Select the device and OS version (from below device details) 
   --> Finish
3] Once Virtual device is created, click on Launch this AVD in the emulator.
4] Command to view the list of devices attached `adb devices`
Device 1: Pixel 3 - version 11
Device 2: Nexus 6 - version 10 [ if you want to run tests in parallel ] 

Clone repository:

git clone https://github.com/sadabnepal/WebdriverIOAppiumMochaJS.git
Navigate to `WebdriverIOAppiumMochaJS`

Note: all npm command should be executed from root project folder.

Install dependencies:

npm install

Verify appium drivers:

appium driver list

Sample output log of driver
-----------------------------
✔ Listing available drivers
- [email protected] [installed (NPM)]
- xcuitest [not installed]

If drivers are not installed then run below commnad as required:

appium driver install uiautomator2  [ android driver ]
appium driver install xcuitest      [ ios driver ]

Verify all pre-requisite for android:

appium-doctor is used to diagnose and fix common Node, iOS and Android configuration issues before starting Appium. You only run it once to check your local machine. See an example output below.

appium-doctor

Sample output log of configuration [ all option should be green checked]
-----------------------------
info AppiumDoctor Appium Doctor v.1.16.0
info AppiumDoctor ### Diagnostic for necessary dependencies starting ###
info AppiumDoctor  ✔ The Node.js binary was found at: C:\Program Files\nodejs\node.EXE
info AppiumDoctor  ✔ Node version is 14.17.3
info AppiumDoctor  ✔ ANDROID_HOME is set to:<APP_DATA_LOCAL_PATH>\Android\Sdk
info AppiumDoctor  ✔ JAVA_HOME is set to: <JDK_PATH>
info AppiumDoctor    Checking adb, android, emulator
info AppiumDoctor      'adb' is in <APP_DATA_LOCAL_PATH>\Android\Sdk\platform-tools\adb.exe
info AppiumDoctor      'android' is in <APP_DATA_LOCAL_PATH>\Android\Sdk\tools\android.bat
info AppiumDoctor      'emulator' is in <APP_DATA_LOCAL_PATH>\Android\Sdk\emulator\emulator.exe      
info AppiumDoctor  ✔ adb, android, emulator exist: <APP_DATA_LOCAL_PATH>\Android\Sdk
info AppiumDoctor  ✔ 'bin' subfolder exists under '<JDK_PATH>\jdk-11.0.12.7-hotspot'

.env file data update

Note: create .env file in root project folder, update required details

RUN_MODE=parallel  # Add this only when you want to run test in both devices

EMULATOR_DEVICE1_ID=Pixel_3
EMULATOR_DEVICE1_NAME=Pixel 3
EMULATOR_DEVICE1_VERSION=11

EMULATOR_DEVICE2_ID=Nexus 6
EMULATOR_DEVICE2_NAME=Nexus_6
EMULATOR_DEVICE2_VERSION=10

BROWSERSTACK_USERNAME=
BROWSERSTACK_ACCESS_KEY=

BROWSERSTACK_ANDROID_APP_ID=
BROWSERSTACK_ANDROID_DEVICE=
BROWSERSTACK_ANDROID_VERSION=

BROWSERSTACK_IOS_APP_ID=
BROWSERSTACK_IOS_DEVICE=
BROWSERSTACK_IOS_VERSION=

SetUp BrowserStack

- Create account
- Find username, access key
- Upload Android (.apk) and IOS (.ipa) files used in project
- Note down app id for both
- Select device for both android and ios
- Update all details in .env file

Run Test:

npm test

Generate Report:

npm run report

Sample Report

report

About

Mobile Test framework using WebdriverIO and Appium with mocha framework

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published