Skip to content

pamepros/appium

 
 

Repository files navigation

Appium

Build Status

Appium is an open source, cross-platform test automation tool for native and hybrid mobile apps. It supports both iOS and Android. Appium drives Apple's UIAutomation library and Android's UiAutomator framework (for newer platforms) using Selenium's WebDriver JSON wire protocol. Appium is based on Dan Cuellar's work on iOS Auto. Appium also comes bundled with Selendroid for testing older Android platforms.

Testing with Appium has two big benefits:

  1. You don't have to recompile your app or modify it in any way, due to use of standard automation APIs on all platforms.

  2. You can write tests with your favorite dev tools using Java, Objective-C, JavaScript, PHP, Python, Ruby, C#, Clojure, or Perl with the Selenium WebDriver API and language-specific client libraries. You can use any testing framework. If you use Apple's UIAutomation library without Appium you can only write tests using JavaScript and you can only run tests through the Instruments application. Similarly, with Google's UiAutomator you can only write tests in Java. Appium opens up the possibility of true cross-platform native mobile automation. Finally!

Requirements

General:

  • Mac OS X 10.6 or higher (Linux OK for Android-only)
  • Node and npm (brew install node) (Node must be >= v0.8)

For iOS automation:

  • XCode
  • Apple Developer Tools (iPhone simulator SDK, command line tools)

For Android automation:

  • Android SDK API >= 17

User Quick Start

Option 1: Use Appium.app:

  • Download the Appium.app dmg
  • Run Appium.app then run a test using your favorite language / framework

Option 2: Run Appium from the command line using Node:

mkdir appium-test && cd appium-test
npm install appium -g  # might have to do this with sudo
npm install wd
curl -O https://raw.github.com/appium/appium/master/sample-code/examples/node/simplest.js
appium &
node simplest.js

Example Tests: Node.js | Python | PHP | Ruby | Java

Write Tests for Appium

We support a sub-set of the Selenium WebDriver JSON Wire Protocol.

We also have several extensions to the JSON Wire Protocol for automating mobile gestures like tap, flick, and swipe.

You can also automate web views in hybrid apps! See the hybrid app guide

We support Android and iOS platforms side-by-side:


Hacking with Appium

Install node.js (includes npm, the node.js package manager). The recommended way to install node is brew install node. Node installed by brew will not require sudo for npm commands.

Fork the Appium repo ( https://github.com/appium/appium ), then clone your fork.

From your local repo's command prompt, install these packages using the following commands (if you didn't install node using homebrew, you might have to run npm with sudo privileges):

npm install -g mocha
npm install -g grunt-cli
./reset.sh

The first two commands install test and build tools (sudo may not be necessary if you installed node.js via Homebrew). The third command installs all app dependencies, builds supporting binaries and test apps. reset.sh is also the recommended command to run after pulling changes from master.

Hacking with Appium (iOS)

(First, have a look at setting up your system for Appium iOS support.)

To avoid a security dialog that may appear when launching your iOS apps you'll have to modify your /etc/authorization file in one of two ways:

  1. Manually modify the element following <allow-root> under <key>system.privilege.taskport</key> in your /etc/authorization file to <true/>.

  2. Run the following grunt command which automatically modifies your /etc/authorization file for you:

    sudo grunt authorize
    

At this point, you can simply run:

./reset.sh --ios

Hacking with Appium (Android)

(First, have a look at setting up your system for Appium Android support.)

Now, you can simply run:

./reset.sh --android

If you want to use Selendroid for older apps:

./reset.sh --selendroid

Make sure you have one and only one Android emulator or device running, e.g. by running this command in another process (assuming the emulator command is on your path):

emulator -avd <MyAvdName>

Making sure you're up to date

Since we use dev versions of some packages, it often becomes necessary to install new NPM packages or update various things. There's a handy shell script to do all this for all platforms:

./reset.sh

Or you can run reset for individual platforms only:

./reset.sh --ios
./reset.sh --android
./reset.sh --selendroid

Running Tests

Once, your system is set up and your code is up to date, you can run various kinds of tests:

grunt functional
grunt android
grunt ios
grunt unit

Or you can run all tests:

grunt test

Before committing code, please run grunt to execute some basic tests and check your changes against code quality standards:

grunt
> Running "lint:all" (lint) task
> Lint free.
> Done, without errors.

Dig in deeper to Appium dev

Advanced grunt

If you want to run the Appium server and have it listen indefinitely, you can execute one of the following commands to start an Appium server with or without a specified app:

grunt appium           // launch Appium server without app
grunt appium:TestApp   // launch Appium server with the TestApp
grunt appium:UICatalog // launch Appium server with the UICatalog app

Like the power of automating dev tasks? Check out the Appium grunt tasks available to help with building apps, installing apps, generating docs, etc...

Running individual tests

If you have an Appium server listening, you can run individual test files using Mocha, for example:

mocha -t 60000 -R spec test/functional/testapp/simple.js

Advanced Appium server flags

Do you like getting close to the metal? Or are you trying to launch an Appium server from a script with a custom app? If so you can start Appium without grunt from the command line with an app or without an app, among other things:

node server.js -V  // launch Appium server without app
node server.js --app /absolute/path/to/app -V  // launch Appium server with app
node server.js --launch // pre-launch the app when appium loads
node server.js --log /my/appium.log // log to file instead of stdout
node server.js --without-delay // (iOS) use faster instruments-without-delay
node server.js --fast-reset // (Android) faster resetting between tests

(See the server documentation for all CLI arguments.)

Using with a Bitbeambot

AWAITING THE FUTURE

Contributing

Fork the project, make a change, and send a pull request!

Oh and please have a look at our Style Guide before getting to work.

Project Credits & Inspiration

The open source community has made this project possible, please add missing projects to the list.

All the OSS code contributing to Appium

Mailing List

Announcements and debates often take place on the Discussion Group, be sure to sign up!

About

Automation for Apps.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published