skip to navigation
skip to content

Not Logged In

pyfrank 0.2.1

python binding for iOS automation using frank.

Latest Version: 0.2.8

pyfrank - python binding for iOS automation using frank.

pyfrank is an API to interact with frank, the iOS automation framework.

Installation

Option 1:

  1. Clone this repo or download the sources
  2. cd pyfrank
  3. python setup.py build
  4. sudo python setup.py install

Option 2:

sudo pip install pyfrank

It's that simple

from pyfrank import *

# We are running a simulator with frank locally on port 32765
device = Device(host='127.0.0.1', port=32765)

# Get the view representing a tab-bar button with the label "Mail"
view = device.getView(UiQuery("tabBarButton", {'marked': "Mail" }))

# Touch the button
response = view.touch()

if isinstance(response, Success):
    logging.info("Test mail button succeeded!");
elif isinstance(response, Failure):
    logging.error("Test mail button failed: %s", response)

The object model

Device

The first entry point for interacting with frank. It's constructor receives the host and the port of the frank enabled device.

Example:

from pyfrank import *

device = Device("127.0.0.1", 32765)

# Type text into the keyboard
device.typeIntoKeyboard("abc")

# Execute an application on the device
device.appExec("appName", "arg1", "arg2", ...)

# Get the accesibility state
accessibilityEnabled = device.accessibilityCheck()

# Get the device orientation
orientation = device.getOrientation()
if orientation == Orientation.PORTRAIT:
    print "Portrait"
elif orientation == Orientation.LANDSCAPE:
    print "Landscape"

# Get the application layout graph
dump = device.dump()

UiQuery

In frank views can be found using a special query specification called "UiQuery".

Example:

from pyfrank import *

UiQuery("view:'UIImageView' marked:'ProfilePicture'")

View

View allows to perform operations on the view(s) that match a UiQuery.

#Get the profile picture view
view = device.getView(UiQuery({'view': 'UIImageView'}, {'marked': 'ProfilePicture'}))

#Flash the profile picture
r = view.flash()

#Test for success
if isinstance(r, Success):
    print "Flashed the profile picture!"
else:
    print "Failed flashing profile picture"

#Touch the profile picture
r = view.touch()


#Get the title text input view
input = device.getView(UiQuery({'view', 'UITextField'}, {'marked': 'Title'}))

r = input.setText("New title text")

if isinstance(r, Success):
    print "Title input was changed successfully."
else:
    print "Failed changing title input"

#More information on frank

http://testingwithfrank.com/

 
File Type Py Version Uploaded on Size
pyfrank-0.2.1.tar.gz (md5) Source 2012-10-04 7KB
  • Downloads (All Versions):
  • 8 downloads in the last day
  • 89 downloads in the last week
  • 554 downloads in the last month