我在使用Laravel 4进行测试时遇到了一些问题。我使用.env
文件按照Laravel's Configuration manual - Protecting Sensitive Configuration 3}中描述的方式管理我的数据库设置p>
app/config/database.php
文件如下所示:
'mysql' => array(
'driver' => 'mysql',
'host' => $_ENV['dbhost'],
'database' => $_ENV['database'],
'username' => $_ENV['dbusername'],
'password' => $_ENV['dbpassword'],
'charset' => 'utf8',
'collation' => 'utf8_unicode_ci',
'prefix' => '',
),
正在测试的控制器方法:
public function getTaxonomies()
{
if (Input::has('page')) {
$limit = (Input::get('limit')) ? Input::get('limit') : 15;
$taxonomy = Taxonomy::with('photos')->paginate($limit)->toArray();
return Response::json(array(
'Taxonomies' => $taxonomy
));
}
return Response::json(array(
'Taxonomies' => Taxonomy::all()->load('photos')->toArray()
));
}
测试:
<?php
# app/tests/controllers/TaxonomyControllerTest.php
class TaxonomyControllerTest extends TestCase
{
public function testGetTaxonomies()
{
$this->action('GET', 'TaxonomyController@getTaxonomies');
$this->assertResponseOk();
}
}
我得到的错误是ErrorException: Undefined index: dbhost
。我意识到这是因为$_ENV
var未在CLI中填充。所以我的问题是,我应该如何处理数据库信用卡进行测试?
更新
所以我在我的database.php
文件夹中添加了一个空的app/config/testing
文件,现在我不再收到该错误。我假设它是因为数据库不再被调用了吗?我应该使用嘲弄来测试数据吗?
答案 0 :(得分:2)
注意:您可以为您支持的每个环境创建一个文件 应用。例如,开发环境将加载 .env.development.php文件(如果存在)。
只需创建.env.testing.php
文件并在其中编写测试数据库凭据。
return array(
/*
|--------------------------------------------------------------------------
| Database Credentials
|--------------------------------------------------------------------------
*/
'dbhost' => '127.0.0.1',
'database' => 'database',
'dbusername' => 'username',
'dbpassword' => 'password',
);