* #17 - set up Laravel Dusk * #17 - ecs fix * #17 - fix * #17 - fix * #17 - fix * #17 - fix * Update .env.dusk.local Co-authored-by: Krzysztof Rewak <krzysztof.rewak@blumilk.pl> Co-authored-by: Adrian Hopek <adrian.hopek@blumilk.pl> Co-authored-by: Krzysztof Rewak <krzysztof.rewak@blumilk.pl>
This commit is contained in:
65
tests/DuskTestCase.php
Normal file
65
tests/DuskTestCase.php
Normal file
@@ -0,0 +1,65 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Tests;
|
||||
|
||||
use Facebook\WebDriver\Chrome\ChromeOptions;
|
||||
use Facebook\WebDriver\Remote\DesiredCapabilities;
|
||||
use Facebook\WebDriver\Remote\RemoteWebDriver;
|
||||
use Laravel\Dusk\TestCase as BaseTestCase;
|
||||
|
||||
abstract class DuskTestCase extends BaseTestCase
|
||||
{
|
||||
use CreatesApplication;
|
||||
|
||||
/**
|
||||
* @beforeClass
|
||||
*/
|
||||
public static function prepare(): void
|
||||
{
|
||||
if (!static::runningInDocker()) {
|
||||
static::startChromeDriver();
|
||||
}
|
||||
}
|
||||
|
||||
protected function driver(): RemoteWebDriver
|
||||
{
|
||||
$options = (new ChromeOptions())->addArguments(
|
||||
collect(
|
||||
[
|
||||
"--window-size=1920,1080",
|
||||
],
|
||||
)->unless(
|
||||
$this->hasHeadlessDisabled(),
|
||||
function ($items) {
|
||||
return $items->merge(
|
||||
[
|
||||
"--disable-gpu",
|
||||
"--headless",
|
||||
],
|
||||
);
|
||||
},
|
||||
)->all(),
|
||||
);
|
||||
|
||||
return RemoteWebDriver::create(
|
||||
env("DUSK_DRIVER_URL") ?? "http://localhost:" . env("SELENIUM_PORT"),
|
||||
DesiredCapabilities::chrome()->setCapability(
|
||||
ChromeOptions::CAPABILITY,
|
||||
$options,
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
protected function hasHeadlessDisabled(): bool
|
||||
{
|
||||
return isset($_SERVER["DUSK_HEADLESS_DISABLED"]) ||
|
||||
isset($_ENV["DUSK_HEADLESS_DISABLED"]);
|
||||
}
|
||||
|
||||
protected static function runningInDocker(): bool
|
||||
{
|
||||
return isset($_ENV["DUSK_IN_DOCKER"]) && $_ENV["DUSK_IN_DOCKER"] === "true";
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user