视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Laravel Dusk 中五个的使用技巧
2020-11-03 12:31:03 责编:小采
文档

Laravel Dusk 是 Laravel 的一个表达性强、易于使用,且功能强大的浏览器自动化测试工具。通过 Dusk 可以以编程的方式测试 JavaScript 驱动的应用程序。在使用 Dusk 编写测试案例时,我经常遇到一些。现在我在本文中将这些情况以及如何克服分享给大家。

1. 填充隐藏字段

在测试某些 JS 组件时 (例如自动完成,日期选择器等) ,可能需要编写动作模拟操作与这些组件交互。犹豫这些组件中的大多数最终都会将值保存到隐藏字段中。那么将值直接填写到隐藏字段中可能更加方便。这可以防止不稳定的测试,并确保我们不测试自己不拥有 / 控制的东西 (第三方组件)。

尽管 Laravel Dusk 没有为我们提供类似 $browser->fillHidden($field, $value) 的方法,但我们可以使用 Dusk Browser Macros 来实现。

//将以下代码添加到 serviceprovider.php 中
Browser::macro('fillHidden', function ($name , $value) {
 $this->script("document.getElementsByName('$name')[0].value = '$value'");
 return $this;
});
// 然后你可以像这样使用
/** @test */
public function fill_hidden_fields()
{
 $this->browse(function (Browser $browser) {
 $browser->visit('https://website.com/form')
 ->type('input.name', $name)
 ->type('input.address', $address)
 ->fillHidden('checkin_date', $date)
 ->click('#Submit')
 ->waitForText('Orders');
 });
}

2. 模拟 HTML 地理位置

我曾经不得不测试一个页面,该页面需要 HTML 网站提供地理位置,以便它可以显示一些结果。没有可用的直接模拟方法,因此我不得不重写 getCurrentPosition 方法,该方法最终将由页面调用。

/** @test */
public function test_geo_location()
{
 $faker = FakerFactory::create();
 $latitude = $faker->latitude;
 $longitude = $faker->longitude;
 $this->browse(function (Browser $browser) use($latitude, $longitude) {
 $browser->visit(new Homepage)
 ->assertOnPage();
 $browser->driver->executeScript(
 "window.navigator.geolocation.getCurrentPosition = function(onSuccessCallback) {
 var position = {
 'coords': { 'latitude': {$latitude}, 'longitude': {$longitude} }
 };
 onSuccessCallback(position);
 }"
 );
 $browser->click('#geolocate-button')
 ->assertSee('Longitude: $longitude')
 ->assertSee('Latitude: Latitude')
 });
}

3. 使用 XPath 选择器

有时,我会遇到无法使用 CSS 选择器来定位元素的情况。这些通常发生在动态表格中,或者在我无法修改的第三方 js 组件中。但是,Laravel Dusk 不直接支持 XPath 选择器,并且经常需要访问基础 WebDriver 实例。

$browser->driver->findElement(
WebDriverBy::xpath("//table[@class='x-grid3-row-table']/tbody/tr/td/div/a[contains(text(),'$value')]")
)->click();

这种方法的唯一问题就是 [问题不大] 可能会终端 $browser 链式调用.

4. 整页截屏

Laravel dusks 为我们提供了失败测试的屏幕截图,这对于了解测试失败的原因非常有帮助。但是,有时错误或有问题的元素可能在屏幕显示区域以外。

要在 Laravel Dusk 中创建完整的屏幕截图,我们必须在我们的 tests DuskTestCase.php 中创建一个 captureFailuresFor() 方法,它将覆盖最初在 LaravelDuskConcernsProvidesBrowser 中定义的一个方法。

protected function captureFailuresFor($browsers)
{
 $browsers->each(function (Browser $browser, $key) {
 $body = $browser->driver->findElement(WebDriverBy::tagName('body'));
 if (!empty($body)) {
 $currentSize = $body->getSize();
 $size = new WebDriverDimension($currentSize->getWidth(), $currentSize->getHeight());
 $browser->driver->manage()->window()->setSize($size);
 }
 $name = str_replace('\', '_', get_class($this)).'_'.$this->getName(false);
 $browser->screenshot('failure-'.$name.'-'.$key);
 });
}

现在,无论何时我们调用 $browser->screenshot('$shotname') ,发生错误时我们都将获得完整的屏幕截图

5. 访问浏览器错误日志

这个没什么问题,只是我发现的一些有趣的东西。我们可以通过调用 $browser->driver->manage()->getLog(‘browser’) 来访问浏览器控制台日志。

这将在浏览器的控制台中返回一系列日志。例如,对于页面上没有 javascript 错误的测试而言,它可能很有用。

@test
public function no_browser_errors()
{
 $this->browse(function ($browser) {
 $this->assertEmpty($browser->driver->manage()->getLog('browser'));
 });
}

但是请注意,它不包含 console.log 调用的输出

结论

感谢您阅读本文,希望您有所收获。

感谢阅读

推荐教程:《Laravel教程》《PHP教程》

下载本文
显示全文
专题