Skip to content

ingenerator/chrome-mink-driver

Repository files navigation

FORKED PROJECT: VERSIONING STRATEGY

This is a (possibly temporary) fork of the original dmore/chrome-mink-driver package with some custom additions. To avoid complicating version constraints, our releases will track upstream versions, using point releases to mark our additions. Therefore we do not follow semantic versioning. A version 2.7.0.2 means it's our second modification to the upstream 2.7.0. It may well include breaking changes from both 2.7.0 and 2.7.0.1. We consider this acceptable because this is test code - by definition any problems it causes are guaranteed to show up during testing before you merge the new version to your project.

Chrome Mink Driver

Mink driver for controlling Chrome without the overhead of Selenium.

It communicates directly with Google Chrome over HTTP and WebSockets, which allows it to work at least twice as fast as Chrome with Selenium. For Chrome 59+ it supports headless mode, eliminating the need to install a display server, and the overhead that comes with it. This driver is tested and benchmarked against a behat suite of 1800 scenarios and 19000 steps. It can successfully run it in less than 18 minutes with Chrome 60 headless. The same suite running against Chrome 58 with xvfb and Selenium takes ~60 minutes.

Gitlab CI pipeline OpenSSF Best Practices

Installation:

composer require ingenerator/chrome-mink-driver

Requirements:

  • Google Chrome or Chromium running with remote debugging.

Example:

google-chrome-stable --remote-debugging-address=0.0.0.0 --remote-debugging-port=9222

or headless (v59+):

google-chrome-unstable --disable-gpu --headless --remote-debugging-address=0.0.0.0 --remote-debugging-port=9222

It is recommended to start Chrome with the --disable-extensions flag.

See https://gitlab.com/DMore/behat-chrome-skeleton for a fully working example.

Contributing

Contributions are welcome! Use the issue queue and merge requests to propose changes. Please refer to Gitlab documentation for how to use the Gitlab interface.

  • To report an issue (bug, feature request etc) use the issue queue.
  • If you are reporting a potential security issue, please check "This issue is confidential" when reporting the issue to the project.
  • To propose code changes or a solution for an issue, use merge requests.
  • Test coverage is executed on merge requests. Contributions should extend test coverage where possible and ensure all tests pass.
  • Coding standards checks are executed on merge requests. Contributions should maintain coding standards.

Tests

The project has test coverage, which you can execute using the commands below.

Test execution requires a webserver configured to serve fixtures from minkphp/driver-testsuite, which is provided by a docker image from the related behat-chrome/docker-chrome-headless project. Tests executed are both tests specific to this driver and the more comprehensive test suite from mink/driver-testsuite, which is the common testsuite to ensure consistency across Mink driver implementations.

Using make

command purpose
make install Install dependencies with composer
make test Run tests with phpunit
make phpcbf Tidy code using phpcbf
make phpcs Check coding standards with phpcs

Without make

To perform these tasks without make, you can execute the same commands as above in a container. To run the tests using phpunit:

docker run --rm -it -v .:/code -e DOCROOT=/code/vendor/mink/driver-testsuite/web-fixtures registry.gitlab.com/behat-chrome/docker-chrome-headless bash

then, in the container shell:

composer install
vendor/bin/phpunit

Versioning & releases

Usage

use Behat\Mink\Mink;
use Behat\Mink\Session;
use DMore\ChromeDriver\ChromeDriver;

$mink = new Mink([
  'browser' => new Session(new ChromeDriver('http://localhost:9222', null, 'http://www.google.com'))
]);

Configuration

Option Value Description
socketTimeout int, default: 10 Connection timeout (seconds)
domWaitTimeout int, default: 3000 DOM ready waiting timeout (milliseconds)
downloadBehavior allow, default, deny Chrome switch to permit downloads. (v62+)
downloadPath e.g. /tmp/ (the default) Where to download files to, if permitted.

Pass configuration values as the third parameter to new ChromeDriver().

Rendering PDF and Screenshots

Despite the Mink functionality the driver supports printing PDF pages or capturing a screenshot.

use Behat\Mink\Mink;
use Behat\Mink\Session;
use DMore\ChromeDriver\ChromeDriver;
$mink = new Mink(array(
    'browser' => new Session(new ChromeDriver('http://localhost:9222', null, 'http://www.google.com'))
));
$mink->setDefaultSessionName('browser');
$mink->getSession()->visit('https://gitlab.com/behat-chrome/chrome-mink-driver/blob/master/README.md');
$driver = $mink->getSession()->getDriver();
$driver->printToPdf('/tmp/readme.pdf');

The available options are documented here: https://chromedevtools.github.io/devtools-protocol/tot/Page/#method-printToPDF

Screenshots are supported using the Mink driver interface method getScreenshot().

Related projects

Behat extension

To use this driver with Behat, try the dmore/behat-chrome-extension Behat extension.

Docker image

A Docker image is used to execute tests against the targeted browser(s), and includes recent Chrome Stable, Chrome Beta and Chromium.