123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 |
- <?php
- /*
- * This file is part of the Sonata Project package.
- *
- * (c) Thomas Rabaix <thomas.rabaix@sonata-project.org>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Sonata\AdminBundle\Tests\Security\Handler;
- use Sonata\AdminBundle\Admin\AdminInterface;
- use Sonata\AdminBundle\Security\Handler\RoleSecurityHandler;
- use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;
- use Symfony\Component\Security\Core\Exception\AuthenticationCredentialsNotFoundException;
- use Symfony\Component\Security\Core\SecurityContextInterface;
- /**
- * Test for RoleSecurityHandler.
- *
- * @author Andrej Hudec <pulzarraider@gmail.com>
- */
- class RoleSecurityHandlerTest extends \PHPUnit_Framework_TestCase
- {
- /**
- * @var AdminInterface
- */
- private $admin;
- /**
- * @var AuthorizationCheckerInterface|SecurityContextInterface
- */
- private $authorizationChecker;
- public function setUp()
- {
- // Set the SecurityContext for Symfony <2.6
- if (interface_exists('Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface')) {
- $this->authorizationChecker = $this->getMock('Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface');
- } else {
- $this->authorizationChecker = $this->getMock('Symfony\Component\Security\Core\SecurityContextInterface');
- }
- $this->admin = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
- }
- /**
- * @dataProvider getBaseRoleTests
- */
- public function testGetBaseRole($expected, $code)
- {
- $handler = new RoleSecurityHandler($this->authorizationChecker, array('ROLE_BATMAN', 'ROLE_IRONMAN'));
- $this->admin->expects($this->once())
- ->method('getCode')
- ->will($this->returnValue($code));
- $this->assertSame($expected, $handler->getBaseRole($this->admin));
- }
- public function getBaseRoleTests()
- {
- return array(
- array('ROLE_FOO_BAR_%s', 'foo.bar'),
- array('ROLE_FOO_BAR_%s', 'Foo.Bar'),
- array('ROLE_FOO_BAR_BAZ_%s', 'foo.bar_baz'),
- array('ROLE_FOO_BAR_%s', 'FOO.BAR'),
- );
- }
- /**
- * @dataProvider getIsGrantedTests
- */
- public function testIsGranted($expected, array $superAdminRoles, $adminCode, $operation, $object = null)
- {
- $handler = $this->getRoleSecurityHandler($superAdminRoles);
- $this->admin->expects($this->any())
- ->method('getCode')
- ->will($this->returnValue($adminCode));
- $this->authorizationChecker->expects($this->any())
- ->method('isGranted')
- ->will($this->returnCallback(function (array $attributes, $object) {
- if (in_array('ROLE_BATMAN', $attributes)) {
- return true;
- }
- if (in_array('ROLE_IRONMAN', $attributes)) {
- return true;
- }
- if (in_array('ROLE_AUTH_EXCEPTION', $attributes)) {
- throw new AuthenticationCredentialsNotFoundException();
- }
- if (in_array('ROLE_FOO_BAR_ABC', $attributes)) {
- return true;
- }
- if (in_array('ROLE_FOO_BAR_DEF', $attributes) && is_a($object, 'stdClass')) {
- return true;
- }
- return false;
- }));
- $this->assertSame($expected, $handler->isGranted($this->admin, $operation, $object));
- }
- public function getIsGrantedTests()
- {
- return array(
- //empty
- array(false, array(''), 'foo.bar', ''),
- array(false, array(''), 'foo.bar', array('')),
- array(false, array(''), 'foo.bar.abc', array('')),
- array(false, array(''), 'foo.bar.def', array('')),
- array(false, array(''), 'foo.bar.baz.xyz', ''),
- array(false, array(''), 'foo.bar.baz.xyz', array('')),
- //superadmins
- array(true, array('ROLE_BATMAN', 'ROLE_IRONMAN'), 'foo.bar', 'BAZ'),
- array(true, array('ROLE_BATMAN', 'ROLE_IRONMAN'), 'foo.bar', 'ANYTHING'),
- array(true, array('ROLE_BATMAN', 'ROLE_IRONMAN'), 'foo.bar', array('BAZ', 'ANYTHING')),
- array(true, array('ROLE_IRONMAN'), 'foo.bar', 'BAZ'),
- array(true, array('ROLE_IRONMAN'), 'foo.bar', 'ANYTHING'),
- array(true, array('ROLE_IRONMAN'), 'foo.bar.baz.xyz', 'ANYTHING'),
- array(true, array('ROLE_IRONMAN'), 'foo.bar', ''),
- array(true, array('ROLE_IRONMAN'), 'foo.bar', array('')),
- //operations
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', 'ABC'),
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', array('ABC')),
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', array('ABC', 'DEF')),
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', array('BAZ', 'ABC')),
- array(false, array('ROLE_SPIDERMAN'), 'foo.bar', 'DEF'),
- array(false, array('ROLE_SPIDERMAN'), 'foo.bar', array('DEF')),
- array(false, array('ROLE_SPIDERMAN'), 'foo.bar', 'BAZ'),
- array(false, array('ROLE_SPIDERMAN'), 'foo.bar', array('BAZ')),
- array(true, array(), 'foo.bar', 'ABC'),
- array(true, array(), 'foo.bar', array('ABC')),
- array(false, array(), 'foo.bar', 'DEF'),
- array(false, array(), 'foo.bar', array('DEF')),
- array(false, array(), 'foo.bar', 'BAZ'),
- array(false, array(), 'foo.bar', array('BAZ')),
- array(false, array(), 'foo.bar.baz.xyz', 'ABC'),
- array(false, array(), 'foo.bar.baz.xyz', array('ABC')),
- array(false, array(), 'foo.bar.baz.xyz', array('ABC', 'DEF')),
- array(false, array(), 'foo.bar.baz.xyz', 'DEF'),
- array(false, array(), 'foo.bar.baz.xyz', array('DEF')),
- array(false, array(), 'foo.bar.baz.xyz', 'BAZ'),
- array(false, array(), 'foo.bar.baz.xyz', array('BAZ')),
- //objects
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', array('DEF'), new \stdClass()),
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', array('ABC'), new \stdClass()),
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', array('ABC', 'DEF'), new \stdClass()),
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', array('BAZ', 'DEF'), new \stdClass()),
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', 'DEF', new \stdClass()),
- array(true, array('ROLE_SPIDERMAN'), 'foo.bar', 'ABC', new \stdClass()),
- array(false, array('ROLE_SPIDERMAN'), 'foo.bar', 'BAZ', new \stdClass()),
- array(false, array('ROLE_SPIDERMAN'), 'foo.bar.baz.xyz', 'DEF', new \stdClass()),
- array(false, array('ROLE_SPIDERMAN'), 'foo.bar.baz.xyz', 'ABC', new \stdClass()),
- array(true, array(), 'foo.bar', array('ABC'), new \stdClass()),
- array(true, array(), 'foo.bar', 'ABC', new \stdClass()),
- array(true, array(), 'foo.bar', array('DEF'), new \stdClass()),
- array(true, array(), 'foo.bar', 'DEF', new \stdClass()),
- array(false, array(), 'foo.bar', array('BAZ'), new \stdClass()),
- array(false, array(), 'foo.bar', 'BAZ', new \stdClass()),
- array(false, array(), 'foo.bar.baz.xyz', 'BAZ', new \stdClass()),
- array(false, array(), 'foo.bar.baz.xyz', array('BAZ'), new \stdClass()),
- array(false, array('ROLE_AUTH_EXCEPTION'), 'foo.bar.baz.xyz', array('BAZ'), new \stdClass()),
- );
- }
- public function testIsGrantedWithException()
- {
- $this->setExpectedException('RuntimeException', 'Something is wrong');
- $this->admin->expects($this->any())
- ->method('getCode')
- ->will($this->returnValue('foo.bar'));
- $this->authorizationChecker->expects($this->any())
- ->method('isGranted')
- ->will($this->returnCallback(function (array $attributes, $object) {
- throw new \RuntimeException('Something is wrong');
- }));
- $handler = $this->getRoleSecurityHandler(array('ROLE_BATMAN'));
- $handler->isGranted($this->admin, 'BAZ');
- }
- public function testCreateObjectSecurity()
- {
- $handler = $this->getRoleSecurityHandler(array('ROLE_FOO'));
- $this->assertNull($handler->createObjectSecurity($this->getSonataAdminObject(), new \stdClass()));
- }
- public function testDeleteObjectSecurity()
- {
- $handler = $this->getRoleSecurityHandler(array('ROLE_FOO'));
- $this->assertNull($handler->deleteObjectSecurity($this->getSonataAdminObject(), new \stdClass()));
- }
- public function testBuildSecurityInformation()
- {
- $handler = $this->getRoleSecurityHandler(array('ROLE_FOO'));
- $this->assertSame(array(), $handler->buildSecurityInformation($this->getSonataAdminObject()));
- }
- /**
- * @return RoleSecurityHandler
- */
- private function getRoleSecurityHandler(array $superAdminRoles)
- {
- return new RoleSecurityHandler($this->authorizationChecker, $superAdminRoles);
- }
- /**
- * @return AdminInterface
- */
- private function getSonataAdminObject()
- {
- return $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
- }
- }
|