geckodriver/README.md

478 строки
14 KiB
Markdown
Исходник Обычный вид История

2016-05-04 19:54:04 +03:00
# geckodriver [![Build Status](https://travis-ci.org/mozilla/geckodriver.svg?branch=master)](https://travis-ci.org/mozilla/geckodriver)
2016-05-04 19:54:04 +03:00
Proxy for using W3C WebDriver-compatible clients
to interact with Gecko-based browsers.
2015-08-12 06:36:50 +03:00
2016-05-04 19:54:04 +03:00
This program provides the HTTP API described by
the [WebDriver protocol](http://w3c.github.io/webdriver/webdriver-spec.html#protocol)
to communicate with Gecko browsers, such as Firefox.
It translates calls into
the [Marionette automation protocol](https://developer.mozilla.org/en-US/docs/Mozilla/QA/Marionette)
2016-05-04 19:54:04 +03:00
by acting as a proxy between the local- and remote ends.
2015-08-12 06:36:50 +03:00
You can consult the [change log](https://github.com/mozilla/geckodriver/blob/master/CHANGES.md)
for a record of all notable changes to the program.
[Releases](https://github.com/mozilla/geckodriver/releases)
are made available on GitHub
on [supported platforms](#supported-firefoxen).
## Supported clients
[Selenium](http://docs.seleniumhq.org/) users
must update to [version 3.3.1](https://github.com/SeleniumHQ/selenium/releases/tag/selenium-3.3.1)
or later to use geckodriver.
Other clients that follow the [W3C WebDriver specification](https://w3c.github.io/webdriver/webdriver-spec.html) are also supported.
2017-03-09 17:22:44 +03:00
## Supported Firefoxen
Marionette and geckodriver are not yet feature complete.
2016-12-13 19:24:52 +03:00
This means that they do not yet offer full conformance
with the [WebDriver standard](https://w3c.github.io/webdriver/webdriver-spec.html)
or complete compatibility with [Selenium](http://www.seleniumhq.org/).
You can track the [implementation status](https://developer.mozilla.org/en-US/docs/Mozilla/QA/Marionette/WebDriver/status)
of the latest [Firefox Nightly](http://whattrainisitnow.com/) on
[MDN](https://developer.mozilla.org/).
2016-08-02 19:23:55 +03:00
We also keep track of known
[Marionette](https://github.com/mozilla/geckodriver/issues?q=is%3Aissue+is%3Aopen+label%3Amarionette),
[Selenium](https://github.com/mozilla/geckodriver/issues?q=is%3Aissue+is%3Aopen+label%3Aselenium),
and [specification](https://github.com/mozilla/geckodriver/issues?q=is%3Aissue+is%3Aopen+label%3Aspec)
problems in our
[issue tracker](https://github.com/mozilla/geckodriver/issues).
Support is best in Firefox 52.0.3 and onwards,
although generally the more recent the Firefox version,
the better the experience as they have more bug fixes and features.
Some features will only be available in the most recent Firefox versions,
and we strongly advise using the [latest Firefox Nightly](https://nightly.mozilla.org/) with geckodriver.
Since Windows XP support in Firefox will be dropped with Firefox 53,
we do not support this platform.
## WebDriver capabilities
geckodriver supports a number of
[WebDriver capabilities](https://w3c.github.io/webdriver/webdriver-spec.html#capabilities):
<table>
<thead>
<tr>
<th>Name
<th>Type
<th>Description
</tr>
</thead>
<tr>
<td><code>proxy</code>
<td><a href=#proxy-object><code>proxy</code></a> object
<td>Sets browser proxy settings.
</tr>
<tr>
<td><code>acceptInsecureCerts</code>
<td>boolean
<td>Boolean initially set to false,
indicating the session will not implicitly trust untrusted
or self-signed TLS certificates on navigation.
</tr>
</table>
### `proxy` object
<table>
<thead>
<tr>
<th>Name
<th>Type
<th>Description
</tr>
</thead>
<tr>
<td><code>proxyType</code>
<td>string
<td>Indicates the type of proxy configuration.
This value must be one of
<code>pac</code>,
<code>noproxy</code>,
<code>autodetect</code>,
<code>system</code>,
or <code>manual</code>.
</tr>
<tr>
<td><code>proxyAutoconfigUrl</code>
<td>string
<td>Defines the URL for a proxy auto-config file.
This property should only be set
when <code>proxyType</code> is <code>pac</code>.
</tr>
<tr>
<td><code>ftpProxy</code>
<td>string
<td>Defines the proxy hostname for FTP traffic.
Should only be set then the <code>proxyType</code>
is set to <code>manual</code>.
</tr>
<tr>
<td><code>ftpProxyPort</code>
<td>number
<td>Defines the proxy port for FTP traffic.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>httpProxy</code>
<td>string
<td>Defines the hostname for HTTP traffic.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>httpProxyPort</code>
<td>number
<td>Defines the proxy port for HTTP traffic.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>sslProxy</code>
<td>string
<td>Defines the proxy hostname
for encrypted TLS traffic.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>sslProxyPort</code>
<td>number
<td>Defines the proxy port for SSL traffic.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>socksProxy</code>
<td>string
<td>Defines the proxy hostname for a SOCKS proxy.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>socksProxyPort</code>
<td>number
<td>Defines the proxy port for a SOCKS proxy.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>socksVersion</code>
<td>number
<td>Defines the SOCKS proxy version.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>socksUsername</code>
<td>string
<td>Defines the username used
when authenticating with a SOCKS proxy.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
<tr>
<td><code>socksPassword</code>
<td>string
<td>Defines the password used
when authenticating with a SOCKS proxy.
This property should only be set
when <code>proxyType</code> is <code>manual</code>.
</tr>
</table>
## Firefox capabilities
2016-12-08 06:03:36 +03:00
geckodriver also supports a capability named `moz:firefoxOptions`
which takes Firefox-specific options.
This must be a dictionary
and may contain any of the following fields:
<table>
<thead>
<tr>
<th>Name
<th>Type
<th>Description
</tr>
</thead>
<tr>
<td><code>binary</code>
<td>string
<td>Absolute path of the Firefox binary,
e.g. <code>/usr/bin/firefox</code>
or <code>/Applications/Firefox.app/Contents/MacOS/firefox</code>,
to select which custom browser binary to use.
If left undefined geckodriver will attempt
to deduce the default location of Firefox
on the current system.
</tr>
<tr>
<td><code>args</code>
2016-10-05 19:07:01 +03:00
<td>array&nbsp;of&nbsp;strings
<td>Command line arguments to pass to the Firefox binary.
These must include the leading <code>--</code> where required
e.g. <code>["--devtools"]</code>.
</tr>
<tr>
<td><code>profile</code>
<td>string
<td>Base64-encoded zip of a profile directory
to use as the profile for the Firefox instance.
This may be used to e.g. install extensions
or custom certificates.
</tr>
<tr>
<td><code>log</code>
2016-10-05 19:05:40 +03:00
<td><a href=#log-object><code>log</code></a>&nbsp;object
<td>Logging options for Gecko.
</tr>
<tr>
<td><code>prefs</code>
2016-10-05 19:05:40 +03:00
<td><a href=#prefs-object><code>prefs</code></a>&nbsp;object
<td>Map of preference name to preference value, which can be a
string, a boolean or an integer.
</tr>
</table>
### `log` object
<table>
<thead>
<tr>
<th>Name
<th>Type
<th>Description
</tr>
</thead>
<tr>
<td><code>level</code>
<td>string
<td>Set the level of verbosity in Gecko.
Available levels are <code>trace</code>,
<code>debug</code>, <code>config</code>,
<code>info</code>, <code>warn</code>,
<code>error</code>, and <code>fatal</code>.
If left undefined the default is <code>info</code>.
</tr>
</table>
### `prefs` object
<table>
<thead>
<tr>
<th>Name
<th>Type
<th>Description
</tr>
</thead>
<tr>
<td><var>preference name</var>
<td>string, number, boolean
<td>One entry per preference to override.
</tr>
</table>
2016-12-08 06:03:36 +03:00
## Capabilities examples
To select a specific Firefox binary
and run it with a specific command-line flag,
set a preference,
and enable verbose logging:
```js
{
"capabilities": {
"alwaysMatch": {
"moz:firefoxOptions": {
"binary": "/usr/local/firefox/bin/firefox",
"args": ["--no-remote"],
"prefs": {
"dom.ipc.processCount": 8
},
"log": {
"level": "trace"
}
}
2016-12-08 06:03:36 +03:00
}
}
}
```
## Usage
Usage steps are [documented on MDN](https://developer.mozilla.org/en-US/docs/Mozilla/QA/Marionette/WebDriver),
but how you invoke geckodriver largely depends on your use case.
### Selenium
If you are using geckodriver through [Selenium](http://seleniumhq.org/),
you must ensure that you have version 3.3.1 or greater.
Because geckodriver implements the [W3C WebDriver standard](https://w3c.github.io/webdriver/webdriver-spec.html)
and not the same Selenium wire protocol older drivers are using,
you may experience incompatibilities and migration problems
when making the switch from FirefoxDriver to geckodriver.
Generally speaking, Selenium 3 enabled geckodriver
as the default WebDriver implementation for Firefox.
With the release of Firefox 47, FirefoxDriver had to be discontinued
for its lack of support for the [new multi-processing architecture in Gecko](https://developer.mozilla.org/en-US/Firefox/Multiprocess_Firefox).
Selenium client bindings will pick up the _geckodriver_ binary executable
from your [systems `PATH` environmental variable](https://en.wikipedia.org/wiki/PATH_(variable))
unless you override it by setting the `webdriver.gecko.driver`
[Java VM system property](http://docs.oracle.com/javase/tutorial/essential/environment/sysprop.html):
```java
System.setProperty("webdriver.gecko.driver", "/home/user/bin");
```
Or by passing it as a flag to the [java(1)](http://www.manpagez.com/man/1/java/) launcher:
% java -Dwebdriver.gecko.driver=/home/user/bin YourApplication
Your milage with this approach may vary
based on which programming language bindings you are using.
It is in any case generally the case that geckodriver will be picked up
if it is available on the system path.
In a bash compatible shell,
you can make other programs aware of its location
by exporting or setting the `PATH` variable:
% export PATH=$PATH:/home/user/bin
% whereis geckodriver
geckodriver: /home/user/bin/geckodriver
On Window systems you can change the system path
by right-clicking **My Computer** and choosing **Properties**.
In the dialogue that appears, navigate
**Advanced** → **Environmental Variables****Path**.
Or in the Windows console window:
$ set PATH=%PATH%;C:\bin\geckodriver
### Standalone
Since geckodriver is a separate HTTP server
that is a complete remote end implementation
of [WebDriver](https://w3c.github.io/webdriver/webdriver-spec.html),
it is possible to avoid using the Selenium remote server
if you have no requirements
to distribute processes across a matrix of systems.
Given a W3C WebDriver conforming client library (or _local end_)
you may interact with the geckodriver HTTP server
as if you were speaking to any Selenium server.
Using [curl(1)](http://www.manpagez.com/man/1/curl/):
% geckodriver &
[1] 16010
% 1491834109194 geckodriver INFO Listening on 127.0.0.1:4444
% curl -d '{"capabilities": {"alwaysMatch": {"acceptInsecureCerts": true}}}' http://localhost:4444/session
2017-04-10 18:33:57 +03:00
{"sessionId":"d4605710-5a4e-4d64-a52a-778bb0c31e00","value":{"XULappId":"{ec8030f7-c20a-464f-9b0e-13a3a9e97384}","acceptSslCerts":false,"appBuildId":"20160913030425","browserName":"firefox","browserVersion":"51.0a1","command_id":1,"platform":"LINUX","platformName":"linux","platformVersion":"4.9.0-1-amd64","processId":17474,"proxy":{},"raisesAccessibilityExceptions":false,"rotatable":false,"specificationLevel":0,"takesElementScreenshot":true,"takesScreenshot":true,"version":"51.0a1"}}
% curl -d '{"url": "https://mozilla.org"}' http://localhost:4444/session/d4605710-5a4e-4d64-a52a-778bb0c31e00/url
{}
% curl http://localhost:4444/session/d4605710-5a4e-4d64-a52a-778bb0c31e00/url
{"value":"https://www.mozilla.org/en-US/"
% curl -X DELETE http://localhost:4444/session/d4605710-5a4e-4d64-a52a-778bb0c31e00
{}
% fg
geckodriver
^C
%
Using the Python [wdclient](https://github.com/w3c/wpt-tools/tree/master/webdriver) library:
```py
import webdriver
with webdriver.Session("127.0.0.1", 4444) as session:
session.url = "https://mozilla.org"
print "The current URL is %s" % session.url
```
And to run:
% geckodriver &
[1] 16054
% python example.py
1491835308354 geckodriver INFO Listening on 127.0.0.1:4444
The current URL is https://www.mozilla.org/en-US/
% fg
geckodriver
^C
%
You may also see all flags and options
available in geckodriver by viewing the help message:
% geckodriver -h
WebDriver implementation for Firefox.
USAGE:
geckodriver [FLAGS] [OPTIONS]
FLAGS:
--connect-existing Connect to an existing Firefox instance
-h, --help Prints help information
-v Log level verbosity (-v for debug and -vv for
trace level)
-V, --version Prints version and copying information
OPTIONS:
-b, --binary <BINARY> Path to the Firefox binary
--log <LEVEL>
Set Gecko log level [values: fatal, error, warn, info, config,
debug, trace]
--marionette-port <PORT>
Port to use to connect to Gecko (default: random free port)
--host <HOST>
Host ip to use for WebDriver server (default: 127.0.0.1)
-p, --port <PORT>
Port to use for WebDriver server (default: 4444)
2016-05-04 19:54:04 +03:00
## Building
2015-08-12 06:36:50 +03:00
geckodriver is written in [Rust](https://www.rust-lang.org/),
a systems programming language from [Mozilla](https://www.mozilla.org/en-US/).
In order to build this program,
you will need the [Rust compiler toolchain](https://rustup.rs/).
2015-08-12 06:36:50 +03:00
To build the project for release,
ensure you compile with optimisations
to get the best performance:
2015-08-12 06:36:50 +03:00
% cargo build --release
Or if you want a non-optimised binary for debugging:
2016-05-04 19:54:04 +03:00
% cargo build