| Package Data | |
|---|---|
| Maintainer Username: | Josrom |
| Maintainer Contact: | taylor@laravel.com (Taylor Otwell) |
| Package Create Date: | 2017-06-29 |
| Package Last Update: | 2019-03-21 |
| Language: | PHP |
| License: | MIT |
| Last Refreshed: | 2025-12-09 03:01:21 |
| Package Statistics | |
|---|---|
| Total Downloads: | 1,737 |
| Monthly Downloads: | 0 |
| Daily Downloads: | 0 |
| Total Stars: | 1 |
| Total Watchers: | 1 |
| Total Forks: | 2 |
| Total Open Issues: | 0 |
Laravel Dusk provides an expressive, easy-to-use browser automation and testing API. By default, Dusk does not require you to install JDK or Selenium on your machine. Instead, Dusk uses a standalone Chromedriver. However, you are free to utilize any other Selenium driver you wish.
Documentation for Dusk can be found on the Laravel website.
To get the last version of Laravel Dusk for 5.1, simply require the project using Composer:
composer require --dev josrom/laravel-dusk-5.1
Instead, you may of course manually update your require block and run composer update if you so choose:
{
"require-dev": {
"josrom/laravel-dusk-5.1": "0.1.*"
}
}
Add the service provider app/Providers/AppServiceProvider.php file:
if ($this->app->environment('local')) {
$this->app->register(\Laravel\Dusk\DuskServiceProvider::class);
}
After installing the Dusk package, run the dusk:install Artisan command:
php artisan dusk:install
A Browser directory will be created within your tests directory and will contain an example test. Next, set the APP_URL environment variable in your .env file. This value should match the URL you use to access your application in a browser.
To run your tests, use the dusk Artisan command. The dusk command accepts any argument that is also accepted by the phpunit command:
php artisan dusk
By default dusk use the port 9515 and have a timeout of 20 seconds.
If you need change the configuration the dusk port and/or timeout, it is needed to publish the config file:
php artisan vendor:publish --provider="Laravel\Dusk\DuskServiceProvider" --tag="config"
To make the changes by environment variables*, add the fields in the dusk env file.
| Method | Definition | | ------ | ---------- | | switchFrame | (type of selector, value of selector) | | select2 | (selector, value(s), wait in seconds) | | selectBySelector | (selector css, value of selector) | | assertFragmentIs | (value of fragment) | | assertQueryIs | (value of query) | | scrollTo | (selector jQuery) | | wysiwyg | (type of wysiwyg: tinymce, ID of wysiwyg, value) |
Example of payment with paypal using the switchFrame method:
$browser->loginAs($user)
->visit('/user')
->assertSee('Some Event')
->clickLink('Register Now')
->assertSee('Some Event')
->check('accept_terms')
->press('Submit Application')
->assertSee('Your application has been submitted.')
->press('.paypal-button')
->waitFor('#injectedUnifiedLogin', 30)
->switchFrame('injectedUl')
->type('#email', env('PAYPAL_TEST_BUYER_USERNAME'))
->type('#password', env('PAYPAL_TEST_BUYER_PASSWORD'))
->press('#btnLogin')
->waitFor('#confirmButtonTop', 30)
->waitUntilMissing('#spinner')
->press('#confirmButtonTop')
->waitForText('You paid', 30)
->waitUntilMissing('#spinner')
->press('#merchantReturnBtn')
->waitForText('Events Registration', 30)
->pause(10000) // waiting for IPN callback from paypal
->refresh()
->assertSee('Payment verified')
;
Example of select2 uses:
$browse->select2('@selector');
$browse->select2('@selector', 'you_text_value');
$browse->select2('@selector', ['foo', 'bar'], 5);
<select class="form-control select2-users" name="user_id">
</select>
$browse->select2('.select2-users + .select2', 'you_text_value');
Example of selectBySelector uses:
$browse->selectBySelector('select.my-custom-selector', 'value');
Example of assertFragmentIs uses:
$browser->visit('http://laravel.com/#/login')
->assertPathIs('/')
->assertFragmentIs('/login');
Example of assertQueryIs uses:
$browser->visit('http://laravel.com?key=test')
->assertPathIs('/')
->assertQueryIs('key=test');
Example of scrollTo uses:
$browser->visit('http://laravel.com')
->scrollTo('#cookie-id')
->click('#cookie-id');
Example of wysiwyg uses:
$browser->visit('http://laravel.com')
->wysiwyg('tinymce', 'form-id', '<h2>value</h2>');
Laravel Dusk is open-sourced software licensed under the MIT license