RuntimeException:尚未设置外观根

时间:2019-09-08 13:45:25

标签: php testing laravel-5 phpunit

我正在尝试在fork of another package上开发实用程序,以处理Laravel应用程序的数据库模式。

在我的开发中,由于上一个测试什么都没有,所以我想使用测试。尽管当我尝试测试该软件包时,该软件包可以完美地与Laravel 6.X集成在应用程序中,但失败了

<?php

namespace Abkrim\DbSchema\Tests;

use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\DB;
use PHPUnit\Framework\TestCase;
use Faker\Factory as Faker;

class DbSchemaTest extends TestCase
{
    /** @test */
    function it_can_access_the_database()
    {
       $faker = Faker::create();

       $user = DB::table('users')->insert([
           'email' => $faker->unique()->email,
           'name' => $faker->unique()->name,
           'password' => $faker->password(10),
           'rememberToken' => $faker->md5
       ]);
    }
}

如果尝试运行测试

vendor/bin/phpunit --filter DbSchemaTest

1) Abkrim\DbSchema\Tests\DbSchemaTest::it_can_access_the_database
RuntimeException: A facade root has not been set.

/home/abkrim/Sites/db-schema/vendor/laravel/framework/src/Illuminate/Support/Facades/Facade.php:236
/home/abkrim/Sites/db-schema/tests/DbSchemaTest.php:17

1 个答案:

答案 0 :(得分:1)

简单的健忘。要在Laravel外部测试Laravel软件包,必须扩展Orchestra TestCase而不是PHPUnit

正确的代码是

<?php

namespace Abkrim\DbSchema\Tests;

use Abkrim\DbSchema\DbSchema;
use Abkrim\DbSchema\DbSchemaServiceProvider;
use Abkrim\DbSchema\DbSchemaFacade;
use Faker\Factory as Faker;
use Illuminate\Support\Facades\DB;
use Orchestra\Testbench\TestCase;

class DbSchemaTest extends TestCase
{
    protected function getPackageProviders($app)
    {
        return [
            DbSchemaServiceProvider::class
        ];
    }

    protected function getPackageAliases($app)
    {
        return [
            'DbSchema' => DbSchema::class
        ];
    }

    protected function getEnvironmentSetUp($app)
    {
        include_once __DIR__ . '/../database/migrations/create_users_table.php.stub';

        (new \CreateUsersTable)->up();
    }

    /** @test */
    function it_can_access_the_database()
    {
        $faker = Faker::create();
        $mail = 'fake@mail.tld';

        DB::table('users')->insert([
           'email' => $mail,
           'name' => $faker->unique()->name,
           'password' => $faker->password(10),
           'remember_token' => $faker->md5
        ]);

        $user = DB::table('users')->first();

        $this->assertSame($user->email, $mail);
    }
}