Laravel黄昏报告"一般错误:5数据库被锁定"和"操作超时"

时间:2017-10-17 13:45:22

标签: laravel phpunit laravel-dusk

我正在运行脚本

namespace Tests\Browser;

use App\User;
use Tests\DuskTestCase;
use Laravel\Dusk\Browser;
use Illuminate\Foundation\Testing\RefreshDatabase;

class RegistrationTest extends DuskTestCase
{

    use RefreshDatabase;

    /** @test */

    public function a_user_registers_for_an_account()
    {
        $this->browse(function (Browser $browser)
        {
            $browser->visit(route('app-registration-create'))
                ->type('name', 'John')
                ->type('lastName', 'Doe')
                ->type('email', 'john.doe@ps.com')
                ->type('password', 'password')
                ->type('password_confirmation', 'password')
                ->click('@dusk-accept')
                ->click('@register-button') //
                ->assertDontSee('The name field is required.');
        });

        $this->assertDatabaseHas('users', [
            'email' => 'john.doe@ps.com',
            'verified' => 0
        ]);
    }


    /** @test */

    public function a_user_confirms_a_email_address()
    {
        $this->browse(function (Browser $browser)
        {
            $user = User::where('email', 'john.doe@ps.com')->first();

            var_dump(route('app-registration-confirm-email', ['token' => $user->token])); // "http://ps.dev/app/registration/confirm/aPAWN1QlGyl8Id2vXIJU9Fn8G6bsef"

            $browser->visit(route('app-registration-confirm-email', ['token' => $user->token]));

        });

        $this->assertDatabaseHas('users', [
            'email' => 'john.doe@ps.com',
            'verified' => 1
        ]);
    }

}

当它击中线

$browser->visit(route('app-registration-confirm-email', ['token' => $user->token]));

它停止工作。该步骤背后的想法是验证用户提供了有效的电子邮件地址。因此,应用程序将从URL中获取令牌,并检查数据库中是否存在具有该令牌的用户。如果是,请将verified属性设置为1并将标记设置为null。

但我收到以下错误:

在laravel.log文件中我可以看到:

[2017-10-17 13:24:30] testing.ERROR: SQLSTATE[HY000]: General error: 5 
database is locked (SQL: update "users" set "verified" = 1, "token" = , 
"updated_at" = 2017-10-17 13:23:30 where "id" = 1)

在终端上我可以看到:

There was 1 error:

1) Tests\Browser\RegistrationTest::a_user_confirms_a_email_address
Facebook\WebDriver\Exception\WebDriverCurlException: Curl error thrown for http GET to /session/856dbb7e7769ec0a369e44e13b6b676d/screenshot

Operation timed out after 30000 milliseconds with 0 bytes received

/home/vagrant/ps/vendor/facebook/webdriver/lib/Remote/HttpCommandExecutor.php:286
/home/vagrant/ps/vendor/facebook/webdriver/lib/Remote/RemoteWebDriver.php:535
/home/vagrant/ps/vendor/facebook/webdriver/lib/Remote/RemoteWebDriver.php:333
/home/vagrant/ps/vendor/laravel/dusk/src/Browser.php:244
/home/vagrant/ps/vendor/laravel/dusk/src/TestCase.php:160
/home/vagrant/ps/vendor/laravel/framework/src/Illuminate/Support/Collection.php:341
/home/vagrant/ps/vendor/laravel/dusk/src/TestCase.php:161
/home/vagrant/ps/vendor/laravel/dusk/src/TestCase.php:94
/home/vagrant/ps/tests/Browser/RegistrationTest.php:51

也许我没有正确应用黄昏,但我无法在网上找到解决方案。

1 个答案:

答案 0 :(得分:2)

这是一个已经有些陈旧的问题但我自己拥有它时找到了解决这个问题的方法。 问题是测试之间没有关闭连接。如果我一次只调用1但是运行一批测试会导致数据库锁定错误,那么我的测试会起作用。

解决方案是我在自己的拆解功能中错过了parent::tearDown();。这意味着测试之间不会关闭连接。

对于被问到的问题,tearDown或其他测试中很可能只有DuskTestCase函数而没有parent::tearDown();。看看这个,你应该能够在某个地方找到问题。

TLDR:检查您的tearDown功能,确保它们包含parent::tearDown();。否则,在测试后,连接将不会关闭。