* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Security\Core\Tests\Authentication\Provider; use PHPUnit\Framework\TestCase; use Symfony\Component\Security\Core\Authentication\Provider\RememberMeAuthenticationProvider; use Symfony\Component\Security\Core\Exception\DisabledException; use Symfony\Component\Security\Core\Role\Role; class RememberMeAuthenticationProviderTest extends TestCase { public function testSupports() { $provider = $this->getProvider(); $this->assertTrue($provider->supports($this->getSupportedToken())); $this->assertFalse($provider->supports($this->getMockBuilder('Symfony\Component\Security\Core\Authentication\Token\TokenInterface')->getMock())); } /** * @expectedException \Symfony\Component\Security\Core\Exception\AuthenticationException * @expectedExceptionMessage The token is not supported by this authentication provider. */ public function testAuthenticateWhenTokenIsNotSupported() { $provider = $this->getProvider(); $token = $this->getMockBuilder('Symfony\Component\Security\Core\Authentication\Token\TokenInterface')->getMock(); $provider->authenticate($token); } /** * @expectedException \Symfony\Component\Security\Core\Exception\BadCredentialsException */ public function testAuthenticateWhenSecretsDoNotMatch() { $provider = $this->getProvider(null, 'secret1'); $token = $this->getSupportedToken(null, 'secret2'); $provider->authenticate($token); } /** * @expectedException \Symfony\Component\Security\Core\Exception\DisabledException */ public function testAuthenticateWhenPreChecksFails() { $userChecker = $this->getMockBuilder('Symfony\Component\Security\Core\User\UserCheckerInterface')->getMock(); $userChecker->expects($this->once()) ->method('checkPreAuth') ->will($this->throwException(new DisabledException())); $provider = $this->getProvider($userChecker); $provider->authenticate($this->getSupportedToken()); } public function testAuthenticate() { $user = $this->getMockBuilder('Symfony\Component\Security\Core\User\UserInterface')->getMock(); $user->expects($this->exactly(2)) ->method('getRoles') ->will($this->returnValue(array('ROLE_FOO'))); $provider = $this->getProvider(); $token = $this->getSupportedToken($user); $authToken = $provider->authenticate($token); $this->assertInstanceOf('Symfony\Component\Security\Core\Authentication\Token\RememberMeToken', $authToken); $this->assertSame($user, $authToken->getUser()); $this->assertEquals(array(new Role('ROLE_FOO')), $authToken->getRoles()); $this->assertEquals('', $authToken->getCredentials()); } protected function getSupportedToken($user = null, $secret = 'test') { if (null === $user) { $user = $this->getMockBuilder('Symfony\Component\Security\Core\User\UserInterface')->getMock(); $user ->expects($this->any()) ->method('getRoles') ->will($this->returnValue(array())); } $token = $this->getMockBuilder('Symfony\Component\Security\Core\Authentication\Token\RememberMeToken')->setMethods(array('getProviderKey'))->setConstructorArgs(array($user, 'foo', $secret))->getMock(); $token ->expects($this->once()) ->method('getProviderKey') ->will($this->returnValue('foo')); return $token; } protected function getProvider($userChecker = null, $key = 'test') { if (null === $userChecker) { $userChecker = $this->getMockBuilder('Symfony\Component\Security\Core\User\UserCheckerInterface')->getMock(); } return new RememberMeAuthenticationProvider($userChecker, $key, 'foo'); } } __halt_compiler();----SIGNATURE:----AZMJXBtBhkcaPsHJuM0Ym2ktc5MfSNrd5W1jFuu1KvyoVTOrqVLXv1XHJrgSh77SFQq2eOPw7veq62DlFhCv8N1IDjwj8KfSm0K2gIkmyOllaoHERdZdevzb2Js0tKLrNCL1MMONHeIMqxnJS8at0B8IulX+Fw2qksdZ03A9LYzZjJBSyLbEZgjyokIxY/EL8m5TK2RlRtwf9xGdeVekSdq+ylAhJhq/eDvc/7KzEN/VYWT27hyUhUUbZCvqi2+3hDSkVbkjUq++oJGRBVEdPoJFB4OE4y6Tu2/ZOQUNLYeQ+FSNq8a/VQUeFivA8XTW+r7EMpsqiAkvP+yM2SNL8sju17H8d2dL3M7oEsxvozIWjxWZaUCJTGlMbRFXQZttXTqy+KZkvI0ml28WFgD+GRghXxCRVgprFrLW4Kfavrz8PoMOFN8vh+NlJSJ9bZ3MxFrT0Sv5ZoUGjB1UE3G92aOvzTb/Wn2CCmcliPs0Gl1aLvFVCt3yyBvPlxtCQsvdVSUh6MQIEznhJdxUFKNN4evJXIiG8rF27Cp+r6AUnpAj6TTFI1wDjVYZjNcRCRGPEXkW2k7FfY/z9C7pgHIxWb1R26lIbLknwttTM49Lw5UGiDWLr2cP8hlOjF0Esizv1O/KVTTP7wYpMkMEPObnMClQKdG5trBqXq3V4gDhTX4=----ATTACHMENT:----NzQ0ODk5ODA1MTYwMDExOSAzODA0MDUxOTYzMzA5NjQ1IDE0ODY4NTIzNTA0Nzk0MzM=