2013-05-30 9 views
5

Próbuję przetestować metodę wywołania interfejsu API, która jest zabezpieczana przy użyciu podstawowego uwierzytelniania i która musi pobrać użytkownika z kontekstu zabezpieczeń.Nie można pobrać użytkownika z kontekstu zabezpieczeń w środowisku testowym.

Mój plik config_test.yml (używam bazy danych w pamięci do testu ENV):

imports: 
    - { resource: config_dev.yml } 

doctrine: 
    dbal: 
     driver: pdo_sqlite 
     path: :memory: 
     memory: true 
    orm: 
     auto_generate_proxy_classes: %kernel.debug% 
     auto_mapping: true 

framework: 
    test: ~ 
    session: ~ 
    profiler: 
     enabled: false 

web_profiler: 
    toolbar: false 
    intercept_redirects: false 

swiftmailer: 
    disable_delivery: true 

Utworzyłem testu gdzie instancję klienta w następujący sposób:

$options = array(
     'environment' => 'test', 
     'debug'  => true, 
    ); 

    $this->client = static::createClient($options); 

Test wygląda następująco:

public function testProfileAction() 
{ 
    $mockUser = new User(); 
    $mockUser->setUsername("user"); 
    $mockUser->setEmail("[email protected]"); 
    $mockUser->setName("User"); 
    $mockUser->setSurname("User"); 
    $mockUser->setPlainPassword("1234567890"); 
    $this->em->persist($mockUser); 
    $this->em->flush(); 

    $crawler = $this->client->request('GET', '/api/1/user/profile', array(), array(), array(
     'PHP_AUTH_USER' => 'user', 
     'PHP_AUTH_PW' => '1234567890', 
    )); 
    $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); 
} 

Metoda wymaga pozyskania użytkownika z kontekstu zabezpieczeń.

$user = $this->get('security.context')->getToken()->getUser(); 

Ale, podczas testów zawsze otrzymuję 401 zamiast 200. Dumping $ zmienna użytkownika w metodzie jest zawsze zerowa.

Używam Symfony 2.2 i FOSUserBundle.

Z góry dziękuję.

Odpowiedz

5

Miałem ten sam problem. Jak powiedziałeś, musisz utworzyć token, ale musisz również przekształcić go w szereg i utworzyć plik cookie. Oto jak to zrobiłem.

$token = new UsernamePasswordToken($mockUser, null, $firewallName, array($role)); 
self::$kernel->getContainer()->get('security.context')->setToken($token); 
self::$kernel->getContainer()->get('session')->set('security'.$firewallName, serialize($token)); 
self::$kernel->getContainer()->get('session')->save(); 

$cookie = new Cookie(self::$kernel->getContainer()->get('session')->getName(),  self::$kernel->getContainer()->get('session')->getId()); 
$this->client->getCookieJar()->set($cookie); 
0

Musisz najpierw utworzyć token, aby uzyskać do niego dostęp z kontekstu zabezpieczeń.

$firewallName = 'main'; 
$role = 'ROLE_USER'; 

$token = new UsernamePasswordToken($user, null, $firewallName, array($role)); 
self::$kernel->getContainer()->get('security.context')->setToken($token); 

Przykład dostosowany do Twojego przypadku od here.