Book Image

Mobile Test Automation with Appium

By : Nishant Verma
Book Image

Mobile Test Automation with Appium

By: Nishant Verma

Overview of this book

Appium is an open source test automation framework for mobile applications. It allows you to test all three types of mobile applications: native, hybrid, and mobile web. It allows you to run the automated tests on actual devices, emulators, and simulators. Today, when every mobile app is made on at least two platforms, iOS and Android, you need a tool that allows you to test across platforms. Having two different frameworks for the same app increases the cost of the product and time to maintain it as well. Appium helps save this cost. With mobile app growth exploding, mobile app automation is mainstream now. In this book, author Nishant Verma provides you with a firm grounding in the concepts of Appium while diving into how to set up appium & Cucumber-jvm test automation framework, implement page object design pattern, automate gestures, test execution on emulators and physical devices, and implement continuous integration with Jenkins. The mobile app we have referenced in this book is Quikr because of its relatively lower learning curve to understand the application. It's a local classifieds shopping app.
Table of Contents (20 chapters)
Title Page
Credits
About the Author
About the Reviewers
www.PacktPub.com
Customer Feedback
Preface
5
Understanding Appium Inspector to Find Locators
7
How to Automate Gestures
9
How to Run Appium Test on Devices and Emulators

Server argument


Desired capabilities are sent by the client to the server via JSON objects by requesting the automation session we intend to have. Now, with the preceding code refactor, we can start the Appium server by calling the start() method. This method starts the Appium server assuming the node and appium.js files to be in certain locations and using port 4723. If you have tweaked node.js installation, your Appium install path is not the same, or if you want to start Appium server on different ports, we can use AppiumServiceBuilder to override these inputs:

appiumService = AppiumDriverLocalService.buildService(new AppiumServiceBuilder()
        .usingDriverExecutable(new File(("/path/to/node")))
        .withAppiumJS(new File(("/path/to/appium")))
        .withIPAddress("127.0.0.1")
        .usingPort(port)
        .withArgument(argument)
        .withLogFile(new File("path/to/log/file")));
appiumService.start();

AppiumServiceBuilder also gives you other options to override, which are...