Laravel Dusk、assertSee() の使い方を教えてください
質問内容
Laravelプロジェクトを作成した時の welcome.blade.php に対して、
Laravel Dusk の assertSee('Laravel') でページ上にあるかどうかをテストしたのですが、
結果が false になってしまします。
welcome.blade.php には、初期で Laravel というテキストが記載されているので、
テスト結果が true になると思うのですがなぜが false になってしまいます。
テスト結果が true にならない理由を教えて頂けますでしょうか?
また、assertSee の使用方法が間違っていれば、正しい使用方法を教えて頂けますでしょうか?
assertSee
指定したテキストが、ページ上に存在することを宣言します。
$browser->assertSee($text);
※ 引用 : Laravel 公式サイトの文章より^1
動作確認手順
- Laravel のプロジェクトを作成(事前準備)
composer require -dev laravel/dusk
を実行してパッケージを追加php artisan dusk:install
を実行php artisan dusk
を実行して、tests/Browser フォルダ下のファイルをテスト
※ 今回は、テスト用に [[### ソース一覧|ExampleTest.php]] のみを作成したので、
この1ファイルのみがテスト対象です
version 情報
php : 7.2.24
Laravel : 6.5.0
Laravel Dusk : 5.6.1
※ ひとまず、上記3つについて version を記載しました。
その他、パッケージなどの version 情報が必要であればおっしゃってください。
ソース一覧
- tests/Browser/ExampleTest.php
<?php
namespace Tests\Browser;
use Tests\DuskTestCase;
use Laravel\Dusk\Browser;
use Illuminate\Foundation\Testing\DatabaseMigrations;
class ExampleTest extends DuskTestCase
{
/**
* A basic browser test example.
*
* @return void
*/
public function testBasicExample()
{
$this->browse(function (Browser $browser) {
$browser->visit('/')
->assertSee('Laravel');
});
}
}
- resources/views/welcome.blade.php
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Laravel</title>
<!-- Fonts -->
<link href="https://fonts.googleapis.com/css?family=Nunito:200,600" rel="stylesheet">
<!-- Styles -->
<style>
html, body {
background-color: #fff;
color: #636b6f;
font-family: 'Nunito', sans-serif;
font-weight: 200;
height: 100vh;
margin: 0;
}
.full-height {
height: 100vh;
}
.flex-center {
align-items: center;
display: flex;
justify-content: center;
}
.position-ref {
position: relative;
}
.top-right {
position: absolute;
right: 10px;
top: 18px;
}
.content {
text-align: center;
}
.title {
font-size: 84px;
}
.links > a {
color: #636b6f;
padding: 0 25px;
font-size: 13px;
font-weight: 600;
letter-spacing: .1rem;
text-decoration: none;
text-transform: uppercase;
}
.m-b-md {
margin-bottom: 30px;
}
</style>
</head>
<body>
<div class="flex-center position-ref full-height">
@if (Route::has('login'))
<div class="top-right links">
@auth
<a href="{{ url('/home') }}">Home</a>
@else
<a href="{{ route('login') }}">Login</a>
@if (Route::has('register'))
<a href="{{ route('register') }}">Register</a>
@endif
@endauth
</div>
@endif
<div class="content">
<div class="title m-b-md">
Laravel
</div>
<div class="links">
<a href="https://laravel.com/docs">Docs</a>
<a href="https://laracasts.com">Laracasts</a>
<a href="https://laravel-news.com">News</a>
<a href="https://blog.laravel.com">Blog</a>
<a href="https://nova.laravel.com">Nova</a>
<a href="https://forge.laravel.com">Forge</a>
<a href="https://vapor.laravel.com">Vapor</a>
<a href="https://github.com/laravel/laravel">GitHub</a>
</div>
</div>
</div>
</body>
</html>