Laravel Model Factory无需连接数据库

时间:2016-08-10 20:06:50

标签: php laravel unit-testing testing lumen

我想在一些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

3 个答案:

答案 0 :(得分:1)

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

您可以自己查看source code

答案 1 :(得分:0)

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

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

答案 2 :(得分:0)

您是否尝试使用 DatabaseTransactions

例如

use Illuminate\Foundation\Testing\DatabaseTransactions;
class ModelTransformerTest extends TestCase
{
    use DatabaseTransactions;
}