Skip to content

Kml55/marionette_client

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 

Repository files navigation

Marionette Client

Marionette is a Mozilla project to enable remote automation in Gecko-based projects, including desktop Firefox, mobile Firefox, and Boot-to-Gecko.

It utilizes the remote-debugger inside Gecko for the transport layer of the Marionette server. The commands the Marionette server will eventually implement are based on Selenium's JSON Wire Protocol, although not all commands are presently implemented, and additional commands will likely be added.

Package Files

  • client.py: This is the Marionette socket client; it speaks the same socket protocol as the Gecko remote debugger.
  • marionette.py: The Marionette client. This uses client.py to communicate with a server that speaks the Gecko remote debugger protocol.
  • selenium_proxy.py: Acts as a remote driver for Selenium test runners. This code translates the Selenium JSON Wire Protocol to the Marionette JSON Protocol. This allows Selenium tests to utilize Marionette.
  • testserver.py: A socket server which mimics the remote debugger in Gecko, and can be used to test pieces of the Marionette client.
  • test_protocol.py: Tests the Marionette JSON Protocol by using testserver.py.
  • test_selenium.py: Tests the Selenium proxy by using testserver.py.

Installation

You'll need the ManifestDestiny and MozHttpd packages from Mozbase:

git clone git://github.com/mozilla/mozbase.git
cd mozbase
python setup_development.py

Other than that, there are no special requirements, unless you're using the Selenium proxy, in which case you'll need to install the Selenium Python bindings using:

pip install selenium

Writing Tests Using the Marionette Client

Tests can be written using the Marionette client directly, or by writing Selenium tests and using the Selenium proxy. See test_protocol.py for an example of the former and test_selenium.py for an example of the latter.

Although test_selenium.py uses the Python binding for Selenium, any of the Selenium webdriver clients should be usable with Marionette.

About

Python client for Marionette

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published