josrom/laravel-dusk-5.1

Laravel Dusk provides simple end-to-end testing and browser automation.

0.1.16 2019-03-21 15:11 UTC

This package is auto-updated.

Last update: 2024-04-22 02:53:06 UTC


README

68747470733a2f2f6c61726176656c2e636f6d2f6173736574732f696d672f636f6d706f6e656e74732f6c6f676f2d6475736b2e737667

Build Status Total Downloads Latest Stable Version License

Laravel 5.1

Build Status Total Downloads Latest Stable Version License

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