Skip to content

A mobile automation framework using Appium, TestNG, and Java to test mobile app functionality. Features login tests, Appium server management, and robust device handling.

License

Notifications You must be signed in to change notification settings

cihat-kose/appium-mobile-automation-framework

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

25 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Appium Mobile Automation Framework

Appium Java TestNG Node.js Maven

πŸš€ Overview

This project automates mobile application testing for both Android and iOS platforms using Appium, TestNG, and Java. The framework is designed to handle multiple platforms by switching desired capabilities and driver configurations dynamically. By modifying the driver setup in the DriverManager class, tests can be executed on Android devices using UiAutomator2 or on iOS devices using XCUITest.

πŸ“‹ Table of Contents

πŸ”§ Prerequisites

  • Java Development Kit (JDK) 11 or higher
  • Apache Maven
  • Node.js and npm
  • Appium Server
  • Appium Inspector
  • Appium Doctor
  • Android SDK
  • Android Emulator or a Physical Android Device

βš™οΈ Setup

1. Install JDK

  • Download and install JDK from Oracle.
  • Set JAVA_HOME environment variable.
  • Environment Variable Setup:
    1. Open the command prompt and run where java to find the Java installation path.
    2. Add the Java installation path to the environment variables:
      • Path: C:\Program Files\Java\jdk-11\bin
      • JAVA_HOME: C:\Program Files\Java\jdk-11
      • Add %JAVA_HOME%\bin to the system Path.

2. Install Maven

  • Download and install Maven from Maven.
  • Set MAVEN_HOME environment variable.

3. Install and Upgrade Node.js and Appium

  • Install Node.js from Node.js.
  • Run the following commands in the command prompt:
    npm install -g appium
    npm install -g appium@next
    appium -v

4. Install Appium Doctor

  • Run the following commands in the command prompt:
    npm install @appium/doctor --location=global
    appium-doctor --android

5. Install Appium Server

  • Download the Appium Desktop application from Appium and install it.
  • Alternatively, you can start the Appium server from the command line:
    appium

6. Install UiAutomator2 (for Android)

  • Run the following commands in the command prompt:
    appium driver install uiautomator2
    appium driver list

7. Install XCUITest (for iOS on MacOS)

If you are using MacOS and need to test iOS devices, you should install the XCUITest driver:

appium driver install xcuitest

8. Install Android SDK

  • Download and install the Android SDK from Android Studio.

  • Environment Variable Setup:

    • Add the following to the system environment variables:
      • ANDROID_HOME: C:\Users\YourUsername\AppData\Local\Android\Sdk
      • Path:
        • %ANDROID_HOME%\platform-tools
        • %ANDROID_HOME%\cmdline-tools
  • SDK Setup in Android Studio:

    1. Open Android Studio and go to More actions > SDK Manager.
    2. Under SDK Platforms, ensure Android API 34 is selected.
    3. Under SDK Tools, ensure the following are installed:
      • Android SDK Build-Tools 34
      • Android SDK Command Line Tools
      • Android SDK Tools (Obsolete) (Uncheck "Hide Obsolete Packages" to see this)
      • Android Emulator
      • Android Emulator hypervisor driver (for AMD processors)
      • Android SDK Platform-Tools
      • Intel x86 Emulator Accelerator (HAXM installer) (Ensure virtualization is enabled in BIOS)

9. Emulator Setup

  • For AMD processors, ensure Android Emulator Hypervisor Driver for AMD Processors (installer) is selected and applied.

10. Windows Features

  • Open Windows Features and ensure the following are NOT selected:
    • Hyper-V
    • Virtual Machine Platform
    • Windows Hypervisor Platform

11. Install Appium Inspector

Appium Inspector is a tool for inspecting mobile applications. To install it, download the latest version from the Appium Inspector releases page and follow the installation instructions for your operating system.

πŸ“ Project Structure

appium-mobile-automation-framework
β”œβ”€β”€ .idea
β”œβ”€β”€ src
β”‚   β”œβ”€β”€ apk
β”‚   β”œβ”€β”€ main
β”‚   └── test
β”‚       └── java
β”‚           └── com
β”‚               └── webdriverio
β”‚                   β”œβ”€β”€ base
β”‚                   β”œβ”€β”€ pages
β”‚                   β”œβ”€β”€ tests
β”‚                   └── utils
β”‚       └── resources
β”‚           └── logs
β”‚               └── log4j2.xml
β”œβ”€β”€ target
β”œβ”€β”€ .gitignore
β”œβ”€β”€ appium-mobile-automation-framework.iml
β”œβ”€β”€ LICENSE
β”œβ”€β”€ pom.xml
β”œβ”€β”€ README.md
└── testng.xml
  • com.webdriverio.base: Contains base classes for the project.
  • com.webdriverio.pages: Contains page object classes for the mobile application.
  • com.webdriverio.tests: Contains TestNG test classes.
  • com.webdriverio.utils: Contains utility classes for the project.
  • resources.logs: Contains log configuration files.

▢️ Running the Tests

Important: Ensure that your Android device or emulator is running and properly configured before executing the tests.

Using Maven

  1. Clone the Repository:

    git clone https://github.com/cihat-kose/appium-mobile-automation-framework.git
    cd appium-mobile-automation-framework
  2. Start Android Emulator or Connect a Physical Device:

    • Start your Android emulator from Android Studio or connect a physical device via USB and ensure it is in developer mode.
  3. Run the Tests:

    • Use Maven to run the tests:
      mvn clean test

Using TestNG in IDE

  1. Start Android Emulator or Connect a Physical Device:

    • Start your Android emulator from Android Studio or connect a physical device via USB and ensure it is in developer mode.
  2. Run the Tests from LoginTest Class:

    • Open the LoginTest class in your IDE.
    • Right-click on the class or the test method and select Run 'LoginTest' or Run 'testLogin'.

πŸ“Œ Project Details

  • AppiumServer Class: Manages the Appium server lifecycle.
  • DriverManager Class: Handles the initialization of the Android driver.
  • LoginPage Class: Contains methods to interact with the login page.
  • LoginTest Class: Contains TestNG test cases for verifying the login functionality.

πŸ“ Logging

The project uses Log4j2 for logging. Configuration is set in the log4j2.xml file located in the src/test/resources/logs directory. Logs provide detailed information about the test execution and any issues encountered.

πŸ‘₯ Contributors

🀝 Contributing

Contributions are welcome! Please fork the repository and create a pull request.

πŸ“œ License

This project is licensed under the MIT License - see the LICENSE file for details.

πŸ“ž Contact

For any questions or suggestions, please open an issue or contact the repository owner.

About

A mobile automation framework using Appium, TestNG, and Java to test mobile app functionality. Features login tests, Appium server management, and robust device handling.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages