summaryrefslogtreecommitdiffstats
path: root/Acl/Tests/Domain/UserSecurityIdentityTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'Acl/Tests/Domain/UserSecurityIdentityTest.php')
-rw-r--r--Acl/Tests/Domain/UserSecurityIdentityTest.php73
1 files changed, 73 insertions, 0 deletions
diff --git a/Acl/Tests/Domain/UserSecurityIdentityTest.php b/Acl/Tests/Domain/UserSecurityIdentityTest.php
new file mode 100644
index 0000000..09d3f0d
--- /dev/null
+++ b/Acl/Tests/Domain/UserSecurityIdentityTest.php
@@ -0,0 +1,73 @@
+<?php
+
+/*
+ * This file is part of the Symfony package.
+ *
+ * (c) Fabien Potencier <fabien@symfony.com>
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Symfony\Component\Security\Acl\Tests\Domain;
+
+use Symfony\Component\Security\Acl\Domain\RoleSecurityIdentity;
+use Symfony\Component\Security\Acl\Domain\UserSecurityIdentity;
+
+class UserSecurityIdentityTest extends \PHPUnit_Framework_TestCase
+{
+ public function testConstructor()
+ {
+ $id = new UserSecurityIdentity('foo', 'Foo');
+
+ $this->assertEquals('foo', $id->getUsername());
+ $this->assertEquals('Foo', $id->getClass());
+ }
+
+ // Test that constructor never changes the type, even for proxies
+ public function testConstructorWithProxy()
+ {
+ $id = new UserSecurityIdentity('foo', 'Acme\DemoBundle\Proxy\__CG__\Symfony\Component\Security\Acl\Tests\Domain\Foo');
+
+ $this->assertEquals('foo', $id->getUsername());
+ $this->assertEquals('Acme\DemoBundle\Proxy\__CG__\Symfony\Component\Security\Acl\Tests\Domain\Foo', $id->getClass());
+ }
+
+ /**
+ * @dataProvider getCompareData
+ */
+ public function testEquals($id1, $id2, $equal)
+ {
+ $this->assertSame($equal, $id1->equals($id2));
+ }
+
+ public function getCompareData()
+ {
+ $account = $this->getMockBuilder('Symfony\Component\Security\Core\User\UserInterface')
+ ->setMockClassName('USI_AccountImpl')
+ ->getMock();
+ $account
+ ->expects($this->any())
+ ->method('getUsername')
+ ->will($this->returnValue('foo'))
+ ;
+
+ $token = $this->getMock('Symfony\Component\Security\Core\Authentication\Token\TokenInterface');
+ $token
+ ->expects($this->any())
+ ->method('getUser')
+ ->will($this->returnValue($account))
+ ;
+
+ return array(
+ array(new UserSecurityIdentity('foo', 'Foo'), new UserSecurityIdentity('foo', 'Foo'), true),
+ array(new UserSecurityIdentity('foo', 'Bar'), new UserSecurityIdentity('foo', 'Foo'), false),
+ array(new UserSecurityIdentity('foo', 'Foo'), new UserSecurityIdentity('bar', 'Foo'), false),
+ array(new UserSecurityIdentity('foo', 'Foo'), UserSecurityIdentity::fromAccount($account), false),
+ array(new UserSecurityIdentity('bla', 'Foo'), new UserSecurityIdentity('blub', 'Foo'), false),
+ array(new UserSecurityIdentity('foo', 'Foo'), new RoleSecurityIdentity('foo'), false),
+ array(new UserSecurityIdentity('foo', 'Foo'), UserSecurityIdentity::fromToken($token), false),
+ array(new UserSecurityIdentity('foo', 'USI_AccountImpl'), UserSecurityIdentity::fromToken($token), true),
+ );
+ }
+}