josrom / laravel-dusk-5.1
Laravel Dusk provides simple end-to-end testing and browser automation.
Installs: 1 737
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 2
Open Issues: 0
pkg:composer/josrom/laravel-dusk-5.1
Requires
- php: >=5.6.4
 - facebook/webdriver: 1.*
 - laravel/framework: 5.1.*
 - nesbot/carbon: ~1.20
 
Requires (Dev)
- mockery/mockery: 0.9.*
 - phpunit/phpunit: 5.7.*
 
README
Laravel 5.1
Introduction
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.
Official Documentation
Documentation for Dusk can be found on the Laravel website.
Installation
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
Configuration
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.
Extra methods
| 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) | 
Examples
switchFrame
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') ;
select2
Example of select2 uses:
- For default select2. If value not passed, it be selected automatically:
 
$browse->select2('@selector');
- Another way, if need concrete value:
 
$browse->select2('@selector', 'you_text_value');
- For multiple mode usage like this:
 
$browse->select2('@selector', ['foo', 'bar'], 5);
- Css-selector for the select html tag should be ends with + select2 name:
 
<select class="form-control select2-users" name="user_id"> </select>
$browse->select2('.select2-users + .select2', 'you_text_value');
selectBySelector
Example of selectBySelector uses:
$browse->selectBySelector('select.my-custom-selector', 'value');
assertFragmentIs
Example of assertFragmentIs uses:
$browser->visit('http://laravel.com/#/login') ->assertPathIs('/') ->assertFragmentIs('/login');
assertQueryIs
Example of assertQueryIs uses:
$browser->visit('http://laravel.com?key=test') ->assertPathIs('/') ->assertQueryIs('key=test');
scrollTo
Example of scrollTo uses:
$browser->visit('http://laravel.com') ->scrollTo('#cookie-id') ->click('#cookie-id');
wysiwyg
Example of wysiwyg uses:
$browser->visit('http://laravel.com') ->wysiwyg('tinymce', 'form-id', '<h2>value</h2>');
License
Laravel Dusk is open-sourced software licensed under the MIT license