|
16 | 16 | use Symfony\Component\HttpFoundation\Request;
|
17 | 17 | use Symfony\Component\HttpFoundation\Session\SessionInterface;
|
18 | 18 | use Symfony\Component\Security\Core\Authentication\Token\NullToken;
|
| 19 | +use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken; |
19 | 20 | use Symfony\Component\Security\Core\User\InMemoryUser;
|
20 | 21 | use Symfony\Component\Security\Http\Authenticator\AuthenticatorInterface;
|
21 | 22 | use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
|
@@ -82,6 +83,26 @@ public function testRequestWithSamePreviousUser()
|
82 | 83 | $this->listener->onSuccessfulLogin($event);
|
83 | 84 | }
|
84 | 85 |
|
| 86 | + public function testRequestWithSamePreviousUserButDifferentTokenType() |
| 87 | + { |
| 88 | + $this->configurePreviousSession(); |
| 89 | + |
| 90 | + $token = $this->createMock(NullToken::class); |
| 91 | + $token->expects($this->once()) |
| 92 | + ->method('getUserIdentifier') |
| 93 | + ->willReturn('test'); |
| 94 | + $previousToken = $this->createMock(UsernamePasswordToken::class); |
| 95 | + $previousToken->expects($this->once()) |
| 96 | + ->method('getUserIdentifier') |
| 97 | + ->willReturn('test'); |
| 98 | + |
| 99 | + $this->sessionAuthenticationStrategy->expects($this->once())->method('onAuthentication')->with($this->request, $token); |
| 100 | + |
| 101 | + $event = new LoginSuccessEvent($this->createMock(AuthenticatorInterface::class), new SelfValidatingPassport(new UserBadge('test', function () {})), $token, $this->request, null, 'main_firewall', $previousToken); |
| 102 | + |
| 103 | + $this->listener->onSuccessfulLogin($event); |
| 104 | + } |
| 105 | + |
85 | 106 | private function createEvent($firewallName)
|
86 | 107 | {
|
87 | 108 | return new LoginSuccessEvent($this->createMock(AuthenticatorInterface::class), new SelfValidatingPassport(new UserBadge('test', fn ($username) => new InMemoryUser($username, null))), $this->token, $this->request, null, $firewallName);
|
|
0 commit comments