我有一个测试文件来测试服务实例化,我已经使用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错误吗? 谢谢,
答案 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'));