Laravel在测试时创建数据库

时间:2013-06-28 20:57:50

标签: php laravel laravel-4

我正在尝试运行单元测试并在安装过程中创建数据库。出于某种原因,我收到错误Unknown database 'coretest'。如果我通过手动创建数据库并运行测试,那么我得到Can't create database 'coretest'; database exists

drop database语句现在只能用于创建数据库。

这是我的setUP和tearDown方法:

class TestCase extends Illuminate\Foundation\Testing\TestCase {
    /**
     * Default preparation for each test
     */

    public function setUp() {
        parent::setUp();

        DB::statement('create database coretest;');
        Artisan::call('migrate');
        $this->seed();
        Mail::pretend(true);
    }

    public function tearDown() {
        parent::tearDown();
        DB::statement('drop database coretest;');
    }
}

4 个答案:

答案 0 :(得分:11)

您收到此错误的原因仅仅是因为laravel尝试连接到config中指定的数据库,该数据库不存在。

解决方案是从设置构建您自己的PDO连接,而不指定数据库(PDO允许此操作)并使用它运行CREATE DATABASE $dbname语句。

我们使用这种方法在我们的项目中进行测试没有任何问题。


Here一些代码:

<?php

/**
 * Bootstrap file for (re)creating database before running tests
 *
 * You only need to put this file in "bootstrap" directory of the project
 * and change "bootstrap" phpunit parameter within "phpunit.xml"
 * from "bootstrap/autoload.php" to "bootstap/testing.php"
 */

$testEnvironment = 'testing';

$config = require("app/config/{$testEnvironment}/database.php");

extract($config['connections'][$config['default']]);

$connection = new PDO("{$driver}:user={$username} password={$password}");
$connection->query("DROP DATABASE IF EXISTS ".$database);
$connection->query("CREATE DATABASE ".$database);

require_once('app/libraries/helpers.php');

// run migrations for packages
foreach(glob('vendor/*/*', GLOB_ONLYDIR) as $package) {
    $packageName = substr($package, 7); // drop "vendor" prefix
    passthru("./artisan migrate --package={$packageName} --env={$testEnvironment}");
}
passthru('./artisan migrate --env='.$testEnvironment);

require('autoload.php'); // run laravel's original bootstap file

答案 1 :(得分:2)

我觉得我有一个更清洁的方式来做这件事。只需通过shell执行命令即可。

$host      = Config::get('database.connections.mysql.host');
$database  = Config::get('database.connections.mysql.database');
$username  = Config::get('database.connections.mysql.username');
$password  = Config::get('database.connections.mysql.password');
echo shell_exec('mysql -h ' . $host . ' -u ' . $username . ' -p' . $password . ' -e "DROP DATABASE ' . $database . '"');
echo shell_exec('mysql -h ' . $host . ' -u ' . $username . ' -p' . $password . ' -e "CREATE DATABASE ' . $database . '"');

答案 2 :(得分:2)

neoascetic有最好的答案,因为基本上你必须再次启动laravel的数据库配置文件。

所以,一个聪明的黑客是在你删除数据库后再次创建数据库。无需触摸配置/数据库。

public function setUp() {
    parent::setUp();

    Artisan::call('migrate');
    $this->seed();
    Mail::pretend(true);
}

public function tearDown() {
    parent::tearDown();

    DB::statement('drop database coretest;');
    DB::statement('create database coretest;');
}

答案 3 :(得分:0)

在Laravel 5中,可以在内部调用Laravel进程进行迁移,最终运行速度比使用外部命令快得多。

在TestCase :: setUp(或更早版本)中,使用以下命令调用migration命令:

$kernel = app('Illuminate\Contracts\Console\Kernel');
$kernel->call('migrate');