Laravel Model Factory无需连接数据库

问题描述 投票:11回答:3

我想在一些PHPUnit测试中使用Laravel的Model Factory。我唯一想做的就是创建一个Model实例而不将其保存到数据库中。

为什么Model Factory需要连接到数据库?这些测试必须传递CI环境而不配置数据库。

当我通过new App\Model($dataArray)手动创建模型时,测试通过并且不需要连接。

我在其他地方使用Model Factory,所以我想在测试中重用它,以避免代码重复。

我正在使用MongoDB和jenssegers/laravel-mongodb库,但我猜它没有问题 - 纯粹的Eloquent和例如MySQL数据库,问题会是一样的。

没有数据库的测试:

class ModelTransformerTest extends TestCase
{
    public function testTransformMinimalModelData()
    {
        $data = [
            '_id' => $faker->md5,
            'email' => $faker->email,
        ];

        $model = new App\Model($data);
        // […];
    }
}

我的模型工厂

$factory->defineAs(Model::class, 'base', function ($faker) {
    return [
        '_id' => $faker->md5,
        'email' => $faker->email,
    ];
});

需要数据库连接的测试:

class ModelTransformerTest extends TestCase
{
    public function testTransformMinimalModelData()
    {
        $model = factory(App\Model::class, 'base')->make();
        // […];
    }
}

完整堆栈跟踪:

Error: Class 'MongoDB\Driver\Manager' not found

app\vendor\mongodb\mongodb\src\Client.php:56
app\vendor\jenssegers\mongodb\src\Jenssegers\Mongodb\Connection.php:147
app\vendor\jenssegers\mongodb\src\Jenssegers\Mongodb\Connection.php:37
app\vendor\jenssegers\mongodb\src\Jenssegers\Mongodb\MongodbServiceProvider.php:27
app\vendor\illuminate\database\DatabaseManager.php:173
app\vendor\illuminate\database\DatabaseManager.php:68
app\vendor\illuminate\database\Eloquent\Model.php:3282
app\vendor\illuminate\database\Eloquent\Model.php:3248
app\vendor\jenssegers\mongodb\src\Jenssegers\Mongodb\Eloquent\Model.php:523
app\vendor\jenssegers\mongodb\src\Jenssegers\Mongodb\Eloquent\Model.php:284
app\vendor\illuminate\database\Eloquent\Model.php:443
app\vendor\illuminate\database\Eloquent\Model.php:281
app\vendor\illuminate\database\Eloquent\FactoryBuilder.php:142
app\vendor\illuminate\database\Eloquent\Model.php:2286
app\vendor\illuminate\database\Eloquent\FactoryBuilder.php:143
app\vendor\illuminate\database\Eloquent\FactoryBuilder.php:106
app\tests\phpunit\Transformers\ModelTransformerTest.php:25
\php\pear\PHPUnit\TextUI\Command.php:176
\php\pear\PHPUnit\TextUI\Command.php:129
php laravel unit-testing testing lumen
3个回答
1
投票

我认为目前不可能。 make()方法调用newModelInstance(),它尝试设置数据库连接。

你可以自己查看source code


0
投票

我通常会创建一个类似的测试数据库并在该数据库上运行所有测试。

它确保您的测试数据库类型与生产相同,并且您不接触生产数据库以运行测试。


0
投票

你尝试使用DatabaseTransactions吗?

例如

use Illuminate\Foundation\Testing\DatabaseTransactions;
class ModelTransformerTest extends TestCase
{
    use DatabaseTransactions;
}
© www.soinside.com 2019 - 2024. All rights reserved.