2012-07-18 102 views
7

我试图设置我的功能测试,并且遇到了通过身份验证的问题。我已阅读了本指南:http://symfony.com/doc/current/cookbook/testing/http_authentication.html并实施了他们所说的操作,但仍然陷于重定向登录。我确信这是件小事,但我不确定是什么。Symfony2功能测试认证

测试控制器

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: 

所述请求的结果

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 
) 

的Ÿ如何解决这个问题的建议?

+1

如果您正在使用FOSUserBundle,请看看http://stackoverflow.com/questions/14957807/symfony2-tests-with-fosuserbundle/27223293# 27223293 – 2014-12-01 07:24:22

回答

8

要么使用:

$crawler = $client->followRedirect(); 

或使该客户端始终重定向:

$client->followRedirects(); 

相关文件:http://symfony.com/doc/current/book/testing.html#redirecting

+0

谢谢。这似乎让我到登录页面,我如何得到它的身份验证? – greg 2012-07-18 16:32:05

+0

我想我可以为抓取工具创建一个模拟登录的方法,但理想情况下它可能只适用于PHP_AUTH变量 – greg 2012-07-18 16:39:55

+0

您是否尝试过? http://symfony.com/doc/cookbook/testing/http_authentication.html – 2012-07-18 17:02:17

8

你应该能够做到以下几点:

1 )'浏览'至页面

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

2)经由提交按钮

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

3)选择的形式传递登录凭证,如数据并提交表单

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

4)按照重定向

$crawler = $client->followRedirect(); 

5)此时你应该能够检查响应c颂

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

或访问受保护的页面

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