Symfony2功能测试认证

前端之家收集整理的这篇文章主要介绍了Symfony2功能测试认证前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试设置我的功能测试,我遇到了经过身份验证的问题.我已经阅读了本指南: http://symfony.com/doc/current/cookbook/testing/http_authentication.html并实现了他们所说的要做但我仍然坚持重定向登录.我确信这是微不足道的,但我不确定是什么.

测试控制器

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)’浏览’到页面

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

2)通过提交按钮选择表格

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

3)将登录凭证作为数据传递并提交表单

$form = $buttonCrawlerNode->form();
$data = array('username' => 'u@u.com','password' => 'pass');
$client->submit($form,$data);

4)按照重定向

$crawler = $client->followRedirect();

5)此时您应该能够检查响应代码

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

或访问安全页面

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

猜你在找的PHP相关文章