2020-05-22 11:02:56 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
2020-05-22 13:20:31 +02:00
|
|
|
namespace Shaarli\Front\Controller\Admin;
|
2020-05-22 11:02:56 +02:00
|
|
|
|
|
|
|
use PHPUnit\Framework\TestCase;
|
2020-05-22 13:20:31 +02:00
|
|
|
use Shaarli\Security\LoginManager;
|
2020-05-22 11:02:56 +02:00
|
|
|
use Shaarli\Security\SessionManager;
|
|
|
|
use Slim\Http\Request;
|
|
|
|
use Slim\Http\Response;
|
|
|
|
|
|
|
|
class SessionFilterControllerTest extends TestCase
|
|
|
|
{
|
2020-05-22 13:20:31 +02:00
|
|
|
use FrontAdminControllerMockHelper;
|
2020-05-22 11:02:56 +02:00
|
|
|
|
|
|
|
/** @var SessionFilterController */
|
|
|
|
protected $controller;
|
|
|
|
|
|
|
|
public function setUp(): void
|
|
|
|
{
|
|
|
|
$this->createContainer();
|
|
|
|
|
|
|
|
$this->controller = new SessionFilterController($this->container);
|
|
|
|
}
|
2020-07-26 14:43:10 +02:00
|
|
|
|
2020-05-22 11:02:56 +02:00
|
|
|
/**
|
|
|
|
* Visibility - Default call for private filter while logged in without current value
|
|
|
|
*/
|
|
|
|
public function testVisibility(): void
|
|
|
|
{
|
|
|
|
$arg = ['visibility' => 'private'];
|
|
|
|
|
2020-09-22 15:17:13 +02:00
|
|
|
$this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller/?searchtag=abc';
|
2020-05-22 11:02:56 +02:00
|
|
|
|
|
|
|
$this->container->loginManager->method('isLoggedIn')->willReturn(true);
|
|
|
|
$this->container->sessionManager
|
|
|
|
->expects(static::once())
|
|
|
|
->method('setSessionParameter')
|
|
|
|
->with(SessionManager::KEY_VISIBILITY, 'private')
|
|
|
|
;
|
|
|
|
|
|
|
|
$request = $this->createMock(Request::class);
|
|
|
|
$response = new Response();
|
|
|
|
|
|
|
|
$result = $this->controller->visibility($request, $response, $arg);
|
|
|
|
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
|
|
static::assertSame(302, $result->getStatusCode());
|
|
|
|
static::assertSame(['/subfolder/controller/?searchtag=abc'], $result->getHeader('location'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Visibility - Toggle off private visibility
|
|
|
|
*/
|
|
|
|
public function testVisibilityToggleOff(): void
|
|
|
|
{
|
|
|
|
$arg = ['visibility' => 'private'];
|
|
|
|
|
2020-09-22 15:17:13 +02:00
|
|
|
$this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller/?searchtag=abc';
|
2020-05-22 11:02:56 +02:00
|
|
|
|
|
|
|
$this->container->loginManager->method('isLoggedIn')->willReturn(true);
|
|
|
|
$this->container->sessionManager
|
|
|
|
->method('getSessionParameter')
|
|
|
|
->with(SessionManager::KEY_VISIBILITY)
|
|
|
|
->willReturn('private')
|
|
|
|
;
|
|
|
|
$this->container->sessionManager
|
|
|
|
->expects(static::never())
|
|
|
|
->method('setSessionParameter')
|
|
|
|
;
|
|
|
|
$this->container->sessionManager
|
|
|
|
->expects(static::once())
|
|
|
|
->method('deleteSessionParameter')
|
|
|
|
->with(SessionManager::KEY_VISIBILITY)
|
|
|
|
;
|
|
|
|
|
|
|
|
$request = $this->createMock(Request::class);
|
|
|
|
$response = new Response();
|
|
|
|
|
|
|
|
$result = $this->controller->visibility($request, $response, $arg);
|
|
|
|
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
|
|
static::assertSame(302, $result->getStatusCode());
|
|
|
|
static::assertSame(['/subfolder/controller/?searchtag=abc'], $result->getHeader('location'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Visibility - Change private to public
|
|
|
|
*/
|
|
|
|
public function testVisibilitySwitch(): void
|
|
|
|
{
|
|
|
|
$arg = ['visibility' => 'private'];
|
|
|
|
|
|
|
|
$this->container->loginManager->method('isLoggedIn')->willReturn(true);
|
|
|
|
$this->container->sessionManager
|
|
|
|
->method('getSessionParameter')
|
|
|
|
->with(SessionManager::KEY_VISIBILITY)
|
|
|
|
->willReturn('public')
|
|
|
|
;
|
|
|
|
$this->container->sessionManager
|
|
|
|
->expects(static::once())
|
|
|
|
->method('setSessionParameter')
|
|
|
|
->with(SessionManager::KEY_VISIBILITY, 'private')
|
|
|
|
;
|
|
|
|
|
|
|
|
$request = $this->createMock(Request::class);
|
|
|
|
$response = new Response();
|
|
|
|
|
|
|
|
$result = $this->controller->visibility($request, $response, $arg);
|
|
|
|
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
|
|
static::assertSame(302, $result->getStatusCode());
|
2020-06-13 11:22:14 +02:00
|
|
|
static::assertSame(['/subfolder/'], $result->getHeader('location'));
|
2020-05-22 11:02:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Visibility - With invalid value - should remove any visibility setting
|
|
|
|
*/
|
|
|
|
public function testVisibilityInvalidValue(): void
|
|
|
|
{
|
|
|
|
$arg = ['visibility' => 'test'];
|
|
|
|
|
2020-09-22 15:17:13 +02:00
|
|
|
$this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller/?searchtag=abc';
|
2020-05-22 11:02:56 +02:00
|
|
|
|
|
|
|
$this->container->loginManager->method('isLoggedIn')->willReturn(true);
|
|
|
|
$this->container->sessionManager
|
|
|
|
->expects(static::never())
|
|
|
|
->method('setSessionParameter')
|
|
|
|
;
|
|
|
|
$this->container->sessionManager
|
|
|
|
->expects(static::once())
|
|
|
|
->method('deleteSessionParameter')
|
|
|
|
->with(SessionManager::KEY_VISIBILITY)
|
|
|
|
;
|
|
|
|
|
|
|
|
$request = $this->createMock(Request::class);
|
|
|
|
$response = new Response();
|
|
|
|
|
|
|
|
$result = $this->controller->visibility($request, $response, $arg);
|
|
|
|
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
|
|
static::assertSame(302, $result->getStatusCode());
|
|
|
|
static::assertSame(['/subfolder/controller/?searchtag=abc'], $result->getHeader('location'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Visibility - Try to change visibility while logged out
|
|
|
|
*/
|
|
|
|
public function testVisibilityLoggedOut(): void
|
|
|
|
{
|
|
|
|
$arg = ['visibility' => 'test'];
|
|
|
|
|
2020-09-22 15:17:13 +02:00
|
|
|
$this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller/?searchtag=abc';
|
2020-05-22 11:02:56 +02:00
|
|
|
|
2020-05-22 13:20:31 +02:00
|
|
|
$this->container->loginManager = $this->createMock(LoginManager::class);
|
2020-05-22 11:02:56 +02:00
|
|
|
$this->container->loginManager->method('isLoggedIn')->willReturn(false);
|
|
|
|
$this->container->sessionManager
|
|
|
|
->expects(static::never())
|
|
|
|
->method('setSessionParameter')
|
|
|
|
;
|
|
|
|
$this->container->sessionManager
|
|
|
|
->expects(static::never())
|
|
|
|
->method('deleteSessionParameter')
|
|
|
|
->with(SessionManager::KEY_VISIBILITY)
|
|
|
|
;
|
|
|
|
|
|
|
|
$request = $this->createMock(Request::class);
|
|
|
|
$response = new Response();
|
|
|
|
|
|
|
|
$result = $this->controller->visibility($request, $response, $arg);
|
|
|
|
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
|
|
static::assertSame(302, $result->getStatusCode());
|
|
|
|
static::assertSame(['/subfolder/controller/?searchtag=abc'], $result->getHeader('location'));
|
|
|
|
}
|
|
|
|
}
|