我正在尝试运行单元测试并在安装过程中创建数据库。出于某种原因,我收到错误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;');
}
}
答案 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');