@@ -240,6 +240,39 @@ public function testSwitchUser()
240
240
$ this ->assertInstanceOf ('Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken ' , $ this ->tokenStorage ->getToken ());
241
241
}
242
242
243
+ public function testSwitchUserAlreadySwitched ()
244
+ {
245
+ $ originalToken = new UsernamePasswordToken ('original ' , null , 'key ' , ['ROLE_FOO ' ]);
246
+ $ alreadySwitchedToken = new SwitchUserToken ('switched_1 ' , null , 'key ' , ['ROLE_BAR ' ], $ originalToken );
247
+
248
+ $ tokenStorage = new TokenStorage ();
249
+ $ tokenStorage ->setToken ($ alreadySwitchedToken );
250
+
251
+ $ targetUser = new User ('kuba ' , 'password ' , ['ROLE_FOO ' , 'ROLE_BAR ' ]);
252
+
253
+ $ this ->request ->query ->set ('_switch_user ' , 'kuba ' );
254
+
255
+ $ this ->accessDecisionManager ->expects ($ this ->once ())
256
+ ->method ('decide ' )->with ($ originalToken , ['ROLE_ALLOWED_TO_SWITCH ' ], $ targetUser )
257
+ ->willReturn (true );
258
+
259
+ $ this ->userProvider ->expects ($ this ->exactly (2 ))
260
+ ->method ('loadUserByUsername ' )
261
+ ->withConsecutive (['kuba ' ])
262
+ ->will ($ this ->onConsecutiveCalls ($ targetUser , $ this ->throwException (new UsernameNotFoundException ())));
263
+ $ this ->userChecker ->expects ($ this ->once ())
264
+ ->method ('checkPostAuth ' )->with ($ targetUser );
265
+
266
+ $ listener = new SwitchUserListener ($ tokenStorage , $ this ->userProvider , $ this ->userChecker , 'provider123 ' , $ this ->accessDecisionManager , null , '_switch_user ' , 'ROLE_ALLOWED_TO_SWITCH ' , null , false );
267
+ $ listener ($ this ->event );
268
+
269
+ $ this ->assertSame ([], $ this ->request ->query ->all ());
270
+ $ this ->assertSame ('' , $ this ->request ->server ->get ('QUERY_STRING ' ));
271
+ $ this ->assertInstanceOf (SwitchUserToken::class, $ tokenStorage ->getToken ());
272
+ $ this ->assertSame ('kuba ' , $ tokenStorage ->getToken ()->getUsername ());
273
+ $ this ->assertSame ($ originalToken , $ tokenStorage ->getToken ()->getOriginalToken ());
274
+ }
275
+
243
276
public function testSwitchUserWorksWithFalsyUsernames ()
244
277
{
245
278
$ token = new UsernamePasswordToken ('username ' , '' , 'key ' , ['ROLE_FOO ' ]);
0 commit comments