测试期间的Phpunit令牌存储错误

时间:2016-01-08 14:33:18

标签: php symfony phpunit

我有一个测试文件来测试服务实例化,我已经使用KnpMenuBundle创建了一个自定义菜单。 一切正常,期待phpunit在测试我的MenuBuilder时返回错误。

有一个函数可以测试我的测试文件的所有服务实例:

class ServiceAvailabilityTest extends KernelTestCase
{
    /**
    * @dataProvider getServiceIds
    *
    * @param $serviceId
    */
    public function testServiceInstance($serviceId)
    {
        static::bootKernel();

        static::$kernel->getContainer()->get($serviceId);
    }
}

在我的MenuBuilder上,我使用authorizationChecker知道用户是否被授予,如下所示。

if ($this->authorizationChecker->isGranted('ROLE_ADMIN')) {
    $menu->addChild('sidebar.front.administration', ['route' => 'sonata_admin_redirect'])
         ->setExtra('translation_domain', 'navigation')
         ->setAttribute('icon', 'fa fa-eye');
}

当我删除所有这些时,测试就可以了

$this->authorizationChecker->isGranted('ROLE_ADMIN')

运行phpunit时出现错误

  

1)使用数据集#423(' menu.main')测试\ ServiceAvailabilityTest :: testServiceInstance       Symfony \ Component \ Security \ Core \ ExceptionAuthenticationCredentialsNotFoundException:令牌存储不包含身份验证令牌。一个可能的原因可能是没有为此URL配置防火墙。 /code/vendor/symfony/symfony/src/Symfony/Component/Security/Core/Authorization/AuthorizationChecker.php:57       /code/src/AppBundle/Menu/MenuBuilder.php:192       /code/src/AppBundle/Menu/MenuBuilder.php:101       /code/app/cache/test/appTestDebugProjectContainer.php:8311       /code/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Container.php:312       /code/tests/ServiceAvailabilityTest.php:3

如果你需要检查我的菜单服务

menu.builder:
    class: AppBundle\Menu\MenuBuilder
    arguments: [ '@knp_menu.factory', '@doctrine', '@manager.server','@security.authorization_checker', '@request_stack' ]

menu.main:
    class: Knp\Menu\MenuItem
    factory: [ '@menu.builder', 'createMainMenu' ]
    arguments: [ '@request_stack' ]
    tags:
        - { name: knp_menu.menu, alias: sidebar }

我已经在互联网上搜索,但他们通过在security.yml上添加一个访问控制来解决这个问题,就像这样

- { path: ^/, role: ROLE_USER }

但我没有任何菜单路线。

有人已经有这个phpunit错误吗? 谢谢,

1 个答案:

答案 0 :(得分:3)

试试这个:

/**
 * @param string        $firewallName
 * @param UserInterface $user
 * @param array         $options
 * @param array         $server
 */
protected function loginUser($firewallName, UserInterface $user, array $options = array(), array $server = array())
{
    $this->client = static::createClient();

    $token = new UsernamePasswordToken($user, null, $firewallName, $user->getRoles());
    static::$kernel->getContainer()->get('security.token_storage')->setToken($token);
    // <2.8 this may be usefull
    //$request = new Request();
    //$event = new InteractiveLoginEvent($request, $token);
    //static::$kernel->getContainer()->get('event_dispatcher')->dispatch('security.interactive_login', $event);

    $session = $this->client->getContainer()->get('session');
    $session->set('_security_'.$firewallName, serialize($token));
    $session->save();
    $cookie = new Cookie($session->getName(), $session->getId());
    $this->client->getCookieJar()->set($cookie);
}

在testCase / setUp中,例如::

static::bootKernel();
$this->loginUser('admin', $testUser);
$this->assertNotFalse(static::$kernel->getContainer()->get('security.authorization_checker')->isGranted('ROLE_ADMIN'));