mercredi 24 décembre 2014

Laravel phpunit Access denied for user

I want to do unit testing with Laravel 4. But i have a problem.


This is my controller



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));
}
}


And this is my test code



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'
]
];
}
}


I get the following errors:



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)


I dont want to use database in the test. I want to use data in halisahaDatas method. I think php unit trying to connect to the database and getting error.


Aucun commentaire:

Enregistrer un commentaire