我正在尝试设置我的功能测试,但我遇到了经过身份验证的问题。我已经阅读了本指南: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
)
有关如何解决这个问题的任何建议吗?
答案 0 :(得分:9)
您应该能够执行以下操作:
1)&#39;浏览&#39;到页面
Appearance > Menus > Manage Locations
2)通过提交按钮
选择表格$client = static::createClient();
$crawler = $client->request('GET', '/login');
3)将登录凭证作为数据传递并提交表单
$buttonCrawlerNode = $crawler->selectButton('submit');
4)按照重定向
$form = $buttonCrawlerNode->form();
$data = array('username' => 'u@u.com','password' => 'pass');
$client->submit($form,$data);
5)此时您应该能够检查响应代码
$crawler = $client->followRedirect();
或访问受保护的页面
$this->assertEquals(302, $client->getResponse()->getStatusCode());
答案 1 :(得分:8)
使用:
$crawler = $client->followRedirect();
或使该客户端始终重定向:
$client->followRedirects();
相关文档:http://symfony.com/doc/current/book/testing.html#redirecting