【发布时间】:2015-02-22 09:07:13
【问题描述】:
我想用 Laravel 4 进行单元测试。但是我有一个问题。
这是我的控制器
class HalisahalarController extends BaseController {
public function getIndex(){
// halı sahaların bilgilerini toplamak için bir dizi değişken oluşturulur
$halisahalar = [];
// halı sahaların foreach içinde gerekli bilgileri alınır
foreach (HalisahaAccount::with(
'halisahaInformation',
'halisahaAdress',
'services',
'halisahaCoverPhoto',
'halisahaUrl'
)->get() as $halisaha) {
$hs['id'] = $halisaha->id; #halı saha id
$hs['name'] = $halisaha->halisahaInformation->halisaha_name; #halı saha ad
$hs['adress']['province'] = isset($halisaha->halisahaAdress) ? $halisaha->halisahaAdress->province->province : -1; # halı saha il
$hs['adress']['county'] = isset($halisaha->halisahaAdress) ? $halisaha->halisahaAdress->county->county : -1; #halı saha ilçe
$hs['services'] = $halisaha->services->toArray(); #halı saha servisleri
$hs['coverPhoto'] = $halisaha->halisahaCoverPhoto->toArray(); #halı saha kapak foto
$hs['halisahaUrl'] = isset($halisaha->halisahaUrl) ? $halisaha->halisahaUrl->url : -1; #halı saha url
// alınan veriler dizi değişken içine itilir
array_push($halisahalar,$hs);
}
return View::make('index',array('halisahalar' => $halisahalar));
}
}
这是我的测试代码
class HalisahalarControllerTest extends TestCase {
/**
* /halisahalar test
*
* @dataProvider halisahaDatas
*/
public function testGetIndex($halisaha)
{
$crawler = $this->client->request('GET', '/halisahalar');
// yanıt başarılı bir şekilde geldi mi
$this->assertResponseOk();
// 200 kodu geldi mi
$this->assertResponseStatus(200);
}
/**
* halisaha datas
*/
public function halisahaDatas () {
return [
[
'id' => 1,
'name' => 'Lider Halı Saha',
'adress' => [
'province' => 'İstanbul',
'county' => 'Sultanbeyli'
],
'services' => [
[
'service' => 'Duş',
'icon' => 'dus.png'
],
[
'service' => 'Çeşitli Oyunlar',
'icon' => 'oyun.png'
]
],
'coverPhoto' => [
[
'photo' => 'lider4.jpg'
]
],
'halisahaUrl' => 'lider'
],[
'id' => 2,
'name' => 'Çalışkan Halı Saha',
'adress' => [
'province' => 'İstanbul',
'county' => 'Sancaktepe'
],
'services' => [
[
'service' => 'Duş',
'icon' => 'dus.png'
],
[
'service' => 'İnternet',
'icon' => 'wifi.png'
]
],
'coverPhoto' => [
],
'halisahaUrl' => 'caliskan-halisaha'
]
];
}
}
我收到以下错误:
1) HalisahalarControllerTest::testGetIndex with data set #0 (1, 'Lider Halı Saha', array('İstanbul', 'Sultanbeyli'), array(array('Duş', 'dus.png'), arra
y('Çeşitli Oyunlar', 'oyun.png')), array(array('lider4.jpg')), 'lider')
PDOException: SQLSTATE[HY000] [1045] Access denied for user 'halisaha_HSHadm'@'localhost' (using password: YES)
2) HalisahalarControllerTest::testGetIndex with data set #1 (2, 'Çalışkan Halı Saha', array('İstanbul', 'Sancaktepe'), array(array('Duş', 'dus.png'),
array('İnternet', 'wifi.png')), array(), 'caliskan-halisaha')
PDOException: SQLSTATE[HY000] [1045] Access denied for user 'halisaha_HSHadm'@'localhost' (using password: YES)
我不想在测试中使用数据库。我想在 halisahaDatas 方法中使用数据。我认为 php 单元试图连接到数据库并出现错误。
【问题讨论】:
-
您需要模拟模型。因为目前我看不到您的
halisahaDatas将如何进入控制器。因此,当您在模型上调用get()时,它当然会使用数据库。 -
我如何断开模型上的 db 进行测试。我在我的应用程序中使用 get()
-
你不能那样做。您可以使用in-memory database 或模拟模型。 Here's a tutorial with mockery
标签: php unit-testing laravel-4 phpunit