質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.37%

laravelでduskを実行しても空のDOMしか取得できない

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 705

score 35

前提・実現したいこと

タイトルの通り、laravelでduskを実行しても空のDOMしか取得できません。

発生している問題・ソースコード

DuskTestCase.php

<?php

namespace Tests;

use Laravel\Dusk\TestCase as BaseTestCase;
use Facebook\WebDriver\Chrome\ChromeOptions;
use Facebook\WebDriver\Remote\RemoteWebDriver;
use Facebook\WebDriver\Remote\DesiredCapabilities;

abstract class DuskTestCase extends BaseTestCase
{
    use CreatesApplication;

    /**
     * Prepare for Dusk test execution.
     *
     * @beforeClass
     * @return void
     */
    public static function prepare()
    {
        // static::startChromeDriver();
    }

    /**
     * Create the RemoteWebDriver instance.
     *
     * @return \Facebook\WebDriver\Remote\RemoteWebDriver
     */
    protected function driver()
    {
        $options = (new ChromeOptions)->addArguments([
            '--disable-gpu',
            '--headless'
        ]);

        return RemoteWebDriver::create(
            'http://selenium:4444/wd/hub',
            DesiredCapabilities::chrome()->setCapability(
                ChromeOptions::CAPABILITY, $options
            )
        );
    }
}


ExampleTest.php
→dumpでDOMを取得しています。

public function testBasicExample()
{
  $this->browse(function (Browser $browser) {
    $browser->visit('/')
            ->dump($browser);
  });
}


↓実行結果

# php artisan dusk
PHPUnit 6.5.14 by Sebastian Bergmann and contributors.

"<html><head></head><body></body></html>"

試したこと

調べたところホスト名が[192.168.99.100]のままだと動かないという情報を見つけ、
ホスト名を付けましたが、変化はありませんでした。

・Win10

192.168.99.100  testapp


・workspace
→なぜかコンテナの再起動を行うと下記で追加した部分は削除されてしまうので、再起動する毎に書き足しています。

127.0.0.1     testapp
APP_NAME=testapp
APP_URL=http://testapp


default.conf

server_name testapp;

次にworkspaceで[curl http://testapp]を実行したところ
curl: (7) Failed to connect to testapp port 80: Connection refused
と返ってきたため、ポート番号の問題かと思い、80→8888に変更しましたが、こちらも変化はありませんでした。
修正後はコンテナの再起動等も行いました。

・laradock配下

NGINX_HOST_HTTP_PORT=8888

補足情報(FW/ツールのバージョンなど)

Win10 Home 64bit
Docker Toolbox
docker version 19.03.12
Laradock
php -v 7.3.20
Laravel Framework 5.5.49
ブラウザテストの実行はChromeドライバではなく、seleniumコンテナを使用しています。

他に必要なソースがありましたら、修正指示をいただければ追記いたします。
よろしくお願いいたします。


追記1

認識が間違っていました。
https://teratail.com/questions/156592
こちらの記事にある通り、

dockerコンテナでexposeしているポート番号とコンテナ内で立ち上がるサーバーのポート番号を同じにする必要がある。

ということなので、ポート番号を8888にする場合、サーバー側も8888にする必要がありました。
docker-compose.yml

### NGINX Server #########################################
nginx:
  build:
    context: ./nginx
    args:
      ...
  volumes:
    ...
  ports:
    - "${NGINX_HOST_HTTP_PORT}:8888" # ←ここを80から8888に変更


ちなみにこの時点でdocker container lsの結果は下記になります。(長いのでポートと名前だけ)
nginxになぜ80/tcpがあるのかはよくわかってません。

$ docker container ls
PORTS                                                                                                                            NAMES
0.0.0.0:4444->4444/tcp                                                                                                           laradock_selenium_1
0.0.0.0:81->81/tcp, 0.0.0.0:443->443/tcp, 80/tcp, 0.0.0.0:8888->8888/tcp                                                         laradock_nginx_1
9000/tcp                                                                                                                         laradock_php-fpm_1
0.0.0.0:8081->80/tcp                                                                                                             laradock_phpmyadmin_1
0.0.0.0:3000-3001->3000-3001/tcp, 0.0.0.0:4200->4200/tcp, 0.0.0.0:8080->8080/tcp, 0.0.0.0:2222->22/tcp, 0.0.0.0:8001->8000/tcp   laradock_workspace_1
0.0.0.0:6379->6379/tcp                                                                                                           laradock_redis_1
0.0.0.0:3306->3306/tcp, 33060/tcp                                                                                                laradock_mysql_1
0.0.0.0:1025->1025/tcp, 0.0.0.0:8025->8025/tcp                                                                                   laradock_mailhog_1
2375-2376/tcp                                                                                                                    laradock_docker-in-docker_1


このあとcurlしましたが結果かわりませんでした。
また、なぜかブラウザで表示もできなくなりましたので、
ゲストとサーバーのポートを80に戻しました。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.37%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る