Edit file File name : SamlLogoutHandlerTest.php Content :<?php /* * This file is part of the Kimai time-tracking app. * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace App\Tests\Saml\Logout; use App\Entity\User; use App\Saml\Logout\SamlLogoutHandler; use App\Saml\SamlAuthFactory; use App\Saml\Token\SamlToken; use OneLogin\Saml2\Auth; use OneLogin\Saml2\Error; use PHPUnit\Framework\TestCase; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken; /** * @covers \App\Saml\Logout\SamlLogoutHandler */ class SamlLogoutHandlerTest extends TestCase { public function testLogout() { $auth = $this->getMockBuilder(Auth::class)->disableOriginalConstructor()->getMock(); $auth->expects($this->once())->method('processSLO')->willThrowException(new Error('blub')); $auth->expects($this->once())->method('getSLOurl')->willReturn(''); $request = new Request(); $response = new Response(); $token = new SamlToken([]); $factory = $this->getMockBuilder(SamlAuthFactory::class)->disableOriginalConstructor()->getMock(); $factory->expects($this->once())->method('create')->willReturn($auth); $sut = new SamlLogoutHandler($factory); $sut->logout($request, $response, $token); } public function testLogoutWithWrongTokenWillNotCallMethods() { $auth = $this->getMockBuilder(Auth::class)->disableOriginalConstructor()->getMock(); $auth->expects($this->never())->method('processSLO'); $auth->expects($this->never())->method('getSLOurl'); $request = new Request(); $response = new Response(); $token = new UsernamePasswordToken(new User(), [], 'test'); $factory = $this->getMockBuilder(SamlAuthFactory::class)->disableOriginalConstructor()->getMock(); $factory->expects($this->never())->method('create'); $sut = new SamlLogoutHandler($factory); $sut->logout($request, $response, $token); } public function testLogoutWithLogoutUrl() { $auth = $this->getMockBuilder(Auth::class)->disableOriginalConstructor()->getMock(); $auth->expects($this->once())->method('processSLO')->willThrowException(new Error('blub')); $auth->expects($this->once())->method('getSLOurl')->willReturn('/logout'); $auth->expects($this->once())->method('logout')->willReturnCallback(function () { $args = \func_get_args(); self::assertNull($args[0]); self::assertEquals([], $args[1]); self::assertEquals('tony', $args[2]); self::assertEquals('foo-bar', $args[3]); }); $request = new Request(); $response = new Response(); $token = new SamlToken([]); $token->setUser((new User())->setUsername('tony')); $token->setAttribute('sessionIndex', 'foo-bar'); $factory = $this->getMockBuilder(SamlAuthFactory::class)->disableOriginalConstructor()->getMock(); $factory->expects($this->once())->method('create')->willReturn($auth); $sut = new SamlLogoutHandler($factory); $sut->logout($request, $response, $token); } } Save