818b3193ff
With the new routes, all pages are not all at the same folder level anymore (e.g. /shaare and /shaare/123), so we can't just use './' everywhere. The most consistent way to handle this is to prefix all path with the proper variable, and handle the actual path in controllers.
274 lines
9.3 KiB
PHP
274 lines
9.3 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Shaarli\Front\Controller\Admin;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
use Shaarli\Security\LoginManager;
|
|
use Shaarli\Security\SessionManager;
|
|
use Slim\Http\Request;
|
|
use Slim\Http\Response;
|
|
|
|
class SessionFilterControllerTest extends TestCase
|
|
{
|
|
use FrontAdminControllerMockHelper;
|
|
|
|
/** @var SessionFilterController */
|
|
protected $controller;
|
|
|
|
public function setUp(): void
|
|
{
|
|
$this->createContainer();
|
|
|
|
$this->controller = new SessionFilterController($this->container);
|
|
}
|
|
|
|
/**
|
|
* Link per page - Default call with valid parameter and a referer.
|
|
*/
|
|
public function testLinksPerPage(): void
|
|
{
|
|
$this->container->environment = ['HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc'];
|
|
|
|
$request = $this->createMock(Request::class);
|
|
$request->method('getParam')->with('nb')->willReturn('8');
|
|
$response = new Response();
|
|
|
|
$this->container->sessionManager
|
|
->expects(static::once())
|
|
->method('setSessionParameter')
|
|
->with(SessionManager::KEY_LINKS_PER_PAGE, 8)
|
|
;
|
|
|
|
$result = $this->controller->linksPerPage($request, $response);
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
static::assertSame(302, $result->getStatusCode());
|
|
static::assertSame(['/subfolder/controller/?searchtag=abc'], $result->getHeader('location'));
|
|
}
|
|
|
|
/**
|
|
* Link per page - Invalid value, should use default value (20)
|
|
*/
|
|
public function testLinksPerPageNotValid(): void
|
|
{
|
|
$request = $this->createMock(Request::class);
|
|
$request->method('getParam')->with('nb')->willReturn('test');
|
|
$response = new Response();
|
|
|
|
$this->container->sessionManager
|
|
->expects(static::once())
|
|
->method('setSessionParameter')
|
|
->with(SessionManager::KEY_LINKS_PER_PAGE, 20)
|
|
;
|
|
|
|
$result = $this->controller->linksPerPage($request, $response);
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
static::assertSame(302, $result->getStatusCode());
|
|
static::assertSame(['/subfolder/'], $result->getHeader('location'));
|
|
}
|
|
|
|
/**
|
|
* Visibility - Default call for private filter while logged in without current value
|
|
*/
|
|
public function testVisibility(): void
|
|
{
|
|
$arg = ['visibility' => 'private'];
|
|
|
|
$this->container->environment = ['HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc'];
|
|
|
|
$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'];
|
|
|
|
$this->container->environment = ['HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc'];
|
|
|
|
$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());
|
|
static::assertSame(['/subfolder/'], $result->getHeader('location'));
|
|
}
|
|
|
|
/**
|
|
* Visibility - With invalid value - should remove any visibility setting
|
|
*/
|
|
public function testVisibilityInvalidValue(): void
|
|
{
|
|
$arg = ['visibility' => 'test'];
|
|
|
|
$this->container->environment = ['HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc'];
|
|
|
|
$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'];
|
|
|
|
$this->container->environment = ['HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc'];
|
|
|
|
$this->container->loginManager = $this->createMock(LoginManager::class);
|
|
$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'));
|
|
}
|
|
|
|
/**
|
|
* Untagged only - valid call
|
|
*/
|
|
public function testUntaggedOnly(): void
|
|
{
|
|
$this->container->environment = ['HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc'];
|
|
|
|
$request = $this->createMock(Request::class);
|
|
$response = new Response();
|
|
|
|
$this->container->sessionManager
|
|
->expects(static::once())
|
|
->method('setSessionParameter')
|
|
->with(SessionManager::KEY_UNTAGGED_ONLY, true)
|
|
;
|
|
|
|
$result = $this->controller->untaggedOnly($request, $response);
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
static::assertSame(302, $result->getStatusCode());
|
|
static::assertSame(['/subfolder/controller/?searchtag=abc'], $result->getHeader('location'));
|
|
}
|
|
|
|
/**
|
|
* Untagged only - toggle off
|
|
*/
|
|
public function testUntaggedOnlyToggleOff(): void
|
|
{
|
|
$this->container->environment = ['HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc'];
|
|
|
|
$request = $this->createMock(Request::class);
|
|
$response = new Response();
|
|
|
|
$this->container->sessionManager
|
|
->method('getSessionParameter')
|
|
->with(SessionManager::KEY_UNTAGGED_ONLY)
|
|
->willReturn(true)
|
|
;
|
|
$this->container->sessionManager
|
|
->expects(static::once())
|
|
->method('setSessionParameter')
|
|
->with(SessionManager::KEY_UNTAGGED_ONLY, false)
|
|
;
|
|
|
|
$result = $this->controller->untaggedOnly($request, $response);
|
|
|
|
static::assertInstanceOf(Response::class, $result);
|
|
static::assertSame(302, $result->getStatusCode());
|
|
static::assertSame(['/subfolder/controller/?searchtag=abc'], $result->getHeader('location'));
|
|
}
|
|
}
|