7

機能テストを設定しようとしていますが、認証の取得に問題があります。私はこのガイドを読みました: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
)

これを回避する方法について何か提案はありますか?

4

2 に答える 2

8

次のいずれかを使用します。

$crawler = $client->followRedirect();

または、クライアントが常にリダイレクトするようにします。

$client->followRedirects();

関連ドキュメント: http://symfony.com/doc/current/book/testing.html#redirecting

于 2012-07-18T08:22:49.207 に答える
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
于 2015-05-28T14:01:52.427 に答える