This package will make Laravel Dusk browser tests run in Firefox. Instead of using Chromedriver, Laravel application tests are sent to Firefox's Geckodriver proxy server.
- Features
- Requirements
- Installation
- Updating Geckodriver
- Configuring Geckodriver
- Running both Firefox & Google Chrome
- Running with Laravel Sail
- Developing only with Laraval Sail
- Mixing other development environments with Laravel Sail
- Development
- FAQ
- Contributing
- Credits
- License
- Downloads the latest stable Geckodriver binary for your operating system.
- Handles automating startup and shutdown of the Geckodriver proxy server process.
- Captures Firefox browser screenshots when tests fail.
- Generates a debugging log file when JavaScript
console
errors occur.
- PHP 7.2+
- Laravel Framework 6.0+
- Laravel Dusk 6.0+
- Mozilla Firefox browser installed locally
First ensure Laravel Dusk command php artisan dusk:install
has been run. This will copy files into your application and generate required subdirectories.
composer require --dev derekmd/laravel-dusk-firefox
php artisan dusk:install-firefox
This will overwrite file tests/DuskTestCase.php
in your application to support running Firefox. Your browser test suite will now open in Firefox rather than Google Chrome:
php artisan dusk
To download the latest stable Geckodriver binary for your current operating system:
php artisan dusk:firefox-driver
Use the --all
option to install all three binaries for Linux, macOS, and Windows.
php artisan dusk:firefox-driver --all
If you wish to download older binaries, pass the GitHub release tag version as the first command line argument. Keep in mind Geckodriver's versioning schema does not relate to Firefox's release version.
php artisan dusk:firefox-driver v0.19.1
The command can also download the binaries through a local proxy server:
php artisan dusk:firefox-driver --proxy=tcp://127.0.0.1:9000 --ssl-no-verify
After tests/DuskTestCase.php
is copied into your application, you may update the class as you please.
namespace Tests;
use Facebook\WebDriver\Firefox\FirefoxDriver;
use Facebook\WebDriver\Remote\DesiredCapabilities;
use Facebook\WebDriver\Remote\RemoteWebDriver;
use Laravel\Dusk\TestCase as BaseTestCase;
abstract class DuskTestCase extends BaseTestCase
{
// ...
protected function driver()
{
$options = [
'args' => [
'--headless',
'--window-size=1920,1080',
],
];
$capabilities = DesiredCapabilities::firefox()
->setCapability('moz:firefoxOptions', $options);
$capabilities->getCapability(FirefoxDriver::PROFILE)
->setPreference('devtools.console.stdout.content', true);
return RemoteWebDriver::create('http://localhost:4444', $capabilities);
}
}
- Firefox profile boolean flag
devtools.console.stdout.content
must be turned on to generate logs for debugging JavaScript errors. --headless
runs tests without opening any windows which is useful for continuous integrations. Remove this option to see the browser viewport while the test runs.--window-size
controls the width and height of the browser viewport. If your UI assertions are failing from elements being off-screen, you may need to change this setting.
Read the Geckodriver usage documentation to see which options are available.
You may wish to run tests in both Google Chrome and Firefox to check for feature parity in your application. This package supports a --with-chrome
option to generate tests/DuskTestCase.php
so it may run in both browsers.
php artisan dusk:install-firefox --with-chrome
The Laravel Dusk command will default to running tests in Firefox:
php artisan dusk
A new command has been added to make tests run in Google Chrome:
php artisan dusk:chrome
You may also pass PHPUnit arguments to the command:
php artisan dusk:chrome tests/Browser/HomepageTest.php --filter testFooter
This command will append environment variable DUSK_CHROME=1
to your .env.dusk file and remove it after tests complete.
If Laravel Dusk crashes or you have cancelled the test suite process using CTRL+C, you may need to manually remove leftover line
DUSK_CHROME=1
from your .env.dusk file.
When running automated test flows through tools such as Chipper CI, CircleCI, Travis CI, or Github Actions, you can setup one job to run Google Chrome and a second job for Firefox. The custom Artisan commands can be skipped and you can instead just set the environment variable. The job configured with DUSK_CHROME=1
will run Google Chrome. The second job missing the environment variable defaults to Firefox.
Laravel Sail is a command-line interface for interacting with your Laravel application's Docker development environment. Laravel Dusk tests can run in Firefox once an additional Docker image is added to Sail's configuration file.
You must uncomment and edit the "selenium" service in the docker-compose.yml
file to install standalone Firefox for Selenium.
version: '3'
services:
laravel.test:
# ....
depends_on:
- mysql
- redis
- selenium
selenium:
image: 'selenium/standalone-firefox'
volumes:
- '/dev/shm:/dev/shm'
networks:
- sail
You may not require this package if you exclusively use Laravel Sail for development.
Over 90% of this package's solution is focused on managing a local Geckodriver process through PHPUnit's event hooks. Laravel Sail replaces Chromedriver/Geckodriver with a Selenium server so the only custom code you'll require in your application is a WebDriver configuration for Firefox. Copy this driver() method into your application's tests/DuskTestCase.php
file. Then use the above docker-compose.yml
instructions to install Docker image "selenium/standalone-firefox".
For projects that have a team of developers across many environments (local native development, Laravel Valet, Laravel Homestead, Laravel Sail) or use a Docker-less continuous integration, this package will allow Laravel Dusk to run Firefox in any of those environments.
Install the package using the sail
commands:
./vendor/bin/sail composer require --dev derekmd/laravel-dusk-firefox
./vendor/bin/sail artisan dusk:install-firefox
This will copy a tests/DuskTestCase.php
file into your application that is configured to recognize Laravel Sail's environment variables. When Sail isn't installed, Laravel Dusk will behave as normal.
Run Laravel Dusk tests in Firefox by executing the command:
./vendor/bin/sail dusk
Other developers not using Laravel Sail can execute the usual Dusk command:
php artisan dusk
This configuration only allows running Dusk test with Mozilla Firefox. To make the command
php artisan dusk:chrome
work with a "selenium/standalone-chrome" image, additional service andsail.sh
file changes are required that fall outside the 80% use case of Laravel Sail.
To run the test suite, Geckodriver binaries for each 64-bit operating systems will need to be downloaded:
composer download
or call the PHP script. Yes, using PHPUnit to run an Artisan command is a hack. Package development!
./vendor/phpunit/phpunit/phpunit tests/DownloadBinaries.php
Run the tests in the command line through Composer:
composer test
or call PHPUnit directly:
./vendor/phpunit/phpunit/phpunit
-
How do I fix error "Failed to connect to localhost port 4444: Connection refused"?
By default Geckodriver runs locally on port 4444. The process may have failed to start.
- Run
php artisan dusk:firefox-driver
to ensure the Geckodriver binary is downloaded. - The Geckodriver proxy server may already be running which can happen after a crash. Kill the conflicting process ("End Task" in Windows) and try running
php artisan dusk
again. - If another service is using port 4444, open
tests/DuskTestCase.php
and change thedriver()
method to configure another port number.
- Run
-
My test suite that passed 100% using Chromedriver now fails in Firefox. How do I fix my tests?
You may find Firefox is more temperamental when calling Laravel Dusk method
visit()
or navigating between web pages. For HTTP redirects and form submissions, you may wish to avoid first calling methodsassertPathIs()
assertPortIsNot()
orassertPathBeginsWith()
. Waiting for elements methods such as thewaitForText()
method are the best fit to delay the test until the next web page has finished loading. When all else fails, add trial-and-errorpause(milliseconds)
calls to make the test determinstic in all environments. -
Can you help me get my tests running in Firefox?
Sorry, no. That would be outside of the scope of support for this package. You can try Laravel community support channels such as the https://laracasts.com/ and https://laravel.io/ forums.
-
Why doesn't the saved browser error log show scripting warnings, such as a .js file failing to load due to CORS (cross-origin resource sharing) restrictions?
Chromedriver implements Selenium's
commands.GetLog
endpoint which provides a wider range of testing feedback. Unfortunately this endpoint is not currently part of the W3C WebDriver API so Geckodriver does not support it.This limitation is the reason Firefox support isn't built into the official Laravel Dusk package.
When submitting a pull request:
- Write new PHP code and docblock in the same style as the Laravel ecoystem. #NoTimeForTypehints
- Add cases to the test suite to ensure code coverage is never reduced.
- Please do not try to support more browsers stubs beyond Chrome & Firefox.
I'll complete a contribution guide when this package warrants it. However I expect this codebase to have a small footprint given its narrow focus.
- Derek MacDonald
- Jonas Staudenmeir, PHP class
FirefoxDriverCommand
is based on proxy downloads in his Laravel Dusk third-party package "staudenmeir/dusk-updater". - All contributors
The MIT License (MIT). Please see License File for more information.