2012-07-18 15 views
7

Próbuję ustawić testy funkcjonalne i mam problemy z uzyskaniem uwierzytelnienia. Przeczytałem ten przewodnik: http://symfony.com/doc/current/cookbook/testing/http_authentication.html i zaimplementowałem to, co powiedzieli, ale nadal utknąłem na przekierowaniu logowania. Jestem pewien, że to jest coś trywialnego, ale nie jestem pewien co.Uwierzytelnianie testu funkcjonalnego Symfony2

testowania kontrolera

namespace HvH\ClientsBundle\Tests\Controller; 

use HvH\ClientsBundle\Controller\ClientsController; 

use Symfony\Bundle\FrameworkBundle\Test\WebTestCase; 
use Symfony\Component\HttpFoundation\Request; 
use Symfony\Component\HttpFoundation\HeaderBag; 
use Symfony\Component\HttpFoundation\Session; 
use Symfony\Bundle\FrameworkBundle\Controller\Controller; 

class ClientsControllerTest extends WebTestCase 
{ 

    public function testGetClientsAction() 
    { 

     $client = static::createClient(); 

     $client->request(
      '/clients/123456', 
      'GET', 
      array(), /* request params */ 
      array(), /* files */ 
      array('X-Requested-With' => "XMLHttpRequest", 'PHP_AUTH_USER' => 'testuser', 'PHP_AUTH_PW' => 'testpass') 
     ); 

     print_r($client->getResponse()); 
     die(); 
    } 
} 

congif_test.yml

security: 
    firewalls: 
     secured_area: 
      http_basic: 

Wynik wniosek

Symfony\Component\HttpFoundation\RedirectResponse Object 
(
    [headers] => Symfony\Component\HttpFoundation\ResponseHeaderBag Object 
     (
      [computedCacheControl:protected] => Array 
       (
        [no-cache] => 1 
       ) 

      [cookies:protected] => Array 
       (
        [] => Array 
         (
          [/] => Array 
           (
            [PHPSESSID] => Symfony\Component\HttpFoundation\Cookie Object 
             (
              [name:protected] => PHPSESSID 
              [value:protected] => 7e3ece541918264de0003e2dcd251833 
              [domain:protected] => 
              [expire:protected] => 1342616045 
              [path:protected] =>/
              [secure:protected] => 
              [httpOnly:protected] => 
             ) 

           ) 

         ) 

       ) 

      [headers:protected] => Array 
       (
        [location] => Array 
         (
          [0] => http://localhost/login 
         ) 

        [cache-control] => Array 
         (
          [0] => no-cache 
         ) 

        [date] => Array 
         (
          [0] => Wed, 18 Jul 2012 00:54:05 GMT 
         ) 

        [content-type] => Array 
         (
          [0] => text/html 
         ) 

        [x-debug-token] => Array 
         (
          [0] => 5006092d43848 
         ) 

       ) 

      [cacheControl:protected] => Array 
       (
       ) 

     ) 

    [content:protected] => <!DOCTYPE html> 
<html> 
    <head> 
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
     <meta http-equiv="refresh" content="1;url=http://localhost/login" /> 

     <title>Redirecting to http://localhost/login</title> 
    </head> 
    <body> 
     Redirecting to <a href="http://localhost/login">http://localhost/login</a>. 
    </body> 
</html> 
    [version:protected] => 1.0 
    [statusCode:protected] => 302 
    [statusText:protected] => Found 
    [charset:protected] => UTF-8 
) 

y sugestie, jak to obejść?

+1

Jeśli urządzenie korzysta FOSUserBundle, proszę spojrzeć na http://stackoverflow.com/questions/14957807/symfony2-tests-with-fosuserbundle/27223293# 27223293 –

Odpowiedz

8

Albo zastosowanie:

$crawler = $client->followRedirect(); 

lub sprawi że klient zawsze przekierowania:

$client->followRedirects(); 

Powiązane doc: http://symfony.com/doc/current/book/testing.html#redirecting

+0

Dzięki. Wydaje mi się, że doprowadziłem mnie do strony logowania, w jaki sposób mogę ją uwierzytelnić? – greg

+0

Myślę, że mógłbym stworzyć metodę dla robota symulującego logowanie, ale najlepiej mogłaby po prostu pracować z PHP_AUTH vars – greg

+0

Czy próbowałeś tego? http://symfony.com/doc/current/cookbook/testing/http_authentication.html –

8

powinien być w stanie wykonać następujące czynności:

1) "przeglądaj" na stronie

$client = static::createClient(); 
$crawler = $client->request('GET', '/login'); 

2) Wybierz formę za pomocą przycisku składania

$buttonCrawlerNode = $crawler->selectButton('submit'); 

3) przechodzą poświadczeń logowania jak dane i wysłać formularz

$form = $buttonCrawlerNode->form(); 
$data = array('username' => '[email protected]','password' => 'pass'); 
$client->submit($form,$data); 

4) Postępuj przekierowanie

$crawler = $client->followRedirect(); 

5) W tym momencie powinieneś być w stanie sprawdzić odpowiedź c Ode

$this->assertEquals(302, $client->getResponse()->getStatusCode()); 

lub dostępu do zabezpieczonej strony

$crawler = $client->request('GET', '/dashboard'); 
//do other stuff 
Powiązane problemy