From de0a2a9b90dce1888d8c2b8ff9a675dd248034b6 Mon Sep 17 00:00:00 2001 From: Beutlin Date: Sat, 8 Apr 2023 04:52:09 +0200 Subject: [PATCH 01/12] Some Improvements for better PHPUnit testing --- application/Languages.php | 15 +++++++++------ application/helper/FileUtils.php | 2 ++ phpunit.xml | 8 ++------ tests/bootstrap.php | 3 ++- .../controller/visitor/DailyControllerTest.php | 1 + tests/languages/fr/LanguagesFrTest.php | 10 ++++++---- tests/utils/ReferenceLinkDB.php | 6 ++---- 7 files changed, 24 insertions(+), 21 deletions(-) diff --git a/application/Languages.php b/application/Languages.php index 3ea434e2a..76f245d3d 100644 --- a/application/Languages.php +++ b/application/Languages.php @@ -96,17 +96,19 @@ protected function initGettextTranslator() { $this->translator = new GettextTranslator(); $this->translator->setLanguage($this->language); - $this->translator->loadDomain(self::DEFAULT_DOMAIN, 'inc/languages'); + $this->translator->loadDomain(self::DEFAULT_DOMAIN, __DIR__ . '/../inc/languages'); // Default extension translation from the current theme - $themeTransFolder = rtrim($this->conf->get('raintpl_tpl'), '/') . '/' . $this->conf->get('theme') . '/language'; + $themeTransFolder = __DIR__ . '/../' . rtrim($this->conf->get('raintpl_tpl'), '/') . '/' + . $this->conf->get('theme') . '/language'; if (is_dir($themeTransFolder)) { $this->translator->loadDomain($this->conf->get('theme'), $themeTransFolder, false); } foreach ($this->conf->get('translation.extensions', []) as $domain => $translationPath) { + $path = __DIR__ . '/../' . $translationPath; if ($domain !== self::DEFAULT_DOMAIN) { - $this->translator->loadDomain($domain, $translationPath, false); + $this->translator->loadDomain($domain, $path, false); } } } @@ -123,7 +125,7 @@ protected function initPhpTranslator() // Core translations try { $translations = $translations->addFromPoFile( - 'inc/languages/' . $this->language . '/LC_MESSAGES/shaarli.po' + __DIR__ . '/../inc/languages/' . $this->language . '/LC_MESSAGES/shaarli.po' ); $translations->setDomain('shaarli'); $this->translator->loadTranslations($translations); @@ -132,7 +134,8 @@ protected function initPhpTranslator() // Default extension translation from the current theme $theme = $this->conf->get('theme'); - $themeTransFolder = rtrim($this->conf->get('raintpl_tpl'), '/') . '/' . $theme . '/language'; + $themeTransFolder = __DIR__ . '/../' . rtrim($this->conf->get('raintpl_tpl'), '/') . '/' + . $theme . '/language'; if (is_dir($themeTransFolder)) { try { $translations = Translations::fromPoFile( @@ -152,7 +155,7 @@ protected function initPhpTranslator() try { $extension = Translations::fromPoFile( - $translationPath . $this->language . '/LC_MESSAGES/' . $domain . '.po' + __DIR__ . '/../' . $translationPath . $this->language . '/LC_MESSAGES/' . $domain . '.po' ); $extension->setDomain($domain); $this->translator->loadTranslations($extension); diff --git a/application/helper/FileUtils.php b/application/helper/FileUtils.php index e8a2168cc..697dc5e99 100644 --- a/application/helper/FileUtils.php +++ b/application/helper/FileUtils.php @@ -36,6 +36,8 @@ class FileUtils */ public static function writeFlatDB($file, $content) { + $folder = basename($file); + file_exists($folder) || $folder !== 'sandbox' || mkdir($folder, 0755, true); if (is_file($file) && !is_writeable($file)) { // The datastore exists but is not writeable throw new IOException($file); diff --git a/phpunit.xml b/phpunit.xml index 8b66e6c5b..383595a20 100644 --- a/phpunit.xml +++ b/phpunit.xml @@ -2,6 +2,7 @@ @@ -18,10 +19,5 @@ tests/languages/fr - - - - application - - + diff --git a/tests/bootstrap.php b/tests/bootstrap.php index e04032968..5c33f7bba 100644 --- a/tests/bootstrap.php +++ b/tests/bootstrap.php @@ -1,6 +1,6 @@ createContainer(); $this->controller = new DailyController($this->container); diff --git a/tests/languages/fr/LanguagesFrTest.php b/tests/languages/fr/LanguagesFrTest.php index 7e24251fa..5fee6f2d3 100644 --- a/tests/languages/fr/LanguagesFrTest.php +++ b/tests/languages/fr/LanguagesFrTest.php @@ -37,11 +37,13 @@ protected function setUp(): void /** * Reset the locale since gettext seems to mess with it, making it too long */ - public static function tearDownAfterClass(): void + protected function tearDown(): void { - if (! empty(getenv('UT_LOCALE'))) { - setlocale(LC_ALL, getenv('UT_LOCALE')); - } + // Reset config-language + $currentLang = getenv('UT_LOCALE') ?? 'en'; + $fallbackLang = 'en'; + $this->conf->set('translation.language', $currentLang); + new Languages($fallbackLang, $this->conf); } /** diff --git a/tests/utils/ReferenceLinkDB.php b/tests/utils/ReferenceLinkDB.php index e85dfdea1..a6d221e27 100644 --- a/tests/utils/ReferenceLinkDB.php +++ b/tests/utils/ReferenceLinkDB.php @@ -5,6 +5,7 @@ use DateTime; use Shaarli\Bookmark\Bookmark; use Shaarli\Bookmark\BookmarkArray; +use Shaarli\Helper\FileUtils; /** * Populates a reference datastore to test Bookmark @@ -199,10 +200,7 @@ protected function addLink( public function write($filename) { $this->reorder(); - file_put_contents( - $filename, - 'bookmarks))) . ' */ ?>' - ); + FileUtils::writeFlatDB($filename, $this->bookmarks); } /** From 732b6f6a7c1a691ce02ee30f5be072b22facfa01 Mon Sep 17 00:00:00 2001 From: Beutlin Date: Tue, 11 Apr 2023 19:31:12 +0200 Subject: [PATCH 02/12] Migrate to Slim 4 framework --- application/api/ApiMiddleware.php | 22 +- application/api/controllers/ApiController.php | 18 +- .../api/controllers/HistoryController.php | 13 +- application/api/controllers/Info.php | 7 +- application/api/controllers/Links.php | 58 +- application/api/controllers/Tags.php | 22 +- application/api/exceptions/ApiException.php | 5 +- application/container/ContainerBuilder.php | 129 ++- application/container/ShaarliContainer.php | 54 -- application/feed/FeedBuilder.php | 16 +- application/front/ShaarliAdminMiddleware.php | 15 +- application/front/ShaarliErrorHandler.php | 160 ++++ application/front/ShaarliMiddleware.php | 75 +- .../controller/admin/ConfigureController.php | 106 ++- .../controller/admin/ExportController.php | 22 +- .../controller/admin/ImportController.php | 11 +- .../controller/admin/LogoutController.php | 13 +- .../controller/admin/ManageTagController.php | 31 +- .../controller/admin/MetadataController.php | 10 +- .../controller/admin/PasswordController.php | 47 +- .../controller/admin/PluginsController.php | 23 +- .../controller/admin/ServerController.php | 31 +- .../admin/SessionFilterController.php | 13 +- .../controller/admin/ShaareAddController.php | 17 +- .../admin/ShaareManageController.php | 64 +- .../admin/ShaarePublishController.php | 136 +-- .../admin/ShaarliAdminController.php | 9 +- .../controller/admin/ThumbnailsController.php | 21 +- .../controller/admin/TokenController.php | 6 +- .../controller/admin/ToolsController.php | 15 +- .../visitor/BookmarkListController.php | 66 +- .../controller/visitor/DailyController.php | 41 +- .../controller/visitor/ErrorController.php | 14 +- .../visitor/ErrorNotFoundController.php | 14 +- .../controller/visitor/FeedController.php | 25 +- .../controller/visitor/InstallController.php | 77 +- .../controller/visitor/LoginController.php | 82 +- .../visitor/OpenSearchController.php | 8 +- .../visitor/PictureWallController.php | 19 +- .../visitor/PublicSessionFilterController.php | 14 +- .../visitor/ShaarliVisitorController.php | 95 +- .../controller/visitor/TagCloudController.php | 20 +- .../controller/visitor/TagController.php | 20 +- application/helper/DailyPageHelper.php | 8 +- application/legacy/LegacyController.php | 17 +- application/render/TemplatePage.php | 2 + composer.json | 4 +- composer.lock | 830 ++++++++++++++++-- doc/md/dev/Plugin-system.md | 4 +- index.php | 185 ++-- plugins/demo_plugin/DemoPluginController.php | 4 +- plugins/readitlater/ReadItLaterController.php | 14 +- tests/api/ApiMiddlewareTest.php | 170 ++-- tests/api/controllers/history/HistoryTest.php | 64 +- tests/api/controllers/info/InfoTest.php | 33 +- .../api/controllers/links/DeleteLinkTest.php | 35 +- tests/api/controllers/links/GetLinkIdTest.php | 33 +- tests/api/controllers/links/GetLinksTest.php | 291 +++--- tests/api/controllers/links/PostLinkTest.php | 117 ++- tests/api/controllers/links/PutLinkTest.php | 103 ++- tests/api/controllers/tags/DeleteTagTest.php | 48 +- tests/api/controllers/tags/GetTagNameTest.php | 48 +- tests/api/controllers/tags/GetTagsTest.php | 83 +- tests/api/controllers/tags/PutTagTest.php | 57 +- tests/bootstrap.php | 44 +- tests/container/ContainerBuilderTest.php | 42 +- tests/container/ShaarliTestContainer.php | 41 - tests/feed/FeedBuilderTest.php | 18 +- .../BookmarkDefaultFormatterTest.php | 2 +- .../BookmarkMarkdownExtraFormatterTest.php | 2 +- .../BookmarkMarkdownFormatterTest.php | 2 +- tests/formatter/BookmarkRawFormatterTest.php | 2 +- tests/formatter/FormatterFactoryTest.php | 2 +- tests/front/ShaarliAdminMiddlewareTest.php | 70 +- tests/front/ShaarliMiddlewareTest.php | 159 ++-- .../admin/ConfigureControllerTest.php | 82 +- .../controller/admin/ExportControllerTest.php | 55 +- .../admin/FrontAdminControllerMockHelper.php | 15 +- .../controller/admin/ImportControllerTest.php | 50 +- .../controller/admin/LogoutControllerTest.php | 19 +- .../admin/ManageTagControllerTest.php | 167 ++-- .../admin/PasswordControllerTest.php | 108 +-- .../admin/PluginsControllerTest.php | 69 +- .../controller/admin/ServerControllerTest.php | 43 +- .../admin/SessionFilterControllerTest.php | 81 +- .../admin/ShaareAddControllerTest.php | 22 +- .../AddOrDeleteTagTest.php | 195 ++-- .../ChangeVisibilityBookmarkTest.php | 217 +++-- .../DeleteBookmarkTest.php | 196 ++--- .../PinBookmarkTest.php | 37 +- .../SharePrivateTest.php | 30 +- .../DisplayCreateBatchFormTest.php | 19 +- .../DisplayCreateFormTest.php | 130 +-- .../DisplayEditFormTest.php | 36 +- .../SaveBookmarkTest.php | 144 ++- .../admin/ShaarliAdminControllerTest.php | 43 +- .../admin/ThumbnailsControllerTest.php | 36 +- .../controller/admin/TokenControllerTest.php | 10 +- .../controller/admin/ToolsControllerTest.php | 22 +- .../visitor/BookmarkListControllerTest.php | 245 ++++-- .../visitor/DailyControllerTest.php | 170 ++-- .../visitor/ErrorControllerTest.php | 24 +- .../visitor/ErrorNotFoundControllerTest.php | 31 +- .../controller/visitor/FeedControllerTest.php | 56 +- .../visitor/FrontControllerMockHelper.php | 50 +- .../visitor/InstallControllerTest.php | 87 +- .../visitor/LoginControllerTest.php | 261 +++--- .../visitor/OpenSearchControllerTest.php | 12 +- .../visitor/PictureWallControllerTest.php | 23 +- .../PublicSessionFilterControllerTest.php | 71 +- .../visitor/ShaarliVisitorControllerTest.php | 113 ++- .../visitor/TagCloudControllerTest.php | 88 +- .../controller/visitor/TagControllerTest.php | 115 ++- tests/helper/DailyPageHelperTest.php | 13 +- tests/languages/fr/LanguagesFrTest.php | 9 +- tests/legacy/LegacyControllerTest.php | 89 +- tests/legacy/LegacyUpdaterTest.php | 2 +- tests/netscape/BookmarkImportTest.php | 7 +- tests/plugins/PluginAddlinkTest.php | 2 +- tests/plugins/PluginReadItLaterTest.php | 2 +- tests/updater/UpdaterTest.php | 2 +- tests/utils/FakeRequest.php | 42 + tests/utils/FakeRequestHandler.php | 33 + tests/utils/FakeRouteCollector.php | 35 + tests/utils/ReferenceLinkDB.php | 3 + 125 files changed, 4320 insertions(+), 3289 deletions(-) delete mode 100644 application/container/ShaarliContainer.php create mode 100644 application/front/ShaarliErrorHandler.php delete mode 100644 tests/container/ShaarliTestContainer.php create mode 100644 tests/utils/FakeRequest.php create mode 100644 tests/utils/FakeRequestHandler.php create mode 100644 tests/utils/FakeRouteCollector.php diff --git a/application/api/ApiMiddleware.php b/application/api/ApiMiddleware.php index cc7af18e9..7208fcb9d 100644 --- a/application/api/ApiMiddleware.php +++ b/application/api/ApiMiddleware.php @@ -3,13 +3,14 @@ namespace Shaarli\Api; use malkusch\lock\mutex\FlockMutex; +use Psr\Container\ContainerInterface as Container; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; +use Psr\Http\Server\RequestHandlerInterface as RequestHandler; use Shaarli\Api\Exceptions\ApiAuthorizationException; use Shaarli\Api\Exceptions\ApiException; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Config\ConfigManager; -use Slim\Container; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class ApiMiddleware @@ -43,7 +44,7 @@ class ApiMiddleware * * @param Container $container instance. */ - public function __construct($container) + public function __construct(Container $container) { $this->container = $container; $this->conf = $this->container->get('conf'); @@ -62,13 +63,12 @@ public function __construct($container) * * @return Response response. */ - public function __invoke($request, $response, $next) + public function __invoke(Request $request, RequestHandler $handler): Response { try { $this->checkRequest($request); - $response = $next($request, $response); + $response = $handler->handle($request); } catch (ApiException $e) { - $e->setResponse($response); $e->setDebug($this->conf->get('dev.debug', false)); $response = $e->getApiResponse(); } @@ -111,7 +111,7 @@ protected function checkToken($request) { if ( !$request->hasHeader('Authorization') - && !isset($this->container->environment['REDIRECT_HTTP_AUTHORIZATION']) + && !isset($request->getServerParams()['REDIRECT_HTTP_AUTHORIZATION']) ) { throw new ApiAuthorizationException('JWT token not provided'); } @@ -120,8 +120,8 @@ protected function checkToken($request) throw new ApiAuthorizationException('Token secret must be set in Shaarli\'s administration'); } - if (isset($this->container->environment['REDIRECT_HTTP_AUTHORIZATION'])) { - $authorization = $this->container->environment['REDIRECT_HTTP_AUTHORIZATION']; + if (isset($request->getServerParams()['REDIRECT_HTTP_AUTHORIZATION'])) { + $authorization = $request->getServerParams()['REDIRECT_HTTP_AUTHORIZATION']; } else { $authorization = $request->getHeaderLine('Authorization'); } @@ -150,6 +150,6 @@ protected function setLinkDb($conf) new FlockMutex(fopen(SHAARLI_MUTEX_FILE, 'r'), 2), true ); - $this->container['db'] = $linkDb; + $this->container->set('db', $linkDb); } } diff --git a/application/api/controllers/ApiController.php b/application/api/controllers/ApiController.php index 88a845ebc..86299c241 100644 --- a/application/api/controllers/ApiController.php +++ b/application/api/controllers/ApiController.php @@ -2,10 +2,11 @@ namespace Shaarli\Api\Controllers; +use DI\Container; +use Psr\Http\Message\ResponseInterface as Response; use Shaarli\Bookmark\BookmarkServiceInterface; use Shaarli\Config\ConfigManager; use Shaarli\History; -use Slim\Container; /** * Abstract Class ApiController @@ -70,4 +71,19 @@ public function getCi() { return $this->ci; } + + /** + * Simple helper, which writes data as JSON to the body + * + * @param Response $response + * @param mixed $data + * @param mixed $jsonStyle + * @return Response + */ + protected function respondWithJson(Response $response, mixed $data, mixed $jsonStyle): Response + { + $jsonStyle = $jsonStyle ?? 0; + $response->getBody()->write(json_encode($data, $jsonStyle)); + return $response->withHeader('Content-Type', 'application/json'); + } } diff --git a/application/api/controllers/HistoryController.php b/application/api/controllers/HistoryController.php index e16036f6d..d2e43470a 100644 --- a/application/api/controllers/HistoryController.php +++ b/application/api/controllers/HistoryController.php @@ -2,9 +2,10 @@ namespace Shaarli\Api\Controllers; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Api\Exceptions\ApiBadParametersException; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\ResponseUtils; /** * Class History @@ -30,8 +31,8 @@ public function getHistory($request, $response) $history = $this->history->getHistory(); // Return history operations from the {offset}th, starting from {since}. - $since = \DateTime::createFromFormat(\DateTime::ATOM, $request->getParam('since', '')); - $offset = $request->getParam('offset'); + $since = \DateTime::createFromFormat(\DateTime::ATOM, $request->getQueryParams()['since'] ?? null); + $offset = $request->getQueryParams()['offset'] ?? null; if (empty($offset)) { $offset = 0; } elseif (ctype_digit($offset)) { @@ -41,7 +42,7 @@ public function getHistory($request, $response) } // limit parameter is either a number of bookmarks or 'all' for everything. - $limit = $request->getParam('limit'); + $limit = $request->getQueryParams()['limit'] ?? null; if (empty($limit)) { $limit = count($history); } elseif (ctype_digit($limit)) { @@ -63,6 +64,6 @@ public function getHistory($request, $response) } $out = array_values($out); - return $response->withJson($out, 200, $this->jsonStyle); + return $this->respondWithJson($response, $out, $this->jsonStyle)->withStatus(200); } } diff --git a/application/api/controllers/Info.php b/application/api/controllers/Info.php index ae7db93e5..93ab54eab 100644 --- a/application/api/controllers/Info.php +++ b/application/api/controllers/Info.php @@ -2,9 +2,10 @@ namespace Shaarli\Api\Controllers; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\BookmarkFilter; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\ResponseUtils; /** * Class Info @@ -38,6 +39,6 @@ public function getInfo($request, $response) ], ]; - return $response->withJson($info, 200, $this->jsonStyle); + return $this->respondWithJson($response, $info, $this->jsonStyle)->withStatus(200); } } diff --git a/application/api/controllers/Links.php b/application/api/controllers/Links.php index fe4bdc9f5..578cec3a3 100644 --- a/application/api/controllers/Links.php +++ b/application/api/controllers/Links.php @@ -2,11 +2,13 @@ namespace Shaarli\Api\Controllers; +use DI\Container; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Api\ApiUtils; use Shaarli\Api\Exceptions\ApiBadParametersException; use Shaarli\Api\Exceptions\ApiLinkNotFoundException; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Routing\RouteContext; /** * Class Links @@ -23,6 +25,11 @@ class Links extends ApiController */ public static $DEFAULT_LIMIT = 20; + public function __construct(Container $ci) + { + parent::__construct($ci); + } + /** * Retrieve a list of bookmarks, allowing different filters. * @@ -35,17 +42,17 @@ class Links extends ApiController */ public function getLinks($request, $response) { - $private = $request->getParam('visibility'); + $private = $request->getQueryParams()['visibility'] ?? null; // Return bookmarks from the {offset}th link, starting from 0. - $offset = $request->getParam('offset'); + $offset = $request->getQueryParams()['offset'] ?? null; if (! empty($offset) && ! ctype_digit($offset)) { throw new ApiBadParametersException('Invalid offset'); } $offset = ! empty($offset) ? intval($offset) : 0; // limit parameter is either a number of bookmarks or 'all' for everything. - $limit = $request->getParam('limit'); + $limit = $request->getQueryParams()['limit'] ?? null; if (empty($limit)) { $limit = self::$DEFAULT_LIMIT; } elseif (ctype_digit($limit)) { @@ -58,8 +65,8 @@ public function getLinks($request, $response) $searchResult = $this->bookmarkService->search( [ - 'searchtags' => $request->getParam('searchtags', ''), - 'searchterm' => $request->getParam('searchterm', ''), + 'searchtags' => $request->getQueryParams()['searchtags'] ?? '', + 'searchterm' => $request->getQueryParams()['searchterm'] ?? '', ], $private, false, @@ -73,14 +80,14 @@ public function getLinks($request, $response) ); // 'environment' is set by Slim and encapsulate $_SERVER. - $indexUrl = index_url($this->ci['environment']); + $indexUrl = index_url($request->getServerParams()); $out = []; foreach ($searchResult->getBookmarks() as $bookmark) { $out[] = ApiUtils::formatLink($bookmark, $indexUrl); } - return $response->withJson($out, 200, $this->jsonStyle); + return $this->respondWithJson($response, $out, $this->jsonStyle)->withStatus(200); } /** @@ -100,10 +107,10 @@ public function getLink($request, $response, $args) if ($id === null || ! $this->bookmarkService->exists($id)) { throw new ApiLinkNotFoundException(); } - $index = index_url($this->ci['environment']); + $index = index_url($request->getServerParams()); $out = ApiUtils::formatLink($this->bookmarkService->get($id), $index); - return $response->withJson($out, 200, $this->jsonStyle); + return $this->respondWithJson($response, $out, $this->jsonStyle)->withStatus(200); } /** @@ -127,18 +134,20 @@ public function postLink($request, $response) ! empty($bookmark->getUrl()) && ! empty($dup = $this->bookmarkService->findByUrl($bookmark->getUrl())) ) { - return $response->withJson( - ApiUtils::formatLink($dup, index_url($this->ci['environment'])), - 409, + return $this->respondWithJson( + $response, + ApiUtils::formatLink($dup, index_url($request->getServerParams())), $this->jsonStyle - ); + )->withStatus(409); } $this->bookmarkService->add($bookmark); - $out = ApiUtils::formatLink($bookmark, index_url($this->ci['environment'])); - $redirect = $this->ci->router->pathFor('getLink', ['id' => $bookmark->getId()]); - return $response->withAddedHeader('Location', $redirect) - ->withJson($out, 201, $this->jsonStyle); + $out = ApiUtils::formatLink($bookmark, index_url($request->getServerParams())); + $routeParser = $request->getAttribute(RouteContext::ROUTE_PARSER); + $redirect = $routeParser->relativeUrlFor('getLink', ['id' => $bookmark->getId()]); + + return $this->respondWithJson($response, $out, $this->jsonStyle) + ->withAddedHeader('Location', $redirect)->withStatus(201); } /** @@ -159,7 +168,7 @@ public function putLink($request, $response, $args) throw new ApiLinkNotFoundException(); } - $index = index_url($this->ci['environment']); + $index = index_url($request->getServerParams()); $data = $request->getParsedBody(); $requestBookmark = ApiUtils::buildBookmarkFromRequest( @@ -173,11 +182,11 @@ public function putLink($request, $response, $args) && ! empty($dup = $this->bookmarkService->findByUrl($requestBookmark->getUrl())) && $dup->getId() != $id ) { - return $response->withJson( + return $this->respondWithJson( + $response, ApiUtils::formatLink($dup, $index), - 409, $this->jsonStyle - ); + )->withStatus(409); } $responseBookmark = $this->bookmarkService->get($id); @@ -185,7 +194,8 @@ public function putLink($request, $response, $args) $this->bookmarkService->set($responseBookmark); $out = ApiUtils::formatLink($responseBookmark, $index); - return $response->withJson($out, 200, $this->jsonStyle); + return $this->respondWithJson($response, $out, $this->jsonStyle) + ->withStatus(200); } /** diff --git a/application/api/controllers/Tags.php b/application/api/controllers/Tags.php index 5a23f6db7..66c70428b 100644 --- a/application/api/controllers/Tags.php +++ b/application/api/controllers/Tags.php @@ -2,12 +2,12 @@ namespace Shaarli\Api\Controllers; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Api\ApiUtils; use Shaarli\Api\Exceptions\ApiBadParametersException; use Shaarli\Api\Exceptions\ApiTagNotFoundException; use Shaarli\Bookmark\BookmarkFilter; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class Tags @@ -35,21 +35,22 @@ class Tags extends ApiController */ public function getTags($request, $response) { - $visibility = $request->getParam('visibility'); + $visibility = $request->getQueryParams()['visibility'] ?? ''; $tags = $this->bookmarkService->bookmarksCountPerTag([], $visibility); // Return tags from the {offset}th tag, starting from 0. - $offset = $request->getParam('offset'); + $offset = $request->getQueryParams()['offset'] ?? ''; if (! empty($offset) && ! ctype_digit($offset)) { throw new ApiBadParametersException('Invalid offset'); } $offset = ! empty($offset) ? intval($offset) : 0; if ($offset > count($tags)) { - return $response->withJson([], 200, $this->jsonStyle); + return $this->respondWithJson($response, [], $this->jsonStyle) + ->withStatus(200); } // limit parameter is either a number of bookmarks or 'all' for everything. - $limit = $request->getParam('limit'); + $limit = $request->getQueryParams()['limit'] ?? null; if (empty($limit)) { $limit = self::$DEFAULT_LIMIT; } @@ -72,7 +73,8 @@ public function getTags($request, $response) } } - return $response->withJson($out, 200, $this->jsonStyle); + return $this->respondWithJson($response, $out, $this->jsonStyle) + ->withStatus(200); } /** @@ -94,7 +96,8 @@ public function getTag($request, $response, $args) } $out = ApiUtils::formatTag($args['tagName'], $tags[$args['tagName']]); - return $response->withJson($out, 200, $this->jsonStyle); + return $this->respondWithJson($response, $out, $this->jsonStyle) + ->withStatus(200); } /** @@ -136,7 +139,8 @@ public function putTag($request, $response, $args) $tags = $this->bookmarkService->bookmarksCountPerTag(); $out = ApiUtils::formatTag($data['name'], $tags[$data['name']]); - return $response->withJson($out, 200, $this->jsonStyle); + return $this->respondWithJson($response, $out, $this->jsonStyle) + ->withStatus(200); } /** diff --git a/application/api/exceptions/ApiException.php b/application/api/exceptions/ApiException.php index 49cfbee4d..ce3d750ae 100644 --- a/application/api/exceptions/ApiException.php +++ b/application/api/exceptions/ApiException.php @@ -3,6 +3,7 @@ namespace Shaarli\Api\Exceptions; use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; /** * Abstract class ApiException @@ -57,7 +58,9 @@ protected function getApiResponseBody() protected function buildApiResponse($code) { $style = $this->debug ? JSON_PRETTY_PRINT : null; - return $this->response->withJson($this->getApiResponseBody(), $code, $style); + $response = $this->response ?? new SlimResponse(); + $response->getBody()->write(json_encode($this->getApiResponseBody(), $style)); + return $response->withStatus($code); } /** diff --git a/application/container/ContainerBuilder.php b/application/container/ContainerBuilder.php index f66d75bd0..4e23e3b00 100644 --- a/application/container/ContainerBuilder.php +++ b/application/container/ContainerBuilder.php @@ -4,6 +4,7 @@ namespace Shaarli\Container; +use DI\Container; use malkusch\lock\mutex\FlockMutex; use Psr\Log\LoggerInterface; use Shaarli\Bookmark\BookmarkFileService; @@ -75,101 +76,95 @@ public function __construct( $this->logger = $logger; } - public function build(): ShaarliContainer + public function build(): Container { - $container = new ShaarliContainer(); + $container = new Container(); - $container['conf'] = $this->conf; - $container['sessionManager'] = $this->session; - $container['cookieManager'] = $this->cookieManager; - $container['loginManager'] = $this->login; - $container['pluginManager'] = $this->pluginManager; - $container['logger'] = $this->logger; - $container['basePath'] = $this->basePath; + $container->set('conf', $this->conf); + $container->set('sessionManager', $this->session); + $container->set('cookieManager', $this->cookieManager); + $container->set('loginManager', $this->login); + $container->set('pluginManager', $this->pluginManager); + $container->set('logger', $this->logger); + $container->set('basePath', $this->basePath); - $container['history'] = function (ShaarliContainer $container): History { - return new History($container->conf->get('resource.history')); - }; + $container->set('history', function (Container $container): History { + return new History($container->get('conf')->get('resource.history')); + }); - $container['bookmarkService'] = function (ShaarliContainer $container): BookmarkServiceInterface { + $container->set('bookmarkService', function (Container $container): BookmarkServiceInterface { return new BookmarkFileService( - $container->conf, - $container->pluginManager, - $container->history, + $container->get('conf'), + $container->get('pluginManager'), + $container->get('history'), new FlockMutex(fopen(SHAARLI_MUTEX_FILE, 'r'), 2), - $container->loginManager->isLoggedIn() + $container->get('loginManager')->isLoggedIn() ); - }; + }); - $container['metadataRetriever'] = function (ShaarliContainer $container): MetadataRetriever { - return new MetadataRetriever($container->conf, $container->httpAccess); - }; + $container->set('metadataRetriever', function (Container $container): MetadataRetriever { + return new MetadataRetriever($container->get('conf'), $container->get('httpAccess')); + }); - $container['pageBuilder'] = function (ShaarliContainer $container): PageBuilder { + $container->set('pageBuilder', function (Container $container): PageBuilder { + $conf = $container->get('conf'); return new PageBuilder( - $container->conf, - $container->sessionManager->getSession(), - $container->logger, - $container->bookmarkService, - $container->sessionManager->generateToken(), - $container->loginManager->isLoggedIn() + $conf, + $container->get('sessionManager')->getSession(), + $container->get('logger'), + $container->get('bookmarkService'), + $container->get('sessionManager')->generateToken(), + $container->get('loginManager')->isLoggedIn() ); - }; + }); - $container['formatterFactory'] = function (ShaarliContainer $container): FormatterFactory { + $container->set('formatterFactory', function (Container $container): FormatterFactory { return new FormatterFactory( - $container->conf, - $container->loginManager->isLoggedIn() + $container->get('conf'), + $container->get('loginManager')->isLoggedIn() ); - }; + }); - $container['pageCacheManager'] = function (ShaarliContainer $container): PageCacheManager { + $container->set('pageCacheManager', function (Container $container): PageCacheManager { return new PageCacheManager( - $container->conf->get('resource.page_cache'), - $container->loginManager->isLoggedIn() + $container->get('conf')->get('resource.page_cache'), + $container->get('loginManager')->isLoggedIn() ); - }; + }); - $container['feedBuilder'] = function (ShaarliContainer $container): FeedBuilder { + $container->set('feedBuilder', function (Container $container): FeedBuilder { return new FeedBuilder( - $container->bookmarkService, - $container->formatterFactory->getFormatter(), - $container->environment, - $container->loginManager->isLoggedIn() + $container->get('bookmarkService'), + $container->get('formatterFactory')->getFormatter(), + $container->get('loginManager')->isLoggedIn() ); - }; + }); - $container['thumbnailer'] = function (ShaarliContainer $container): Thumbnailer { - return new Thumbnailer($container->conf); - }; + $container->set('thumbnailer', function (Container $container): Thumbnailer { + return new Thumbnailer($container->get('conf')); + }); - $container['httpAccess'] = function (): HttpAccess { + $container->set('httpAccess', function (): HttpAccess { return new HttpAccess(); - }; + }); - $container['netscapeBookmarkUtils'] = function (ShaarliContainer $container): NetscapeBookmarkUtils { - return new NetscapeBookmarkUtils($container->bookmarkService, $container->conf, $container->history); - }; + $container->set('netscapeBookmarkUtils', function (Container $container): NetscapeBookmarkUtils { + return new NetscapeBookmarkUtils( + $container->get('bookmarkService'), + $container->get('conf'), + $container->get('history') + ); + }); - $container['updater'] = function (ShaarliContainer $container): Updater { + $container->set('updater', function (Container $container): Updater { return new Updater( - UpdaterUtils::readUpdatesFile($container->conf->get('resource.updates')), - $container->bookmarkService, - $container->conf, - $container->loginManager->isLoggedIn() + UpdaterUtils::readUpdatesFile($container->get('conf')->get('resource.updates')), + $container->get('bookmarkService'), + $container->get('conf'), + $container->get('loginManager')->isLoggedIn() ); - }; - - $container['notFoundHandler'] = function (ShaarliContainer $container): ErrorNotFoundController { - return new ErrorNotFoundController($container); - }; - $container['errorHandler'] = function (ShaarliContainer $container): ErrorController { - return new ErrorController($container); - }; - $container['phpErrorHandler'] = function (ShaarliContainer $container): ErrorController { - return new ErrorController($container); - }; + }); return $container; } diff --git a/application/container/ShaarliContainer.php b/application/container/ShaarliContainer.php deleted file mode 100644 index be0a83001..000000000 --- a/application/container/ShaarliContainer.php +++ /dev/null @@ -1,54 +0,0 @@ -linkDB = $linkDB; $this->formatter = $formatter; - $this->serverInfo = $serverInfo; $this->isLoggedIn = $isLoggedIn; } @@ -91,14 +89,14 @@ public function __construct($linkDB, $formatter, $serverInfo, $isLoggedIn) * Build data for feed templates. * * @param string $feedType Type of feed (RSS/ATOM). - * @param array $userInput $_GET. - * + * @param ?array $userInput $_GET. + * @param array $serverInfo $serverInfo $_SERVER. * @return array Formatted data for feeds templates. */ - public function buildData(string $feedType, ?array $userInput) + public function buildData(string $feedType, ?array $userInput, array $serverInfo) { // Search for untagged bookmarks - if (isset($this->userInput['searchtags']) && empty($userInput['searchtags'])) { + if (isset($userInput['searchtags']) && empty($userInput['searchtags'])) { $userInput['searchtags'] = false; } @@ -107,7 +105,7 @@ public function buildData(string $feedType, ?array $userInput) // Optionally filter the results: $searchResult = $this->linkDB->search($userInput ?? [], null, false, false, true, ['limit' => $limit]); - $pageaddr = escape(index_url($this->serverInfo)); + $pageaddr = escape(index_url($serverInfo)); $this->formatter->addContextData('index_url', $pageaddr); $links = []; foreach ($searchResult->getBookmarks() as $key => $bookmark) { @@ -118,7 +116,7 @@ public function buildData(string $feedType, ?array $userInput) $data['last_update'] = $this->getLatestDateFormatted($feedType); $data['show_dates'] = !$this->hideDates || $this->isLoggedIn; // Remove leading path from REQUEST_URI (already contained in $pageaddr). - $requestUri = preg_replace('#(.*?/)(feed.*)#', '$2', escape($this->serverInfo['REQUEST_URI'])); + $requestUri = preg_replace('#(.*?/)(feed.*)#', '$2', escape($serverInfo['REQUEST_URI'])); $data['self_link'] = $pageaddr . $requestUri; $data['index_url'] = $pageaddr; $data['usepermalinks'] = $this->usePermalinks === true; diff --git a/application/front/ShaarliAdminMiddleware.php b/application/front/ShaarliAdminMiddleware.php index 35ce4a3be..807e6e90e 100644 --- a/application/front/ShaarliAdminMiddleware.php +++ b/application/front/ShaarliAdminMiddleware.php @@ -2,8 +2,9 @@ namespace Shaarli\Front; -use Slim\Http\Request; -use Slim\Http\Response; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; +use Psr\Http\Server\RequestHandlerInterface as RequestHandler; /** * Middleware used for controller requiring to be authenticated. @@ -12,16 +13,16 @@ */ class ShaarliAdminMiddleware extends ShaarliMiddleware { - public function __invoke(Request $request, Response $response, callable $next): Response + public function __invoke(Request $request, RequestHandler $handler): Response { $this->initBasePath($request); - if (true !== $this->container->loginManager->isLoggedIn()) { - $returnUrl = urlencode($this->container->environment['REQUEST_URI']); + if (true !== $this->container->get('loginManager')->isLoggedIn()) { + $returnUrl = urlencode($request->getServerParams()['REQUEST_URI'] ?? null); - return $response->withRedirect($this->container->basePath . '/login?returnurl=' . $returnUrl); + return $this->redirect($this->container->get('basePath') . '/login?returnurl=' . $returnUrl); } - return parent::__invoke($request, $response, $next); + return parent::__invoke($request, $handler); } } diff --git a/application/front/ShaarliErrorHandler.php b/application/front/ShaarliErrorHandler.php new file mode 100644 index 000000000..a98a2f6d9 --- /dev/null +++ b/application/front/ShaarliErrorHandler.php @@ -0,0 +1,160 @@ +container = $container; + } + + public function __invoke( + ServerRequestInterface $request, + Throwable $exception, + bool $displayErrorDetails, + bool $logErrors, + bool $logErrorDetails + ): ResponseInterface { + $resp = parent::__invoke($request, $exception, $displayErrorDetails, $logErrors, $logErrorDetails); + $response = new Response(); + // Unknown error encountered + $this->container->get('pageBuilder')->reset(); + if ($exception instanceof HttpNotFoundException) { + return $this->showError404($request); + } elseif ($exception instanceof ShaarliFrontException) { + // Functional error + $this->assignView('message', nl2br($exception->getMessage())); + + $response = $response->withStatus($exception->getCode()); + } else { + // Internal error (any other Throwable) + if ( + $this->container->get('conf')->get('dev.debug', false) || + $this->container->get('loginManager')->isLoggedIn() + ) { + $this->assignView('message', t('Error: ') . $exception->getMessage()); + $this->assignView( + 'text', + '' + . t('Please report it on Github.') + . '' + ); + $this->assignView('stacktrace', exception2text($exception)); + } else { + $this->assignView('message', t('An unexpected error occurred.')); + } + + $response = $response->withStatus(500); + } + + $response->getBody()->write($this->render(TemplatePage::ERROR)); + return $response; + } + + protected function assignView(string $name, $value): self + { + $this->container->get('pageBuilder')->assign($name, $value); + + return $this; + } + + /** + * Call plugin hooks for header, footer and includes, specifying which page will be rendered. + * Then assign generated data to RainTPL. + */ + protected function executeDefaultHooks(string $template): void + { + $common_hooks = [ + 'includes', + 'header', + 'footer', + ]; + + $parameters = $this->buildPluginParameters($template); + + foreach ($common_hooks as $name) { + $pluginData = []; + $this->container->get('pluginManager')->executeHooks( + 'render_' . $name, + $pluginData, + $parameters + ); + $this->assignView('plugins_' . $name, $pluginData); + } + } + + protected function buildPluginParameters(?string $template): array + { + $basePath = $this->container->get('basePath') ?? ''; + return [ + 'target' => $template, + 'loggedin' => $this->container->get('loginManager')->isLoggedIn(), + 'basePath' => $this->container->get('basePath'), + 'rootPath' => preg_replace('#/index\.php$#', '', $basePath), + 'bookmarkService' => $this->container->get('bookmarkService') + ]; + } + + protected function render(string $template): string + { + // Legacy key that used to be injected by PluginManager + $this->assignView('_PAGE_', $template); + $this->assignView('template', $template); + + $this->assignView('linkcount', $this->container->get('bookmarkService')->count(BookmarkFilter::$ALL)); + $this->assignView('privateLinkcount', $this->container->get('bookmarkService') + ->count(BookmarkFilter::$PRIVATE)); + + $this->executeDefaultHooks($template); + + $this->assignView('plugin_errors', $this->container->get('pluginManager')->getErrors()); + + $basePath = $this->container->get('basePath') ?? ''; + return $this->container->get('pageBuilder')->render($template, $basePath); + } + + protected function showError404($request): Response + { + $response = new SlimResponse(); + // Request from the API + if (false !== strpos($request->getRequestTarget(), '/api/v1')) { + return $response->withStatus(404); + } + $basePathFromRequest = $request->getAttribute(RouteContext::BASE_PATH) ?? ''; + + // This is required because the middleware is ignored if the route is not found. + $this->container->set('basePath', rtrim($basePathFromRequest, '/')); + + $this->assignView('error_message', t('Requested page could not be found.')); + + $response = $response->withStatus(404); + $response->getBody()->write($this->render(TemplatePage::ERROR_404)); + return $response; + } +} diff --git a/application/front/ShaarliMiddleware.php b/application/front/ShaarliMiddleware.php index 164217f4f..b5a1c01aa 100644 --- a/application/front/ShaarliMiddleware.php +++ b/application/front/ShaarliMiddleware.php @@ -2,10 +2,13 @@ namespace Shaarli\Front; -use Shaarli\Container\ShaarliContainer; +use Psr\Container\ContainerInterface as Container; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; +use Psr\Http\Server\RequestHandlerInterface as RequestHandler; use Shaarli\Front\Exception\UnauthorizedException; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Routing\RouteContext; /** * Class ShaarliMiddleware @@ -14,10 +17,10 @@ */ class ShaarliMiddleware { - /** @var ShaarliContainer contains all Shaarli DI */ + /** @var Container contains all Shaarli DI */ protected $container; - public function __construct(ShaarliContainer $container) + public function __construct(Container $container) { $this->container = $container; } @@ -31,32 +34,31 @@ public function __construct(ShaarliContainer $container) * * In case of error, the error template will be displayed with the exception message. * - * @param Request $request Slim request - * @param Response $response Slim response - * @param callable $next Next action - * + * @param Request $request Slim request + * @param RequestHandler $handler * @return Response response. */ - public function __invoke(Request $request, Response $response, callable $next): Response + public function __invoke(Request $request, RequestHandler $handler): Response { $this->initBasePath($request); try { if ( - !is_file($this->container->conf->getConfigFileExt()) - && !in_array($next->getName(), ['displayInstall', 'saveInstall'], true) + !is_file($this->container->get('conf')->getConfigFileExt()) + && !in_array($request + ->getAttribute(RouteContext::ROUTE)->getName(), ['displayInstall', 'saveInstall'], true) ) { - return $response->withRedirect($this->container->basePath . '/install'); + return $this->redirect($this->container->get('basePath') . '/install'); } $this->runUpdates(); - $this->checkOpenShaarli($request, $response, $next); + $this->checkOpenShaarli($request, $handler); - return $next($request, $response); + return $handler->handle($request); } catch (UnauthorizedException $e) { - $returnUrl = urlencode($this->container->environment['REQUEST_URI']); + $returnUrl = urlencode($request->getServerParams()['REQUEST_URI'] ?? null); - return $response->withRedirect($this->container->basePath . '/login?returnurl=' . $returnUrl); + return $this->redirect($this->container->get('basePath') . '/login?returnurl=' . $returnUrl); } // Other exceptions are handled by ErrorController } @@ -66,37 +68,38 @@ public function __invoke(Request $request, Response $response, callable $next): */ protected function runUpdates(): void { - if ($this->container->loginManager->isLoggedIn() !== true) { + if ($this->container->get('loginManager')->isLoggedIn() !== true) { return; } - $this->container->updater->setBasePath($this->container->basePath); - $newUpdates = $this->container->updater->update(); + $this->container->get('updater')->setBasePath($this->container->get('basePath')); + $newUpdates = $this->container->get('updater')->update(); if (!empty($newUpdates)) { - $this->container->updater->writeUpdates( - $this->container->conf->get('resource.updates'), - $this->container->updater->getDoneUpdates() + $this->container->get('updater')->writeUpdates( + $this->container->get('conf')->get('resource.updates'), + $this->container->get('updater')->getDoneUpdates() ); - $this->container->pageCacheManager->invalidateCaches(); + $this->container->get('pageCacheManager')->invalidateCaches(); } } /** * Access is denied to most pages with `hide_public_links` + `force_login` settings. */ - protected function checkOpenShaarli(Request $request, Response $response, callable $next): bool + protected function checkOpenShaarli(Request $request, RequestHandler $handler): bool { if ( // if the user isn't logged in - !$this->container->loginManager->isLoggedIn() + !$this->container->get('loginManager')->isLoggedIn() // and Shaarli doesn't have public content... - && $this->container->conf->get('privacy.hide_public_links') + && $this->container->get('conf')->get('privacy.hide_public_links') // and is configured to enforce the login - && $this->container->conf->get('privacy.force_login') + && $this->container->get('conf')->get('privacy.force_login') // and the current page isn't already the login page // and the user is not requesting a feed (which would lead to a different content-type as expected) - && !in_array($next->getName(), ['login', 'processLogin', 'atom', 'rss'], true) + && !in_array($request->getAttribute(RouteContext::ROUTE) + ->getName(), ['login', 'processLogin', 'atom', 'rss'], true) ) { throw new UnauthorizedException(); } @@ -109,8 +112,18 @@ protected function checkOpenShaarli(Request $request, Response $response, callab */ protected function initBasePath(Request $request): void { - if (null === $this->container->basePath) { - $this->container->basePath = rtrim($request->getUri()->getBasePath(), '/'); + if (null === $this->container->get('basePath')) { + $this->container->set('basePath', rtrim($request->getAttribute('basePath'), '/')); } } + + /** + * @param string $url + * @return Response + */ + protected function redirect(string $url): Response + { + $response = new SlimResponse(); + return $response->withHeader('Location', $url)->withStatus(302); + } } diff --git a/application/front/controller/admin/ConfigureController.php b/application/front/controller/admin/ConfigureController.php index dc421661c..3d4b80a29 100644 --- a/application/front/controller/admin/ConfigureController.php +++ b/application/front/controller/admin/ConfigureController.php @@ -4,12 +4,12 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Languages; use Shaarli\Render\TemplatePage; use Shaarli\Render\ThemeUtils; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; use Throwable; /** @@ -24,39 +24,42 @@ class ConfigureController extends ShaarliAdminController */ public function index(Request $request, Response $response): Response { - $this->assignView('title', $this->container->conf->get('general.title', 'Shaarli')); - $this->assignView('theme', $this->container->conf->get('resource.theme')); + $this->assignView('title', $this->container->get('conf')->get('general.title', 'Shaarli')); + $this->assignView('theme', $this->container->get('conf')->get('resource.theme')); $this->assignView( 'theme_available', - ThemeUtils::getThemes($this->container->conf->get('resource.raintpl_tpl')) + ThemeUtils::getThemes($this->container->get('conf')->get('resource.raintpl_tpl')) ); $this->assignView('formatter_available', ['default', 'markdown', 'markdownExtra']); list($continents, $cities) = generateTimeZoneData( timezone_identifiers_list(), - $this->container->conf->get('general.timezone') + $this->container->get('conf')->get('general.timezone') ); $this->assignView('continents', $continents); $this->assignView('cities', $cities); - $this->assignView('retrieve_description', $this->container->conf->get('general.retrieve_description', false)); - $this->assignView('private_links_default', $this->container->conf->get('privacy.default_private_links', false)); + $this->assignView('retrieve_description', $this->container->get('conf') + ->get('general.retrieve_description', false)); + $this->assignView('private_links_default', $this->container->get('conf') + ->get('privacy.default_private_links', false)); $this->assignView( 'session_protection_disabled', - $this->container->conf->get('security.session_protection_disabled', false) + $this->container->get('conf')->get('security.session_protection_disabled', false) ); - $this->assignView('enable_rss_permalinks', $this->container->conf->get('feed.rss_permalinks', false)); - $this->assignView('enable_update_check', $this->container->conf->get('updates.check_updates', true)); - $this->assignView('hide_public_links', $this->container->conf->get('privacy.hide_public_links', false)); - $this->assignView('api_enabled', $this->container->conf->get('api.enabled', true)); - $this->assignView('api_secret', $this->container->conf->get('api.secret')); + $this->assignView('enable_rss_permalinks', $this->container->get('conf')->get('feed.rss_permalinks', false)); + $this->assignView('enable_update_check', $this->container->get('conf')->get('updates.check_updates', true)); + $this->assignView('hide_public_links', $this->container->get('conf')->get('privacy.hide_public_links', false)); + $this->assignView('api_enabled', $this->container->get('conf')->get('api.enabled', true)); + $this->assignView('api_secret', $this->container->get('conf')->get('api.secret')); $this->assignView('languages', Languages::getAvailableLanguages()); $this->assignView('gd_enabled', extension_loaded('gd')); - $this->assignView('thumbnails_mode', $this->container->conf->get('thumbnails.mode', Thumbnailer::MODE_NONE)); + $this->assignView('thumbnails_mode', $this->container->get('conf') + ->get('thumbnails.mode', Thumbnailer::MODE_NONE)); $this->assignView( 'pagetitle', - t('Configure') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + t('Configure') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); - return $response->write($this->render(TemplatePage::CONFIGURE)); + return $this->respondWithTemplate($response, TemplatePage::CONFIGURE); } /** @@ -66,63 +69,76 @@ public function save(Request $request, Response $response): Response { $this->checkToken($request); - $continent = $request->getParam('continent'); - $city = $request->getParam('city'); + $continent = $request->getParsedBody()['continent'] ?? null; + $city = $request->getParsedBody()['city'] ?? null; $tz = 'UTC'; if (null !== $continent && null !== $city && isTimeZoneValid($continent, $city)) { $tz = $continent . '/' . $city; } - $this->container->conf->set('general.timezone', $tz); - $this->container->conf->set('general.title', escape($request->getParam('title'))); - $this->container->conf->set('general.header_link', escape($request->getParam('titleLink'))); - $this->container->conf->set('general.retrieve_description', !empty($request->getParam('retrieveDescription'))); - $this->container->conf->set('resource.theme', escape($request->getParam('theme'))); - $this->container->conf->set( + $this->container->get('conf')->set('general.timezone', $tz); + $this->container->get('conf')->set('general.title', escape($request->getParsedBody()['title'] ?? null)); + $this->container->get('conf') + ->set('general.header_link', escape($request->getParsedBody()['titleLink'] ?? null)); + $this->container->get('conf')->set( + 'general.retrieve_description', + !empty($request->getParsedBody()['retrieveDescription'] ?? null) + ); + $this->container->get('conf')->set('resource.theme', escape($request->getParsedBody()['theme'] ?? null)); + $this->container->get('conf')->set( 'security.session_protection_disabled', - !empty($request->getParam('disablesessionprotection')) + !empty($request->getParsedBody()['disablesessionprotection'] ?? null) ); - $this->container->conf->set( + $this->container->get('conf')->set( 'privacy.default_private_links', - !empty($request->getParam('privateLinkByDefault')) + !empty($request->getParsedBody()['privateLinkByDefault'] ?? null) + ); + $this->container->get('conf')->set( + 'feed.rss_permalinks', + !empty($request->getParsedBody()['enableRssPermalinks'] ?? null) + ); + $this->container->get('conf') + ->set('updates.check_updates', !empty($request->getParsedBody()['updateCheck'] ?? null)); + $this->container->get('conf')->set( + 'privacy.hide_public_links', + !empty($request->getParsedBody()['hidePublicLinks'] ?? null) ); - $this->container->conf->set('feed.rss_permalinks', !empty($request->getParam('enableRssPermalinks'))); - $this->container->conf->set('updates.check_updates', !empty($request->getParam('updateCheck'))); - $this->container->conf->set('privacy.hide_public_links', !empty($request->getParam('hidePublicLinks'))); - $this->container->conf->set('api.enabled', !empty($request->getParam('enableApi'))); - $this->container->conf->set('api.secret', escape($request->getParam('apiSecret'))); - $this->container->conf->set('formatter', escape($request->getParam('formatter'))); + $this->container->get('conf')->set('api.enabled', !empty($request->getParsedBody()['enableApi'] ?? null)); + $this->container->get('conf')->set('api.secret', escape($request->getParsedBody()['apiSecret'] ?? null)); + $this->container->get('conf')->set('formatter', escape($request->getParsedBody()['formatter'] ?? null)); - if (!empty($request->getParam('language'))) { - $this->container->conf->set('translation.language', escape($request->getParam('language'))); + if (!empty($request->getParsedBody()['language'] ?? null)) { + $this->container->get('conf') + ->set('translation.language', escape($request->getParsedBody()['language'] ?? null)); } - $thumbnailsMode = extension_loaded('gd') ? $request->getParam('enableThumbnails') : Thumbnailer::MODE_NONE; + $thumbnailsMode = extension_loaded('gd') ? + $request->getParsedBody()['enableThumbnails'] ?? null : Thumbnailer::MODE_NONE; if ( $thumbnailsMode !== Thumbnailer::MODE_NONE - && $thumbnailsMode !== $this->container->conf->get('thumbnails.mode', Thumbnailer::MODE_NONE) + && $thumbnailsMode !== $this->container->get('conf')->get('thumbnails.mode', Thumbnailer::MODE_NONE) ) { $this->saveWarningMessage( t('You have enabled or changed thumbnails mode.') . - '' . + '' . t('Please synchronize them.') . '' ); } - $this->container->conf->set('thumbnails.mode', $thumbnailsMode); + $this->container->get('conf')->set('thumbnails.mode', $thumbnailsMode); try { - $this->container->conf->write($this->container->loginManager->isLoggedIn()); - $this->container->history->updateSettings(); - $this->container->pageCacheManager->invalidateCaches(); + $this->container->get('conf')->write($this->container->get('loginManager')->isLoggedIn()); + $this->container->get('history')->updateSettings(); + $this->container->get('pageCacheManager')->invalidateCaches(); } catch (Throwable $e) { $this->assignView('message', t('Error while writing config file after configuration update.')); - if ($this->container->conf->get('dev.debug', false)) { + if ($this->container->get('conf')->get('dev.debug', false)) { $this->assignView('stacktrace', $e->getMessage() . PHP_EOL . $e->getTraceAsString()); } - return $response->write($this->render('error')); + return $this->respondWithTemplate($response, TemplatePage::ERROR); } $this->saveSuccessMessage(t('Configuration was saved.')); diff --git a/application/front/controller/admin/ExportController.php b/application/front/controller/admin/ExportController.php index f01d7e9be..5cad943d2 100644 --- a/application/front/controller/admin/ExportController.php +++ b/application/front/controller/admin/ExportController.php @@ -5,10 +5,10 @@ namespace Shaarli\Front\Controller\Admin; use DateTime; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\Bookmark; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class ExportController @@ -23,9 +23,10 @@ class ExportController extends ShaarliAdminController */ public function index(Request $request, Response $response): Response { - $this->assignView('pagetitle', t('Export') . ' - ' . $this->container->conf->get('general.title', 'Shaarli')); + $this->assignView('pagetitle', t('Export') . ' - ' . $this->container->get('conf') + ->get('general.title', 'Shaarli')); - return $response->write($this->render(TemplatePage::EXPORT)); + return $this->respondWithTemplate($response, TemplatePage::EXPORT); } /** @@ -36,7 +37,7 @@ public function export(Request $request, Response $response): Response { $this->checkToken($request); - $selection = $request->getParam('selection'); + $selection = $request->getParsedBody()['selection'] ?? null; if (empty($selection)) { $this->saveErrorMessage(t('Please select an export mode.')); @@ -44,18 +45,19 @@ public function export(Request $request, Response $response): Response return $this->redirect($response, '/admin/export'); } - $prependNoteUrl = filter_var($request->getParam('prepend_note_url') ?? false, FILTER_VALIDATE_BOOLEAN); + $prependNoteUrl = filter_var($request->getParsedBody()['prepend_note_url'] ?? false, FILTER_VALIDATE_BOOLEAN); try { - $formatter = $this->container->formatterFactory->getFormatter('raw'); + $formatter = $this->container->get('formatterFactory')->getFormatter('raw'); + $a = index_url($request->getServerParams()); $this->assignView( 'links', - $this->container->netscapeBookmarkUtils->filterAndFormat( + $this->container->get('netscapeBookmarkUtils')->filterAndFormat( $formatter, $selection, $prependNoteUrl, - index_url($this->container->environment) + index_url($request->getServerParams()) ) ); } catch (\Exception $exc) { @@ -75,6 +77,6 @@ public function export(Request $request, Response $response): Response $this->assignView('eol', PHP_EOL); $this->assignView('selection', $selection); - return $response->write($this->render(TemplatePage::NETSCAPE_EXPORT_BOOKMARKS)); + return $this->respondWithTemplate($response, TemplatePage::NETSCAPE_EXPORT_BOOKMARKS); } } diff --git a/application/front/controller/admin/ImportController.php b/application/front/controller/admin/ImportController.php index c2ad6a09f..59b34b091 100644 --- a/application/front/controller/admin/ImportController.php +++ b/application/front/controller/admin/ImportController.php @@ -4,10 +4,10 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Psr\Http\Message\UploadedFileInterface; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class ImportController @@ -38,9 +38,10 @@ public function index(Request $request, Response $response): Response true ) ); - $this->assignView('pagetitle', t('Import') . ' - ' . $this->container->conf->get('general.title', 'Shaarli')); + $this->assignView('pagetitle', t('Import') . ' - ' . $this->container->get('conf') + ->get('general.title', 'Shaarli')); - return $response->write($this->render(TemplatePage::IMPORT)); + return $this->respondWithTemplate($response, TemplatePage::IMPORT); } /** @@ -73,7 +74,7 @@ public function import(Request $request, Response $response): Response return $this->redirect($response, '/admin/import'); } - $status = $this->container->netscapeBookmarkUtils->import($request->getParams(), $file); + $status = $this->container->get('netscapeBookmarkUtils')->import($request->getParsedBody(), $file); $this->saveSuccessMessage($status); diff --git a/application/front/controller/admin/LogoutController.php b/application/front/controller/admin/LogoutController.php index 28165129f..6b6fa6cb0 100644 --- a/application/front/controller/admin/LogoutController.php +++ b/application/front/controller/admin/LogoutController.php @@ -4,10 +4,9 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Security\CookieManager; -use Shaarli\Security\LoginManager; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class LogoutController @@ -19,13 +18,13 @@ class LogoutController extends ShaarliAdminController { public function index(Request $request, Response $response): Response { - $this->container->pageCacheManager->invalidateCaches(); - $this->container->sessionManager->logout(); - $this->container->cookieManager->setCookieParameter( + $this->container->get('pageCacheManager')->invalidateCaches(); + $this->container->get('sessionManager')->logout(); + $this->container->get('cookieManager')->setCookieParameter( CookieManager::STAY_SIGNED_IN, 'false', 0, - $this->container->basePath . '/' + $this->container->get('basePath') . '/' ); return $this->redirect($response, '/'); diff --git a/application/front/controller/admin/ManageTagController.php b/application/front/controller/admin/ManageTagController.php index 1333cce72..ce6bbb206 100644 --- a/application/front/controller/admin/ManageTagController.php +++ b/application/front/controller/admin/ManageTagController.php @@ -4,10 +4,10 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\BookmarkFilter; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class ManageTagController @@ -21,10 +21,10 @@ class ManageTagController extends ShaarliAdminController */ public function index(Request $request, Response $response): Response { - $fromTag = $request->getParam('fromtag') ?? ''; + $fromTag = $request->getQueryParams()['fromtag'] ?? ''; $this->assignView('fromtag', escape($fromTag)); - $separator = escape($this->container->conf->get('general.tags_separator', ' ')); + $separator = escape($this->container->get('conf')->get('general.tags_separator', ' ')); if ($separator === ' ') { $separator = ' '; $this->assignView('tags_separator_desc', t('whitespace')); @@ -32,10 +32,10 @@ public function index(Request $request, Response $response): Response $this->assignView('tags_separator', $separator); $this->assignView( 'pagetitle', - t('Manage tags') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + t('Manage tags') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); - return $response->write($this->render(TemplatePage::CHANGE_TAG)); + return $this->respondWithTemplate($response, TemplatePage::CHANGE_TAG); } /** @@ -45,10 +45,11 @@ public function save(Request $request, Response $response): Response { $this->checkToken($request); - $isDelete = null !== $request->getParam('deletetag') && null === $request->getParam('renametag'); + $isDelete = null !== ($request->getParsedBody()['deletetag'] ?? null) + && null === ($request->getParsedBody()['renametag'] ?? null); - $fromTag = trim($request->getParam('fromtag') ?? ''); - $toTag = trim($request->getParam('totag') ?? ''); + $fromTag = trim($request->getParsedBody()['fromtag'] ?? ''); + $toTag = trim($request->getParsedBody()['totag'] ?? ''); if (0 === strlen($fromTag) || false === $isDelete && 0 === strlen($toTag)) { $this->saveWarningMessage(t('Invalid tags provided.')); @@ -57,7 +58,7 @@ public function save(Request $request, Response $response): Response } // TODO: move this to bookmark service - $searchResult = $this->container->bookmarkService->search( + $searchResult = $this->container->get('bookmarkService')->search( ['searchtags' => $fromTag], BookmarkFilter::$ALL, true @@ -69,11 +70,11 @@ public function save(Request $request, Response $response): Response $bookmark->deleteTag($fromTag); } - $this->container->bookmarkService->set($bookmark, false); - $this->container->history->updateLink($bookmark); + $this->container->get('bookmarkService')->set($bookmark, false); + $this->container->get('history')->updateLink($bookmark); } - $this->container->bookmarkService->save(); + $this->container->get('bookmarkService')->save(); $count = $searchResult->getResultCount(); if (true === $isDelete) { @@ -103,7 +104,7 @@ public function changeSeparator(Request $request, Response $response): Response $this->checkToken($request); $reservedCharacters = ['-', '.', '*']; - $newSeparator = $request->getParam('separator'); + $newSeparator = $request->getParsedBody()['separator'] ?? null; if ($newSeparator === null || mb_strlen($newSeparator) !== 1) { $this->saveErrorMessage(t('Tags separator must be a single character.')); } elseif (in_array($newSeparator, $reservedCharacters, true)) { @@ -114,7 +115,7 @@ public function changeSeparator(Request $request, Response $response): Response t('These characters are reserved and can\'t be used as tags separator: ') . $reservedCharacters ); } else { - $this->container->conf->set('general.tags_separator', $newSeparator, true, true); + $this->container->get('conf')->set('general.tags_separator', $newSeparator, true, true); $this->saveSuccessMessage('Your tags separator setting has been updated!'); } diff --git a/application/front/controller/admin/MetadataController.php b/application/front/controller/admin/MetadataController.php index ff8459449..5db05a652 100644 --- a/application/front/controller/admin/MetadataController.php +++ b/application/front/controller/admin/MetadataController.php @@ -4,8 +4,8 @@ namespace Shaarli\Front\Controller\Admin; -use Slim\Http\Request; -use Slim\Http\Response; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; /** * Controller used to retrieve/update bookmark's metadata. @@ -17,13 +17,13 @@ class MetadataController extends ShaarliAdminController */ public function ajaxRetrieveTitle(Request $request, Response $response): Response { - $url = $request->getParam('url'); + $url = $request->getQueryParams()['url'] ?? null; // Only try to extract metadata from URL with HTTP(s) scheme if (!empty($url) && strpos(get_url_scheme($url) ?: '', 'http') !== false) { - return $response->withJson($this->container->metadataRetriever->retrieve($url)); + return $this->respondWithJson($response, $this->container->get('metadataRetriever')->retrieve($url)); } - return $response->withJson([]); + return $this->respondWithJson($response, []); } } diff --git a/application/front/controller/admin/PasswordController.php b/application/front/controller/admin/PasswordController.php index 4aaf1f82c..a29e56ecc 100644 --- a/application/front/controller/admin/PasswordController.php +++ b/application/front/controller/admin/PasswordController.php @@ -4,12 +4,12 @@ namespace Shaarli\Front\Controller\Admin; -use Shaarli\Container\ShaarliContainer; +use DI\Container; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Exception\OpenShaarliPasswordException; use Shaarli\Front\Exception\ShaarliFrontException; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; use Throwable; /** @@ -19,13 +19,13 @@ */ class PasswordController extends ShaarliAdminController { - public function __construct(ShaarliContainer $container) + public function __construct(Container $container) { parent::__construct($container); $this->assignView( 'pagetitle', - t('Change password') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + t('Change password') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); } @@ -34,7 +34,7 @@ public function __construct(ShaarliContainer $container) */ public function index(Request $request, Response $response): Response { - return $response->write($this->render(TemplatePage::CHANGE_PASSWORD)); + return $this->respondWithTemplate($response, TemplatePage::CHANGE_PASSWORD); } /** @@ -44,58 +44,55 @@ public function change(Request $request, Response $response): Response { $this->checkToken($request); - if ($this->container->conf->get('security.open_shaarli', false)) { + if ($this->container->get('conf')->get('security.open_shaarli', false)) { throw new OpenShaarliPasswordException(); } - $oldPassword = $request->getParam('oldpassword'); - $newPassword = $request->getParam('setpassword'); + $oldPassword = $request->getParsedBody()['oldpassword'] ?? null; + $newPassword = $request->getParsedBody()['setpassword'] ?? null; if (empty($newPassword) || empty($oldPassword)) { $this->saveErrorMessage(t('You must provide the current and new password to change it.')); - return $response - ->withStatus(400) - ->write($this->render(TemplatePage::CHANGE_PASSWORD)) - ; + return $this->respondWithTemplate($response, TemplatePage::CHANGE_PASSWORD) + ->withStatus(400); } // Make sure old password is correct. $oldHash = sha1( $oldPassword . - $this->container->conf->get('credentials.login') . - $this->container->conf->get('credentials.salt') + $this->container->get('conf')->get('credentials.login') . + $this->container->get('conf')->get('credentials.salt') ); - if ($oldHash !== $this->container->conf->get('credentials.hash')) { + if ($oldHash !== $this->container->get('conf')->get('credentials.hash')) { $this->saveErrorMessage(t('The old password is not correct.')); - return $response - ->withStatus(400) - ->write($this->render(TemplatePage::CHANGE_PASSWORD)) + return $this->respondWithTemplate($response, TemplatePage::CHANGE_PASSWORD) + ->withStatus(400); ; } // Save new password // Salt renders rainbow-tables attacks useless. - $this->container->conf->set('credentials.salt', sha1(uniqid('', true) . '_' . mt_rand())); - $this->container->conf->set( + $this->container->get('conf')->set('credentials.salt', sha1(uniqid('', true) . '_' . mt_rand())); + $this->container->get('conf')->set( 'credentials.hash', sha1( $newPassword - . $this->container->conf->get('credentials.login') - . $this->container->conf->get('credentials.salt') + . $this->container->get('conf')->get('credentials.login') + . $this->container->get('conf')->get('credentials.salt') ) ); try { - $this->container->conf->write($this->container->loginManager->isLoggedIn()); + $this->container->get('conf')->write($this->container->get('loginManager')->isLoggedIn()); } catch (Throwable $e) { throw new ShaarliFrontException($e->getMessage(), 500, $e); } $this->saveSuccessMessage(t('Your password has been changed')); - return $response->write($this->render(TemplatePage::CHANGE_PASSWORD)); + return $this->respondWithTemplate($response, TemplatePage::CHANGE_PASSWORD); } } diff --git a/application/front/controller/admin/PluginsController.php b/application/front/controller/admin/PluginsController.php index ae47c1af1..ed43f2960 100644 --- a/application/front/controller/admin/PluginsController.php +++ b/application/front/controller/admin/PluginsController.php @@ -5,9 +5,9 @@ namespace Shaarli\Front\Controller\Admin; use Exception; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class PluginsController @@ -21,13 +21,14 @@ class PluginsController extends ShaarliAdminController */ public function index(Request $request, Response $response): Response { - $pluginMeta = $this->container->pluginManager->getPluginsMeta(); + $pluginMeta = $this->container->get('pluginManager')->getPluginsMeta(); // Split plugins into 2 arrays: ordered enabled plugins and disabled. $enabledPlugins = array_filter($pluginMeta, function ($v) { return ($v['order'] ?? false) !== false; }); - $enabledPlugins = load_plugin_parameter_values($enabledPlugins, $this->container->conf->get('plugins', [])); + $enabledPlugins = load_plugin_parameter_values($enabledPlugins, $this->container->get('conf') + ->get('plugins', [])); uasort( $enabledPlugins, function ($a, $b) { @@ -42,10 +43,10 @@ function ($a, $b) { $this->assignView('disabledPlugins', $disabledPlugins); $this->assignView( 'pagetitle', - t('Plugin Administration') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + t('Plugin Administration') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); - return $response->write($this->render(TemplatePage::PLUGINS_ADMIN)); + return $this->respondWithTemplate($response, TemplatePage::PLUGINS_ADMIN); } /** @@ -56,7 +57,7 @@ public function save(Request $request, Response $response): Response $this->checkToken($request); try { - $parameters = $request->getParams() ?? []; + $parameters = $request->getParsedBody() ?? []; $this->executePageHooks('save_plugin_parameters', $parameters); @@ -64,14 +65,14 @@ public function save(Request $request, Response $response): Response unset($parameters['parameters_form']); unset($parameters['token']); foreach ($parameters as $param => $value) { - $this->container->conf->set('plugins.' . $param, escape($value)); + $this->container->get('conf')->set('plugins.' . $param, escape($value)); } } else { - $this->container->conf->set('general.enabled_plugins', save_plugin_config($parameters)); + $this->container->get('conf')->set('general.enabled_plugins', save_plugin_config($parameters)); } - $this->container->conf->write($this->container->loginManager->isLoggedIn()); - $this->container->history->updateSettings(); + $this->container->get('conf')->write($this->container->get('loginManager')->isLoggedIn()); + $this->container->get('history')->updateSettings(); $this->saveSuccessMessage(t('Setting successfully saved.')); } catch (Exception $e) { diff --git a/application/front/controller/admin/ServerController.php b/application/front/controller/admin/ServerController.php index 9be5ea772..fe6319a98 100644 --- a/application/front/controller/admin/ServerController.php +++ b/application/front/controller/admin/ServerController.php @@ -4,10 +4,11 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Helper\ApplicationUtils; use Shaarli\Helper\FileUtils; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Render\TemplatePage; /** * Slim controller used to handle Server administration page, and actions. @@ -26,7 +27,7 @@ class ServerController extends ShaarliAdminController public function index(Request $request, Response $response): Response { $releaseUrl = ApplicationUtils::$GITHUB_URL . '/releases/'; - if ($this->container->conf->get('updates.check_updates', true)) { + if ($this->container->get('conf')->get('updates.check_updates', true)) { $latestVersion = 'v' . ApplicationUtils::getVersion( ApplicationUtils::$GIT_RAW_URL . '/release/' . ApplicationUtils::$VERSION_FILE ); @@ -40,7 +41,7 @@ public function index(Request $request, Response $response): Response $phpEol = new \DateTimeImmutable(ApplicationUtils::getPhpEol(PHP_VERSION)); $permissions = array_merge( - ApplicationUtils::checkResourcePermissions($this->container->conf), + ApplicationUtils::checkResourcePermissions($this->container->get('conf')), ApplicationUtils::checkDatastoreMutex() ); @@ -52,17 +53,17 @@ public function index(Request $request, Response $response): Response $this->assignView('release_url', $releaseUrl); $this->assignView('latest_version', $latestVersion); $this->assignView('current_version', $currentVersion); - $this->assignView('thumbnails_mode', $this->container->conf->get('thumbnails.mode')); - $this->assignView('index_url', index_url($this->container->environment)); - $this->assignView('client_ip', client_ip_id($this->container->environment)); - $this->assignView('trusted_proxies', $this->container->conf->get('security.trusted_proxies', [])); + $this->assignView('thumbnails_mode', $this->container->get('conf')->get('thumbnails.mode')); + $this->assignView('index_url', index_url($request->getServerParams())); + $this->assignView('client_ip', client_ip_id($request->getServerParams())); + $this->assignView('trusted_proxies', $this->container->get('conf')->get('security.trusted_proxies', [])); $this->assignView( 'pagetitle', - t('Server administration') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + t('Server administration') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); - return $response->write($this->render('server')); + return $this->respondWithTemplate($response, TemplatePage::SERVER); } /** @@ -72,19 +73,19 @@ public function clearCache(Request $request, Response $response): Response { $exclude = ['.htaccess']; - if ($request->getQueryParam('type') === static::CACHE_THUMB) { - $folders = [$this->container->conf->get('resource.thumbnails_cache')]; + if (($request->getQueryParams()['type'] ?? null) === static::CACHE_THUMB) { + $folders = [$this->container->get('conf')->get('resource.thumbnails_cache')]; $this->saveWarningMessage( t('Thumbnails cache has been cleared.') . ' ' . - '' . + '' . t('Please synchronize them.') . '' ); } else { $folders = [ - $this->container->conf->get('resource.page_cache'), - $this->container->conf->get('resource.raintpl_tmp'), + $this->container->get('conf')->get('resource.page_cache'), + $this->container->get('conf')->get('resource.raintpl_tmp'), ]; $this->saveSuccessMessage(t('Shaarli\'s cache folder has been cleared!')); diff --git a/application/front/controller/admin/SessionFilterController.php b/application/front/controller/admin/SessionFilterController.php index 0917b6d20..dc94db558 100644 --- a/application/front/controller/admin/SessionFilterController.php +++ b/application/front/controller/admin/SessionFilterController.php @@ -4,10 +4,10 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\BookmarkFilter; use Shaarli\Security\SessionManager; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class SessionFilterController @@ -21,7 +21,7 @@ class SessionFilterController extends ShaarliAdminController */ public function visibility(Request $request, Response $response, array $args): Response { - if (false === $this->container->loginManager->isLoggedIn()) { + if (false === $this->container->get('loginManager')->isLoggedIn()) { return $this->redirectFromReferer($request, $response, ['visibility']); } @@ -30,17 +30,18 @@ public function visibility(Request $request, Response $response, array $args): R $newVisibility = null; } - $currentVisibility = $this->container->sessionManager->getSessionParameter(SessionManager::KEY_VISIBILITY); + $currentVisibility = $this->container->get('sessionManager') + ->getSessionParameter(SessionManager::KEY_VISIBILITY); // Visibility not set or not already expected value, set expected value, otherwise reset it if ($newVisibility !== null && (null === $currentVisibility || $currentVisibility !== $newVisibility)) { // See only public bookmarks - $this->container->sessionManager->setSessionParameter( + $this->container->get('sessionManager')->setSessionParameter( SessionManager::KEY_VISIBILITY, $newVisibility ); } else { - $this->container->sessionManager->deleteSessionParameter(SessionManager::KEY_VISIBILITY); + $this->container->get('sessionManager')->deleteSessionParameter(SessionManager::KEY_VISIBILITY); } return $this->redirectFromReferer($request, $response, ['visibility']); diff --git a/application/front/controller/admin/ShaareAddController.php b/application/front/controller/admin/ShaareAddController.php index ab8e7f408..e7b8fedfe 100644 --- a/application/front/controller/admin/ShaareAddController.php +++ b/application/front/controller/admin/ShaareAddController.php @@ -4,10 +4,10 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Formatter\BookmarkMarkdownFormatter; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; class ShaareAddController extends ShaarliAdminController { @@ -16,19 +16,20 @@ class ShaareAddController extends ShaarliAdminController */ public function addShaare(Request $request, Response $response): Response { - $tags = $this->container->bookmarkService->bookmarksCountPerTag(); - if ($this->container->conf->get('formatter') === 'markdown') { + $tags = $this->container->get('bookmarkService')->bookmarksCountPerTag(); + if ($this->container->get('conf')->get('formatter') === 'markdown') { $tags[BookmarkMarkdownFormatter::NO_MD_TAG] = 1; } $this->assignView( 'pagetitle', - t('Shaare a new link') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + t('Shaare a new link') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); $this->assignView('tags', $tags); - $this->assignView('default_private_links', $this->container->conf->get('privacy.default_private_links', false)); - $this->assignView('async_metadata', $this->container->conf->get('general.enable_async_metadata', true)); + $this->assignView('default_private_links', $this->container->get('conf') + ->get('privacy.default_private_links', false)); + $this->assignView('async_metadata', $this->container->get('conf')->get('general.enable_async_metadata', true)); - return $response->write($this->render(TemplatePage::ADDLINK)); + return $this->respondWithTemplate($response, TemplatePage::ADDLINK); } } diff --git a/application/front/controller/admin/ShaareManageController.php b/application/front/controller/admin/ShaareManageController.php index 05b816780..9b14ca88a 100644 --- a/application/front/controller/admin/ShaareManageController.php +++ b/application/front/controller/admin/ShaareManageController.php @@ -4,9 +4,9 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\Exception\BookmarkNotFoundException; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class PostBookmarkController @@ -22,7 +22,7 @@ public function deleteBookmark(Request $request, Response $response): Response { $this->checkToken($request); - $ids = escape(trim($request->getParam('id') ?? '')); + $ids = escape(trim($request->getQueryParams()['id'] ?? '')); if (empty($ids) || strpos($ids, ' ') !== false) { // multiple, space-separated ids provided $ids = array_values(array_filter(preg_split('/\s+/', $ids), 'ctype_digit')); @@ -37,11 +37,11 @@ public function deleteBookmark(Request $request, Response $response): Response return $this->redirectFromReferer($request, $response, [], ['delete-shaare']); } - $formatter = $this->container->formatterFactory->getFormatter('raw'); + $formatter = $this->container->get('formatterFactory')->getFormatter('raw'); $count = 0; foreach ($ids as $id) { try { - $bookmark = $this->container->bookmarkService->get((int) $id); + $bookmark = $this->container->get('bookmarkService')->get((int) $id); } catch (BookmarkNotFoundException $e) { $this->saveErrorMessage(sprintf( t('Bookmark with identifier %s could not be found.'), @@ -53,20 +53,20 @@ public function deleteBookmark(Request $request, Response $response): Response $data = $formatter->format($bookmark); $this->executePageHooks('delete_link', $data); - $this->container->bookmarkService->remove($bookmark, false); + $this->container->get('bookmarkService')->remove($bookmark, false); ++$count; } if ($count > 0) { - $this->container->bookmarkService->save(); + $this->container->get('bookmarkService')->save(); } // If we are called from the bookmarklet, we must close the popup: - if ($request->getParam('source') === 'bookmarklet') { - return $response->write(''); + if (($request->getQueryParams()['source'] ?? null) === 'bookmarklet') { + return $this->respondWithBody($response, ''); } - if ($request->getParam('source') === 'batch') { + if (($request->getQueryParams()['source'] ?? null) === 'batch') { return $response->withStatus(204); } @@ -83,7 +83,7 @@ public function changeVisibility(Request $request, Response $response): Response { $this->checkToken($request); - $ids = trim(escape($request->getParam('id') ?? '')); + $ids = trim(escape($request->getQueryParams()['id'] ?? '')); if (empty($ids) || strpos($ids, ' ') !== false) { // multiple, space-separated ids provided $ids = array_values(array_filter(preg_split('/\s+/', $ids), 'ctype_digit')); @@ -100,7 +100,7 @@ public function changeVisibility(Request $request, Response $response): Response } // assert that the visibility is valid - $visibility = $request->getParam('newVisibility'); + $visibility = $request->getQueryParams()['newVisibility'] ?? null; if (null === $visibility || false === in_array($visibility, ['public', 'private'], true)) { $this->saveErrorMessage(t('Invalid visibility provided.')); @@ -109,12 +109,12 @@ public function changeVisibility(Request $request, Response $response): Response $isPrivate = $visibility === 'private'; } - $formatter = $this->container->formatterFactory->getFormatter('raw'); + $formatter = $this->container->get('formatterFactory')->getFormatter('raw'); $count = 0; foreach ($ids as $id) { try { - $bookmark = $this->container->bookmarkService->get((int) $id); + $bookmark = $this->container->get('bookmarkService')->get((int) $id); } catch (BookmarkNotFoundException $e) { $this->saveErrorMessage(sprintf( t('Bookmark with identifier %s could not be found.'), @@ -129,14 +129,14 @@ public function changeVisibility(Request $request, Response $response): Response // To preserve backward compatibility with 3rd parties, plugins still use arrays $data = $formatter->format($bookmark); $this->executePageHooks('save_link', $data); - $bookmark->fromArray($data, $this->container->conf->get('general.tags_separator', ' ')); + $bookmark->fromArray($data, $this->container->get('conf')->get('general.tags_separator', ' ')); - $this->container->bookmarkService->set($bookmark, false); + $this->container->get('bookmarkService')->set($bookmark, false); ++$count; } if ($count > 0) { - $this->container->bookmarkService->save(); + $this->container->get('bookmarkService')->save(); } return $this->redirectFromReferer($request, $response, ['/visibility'], ['change_visibility']); @@ -154,7 +154,7 @@ public function pinBookmark(Request $request, Response $response, array $args): if (false === ctype_digit($id)) { throw new BookmarkNotFoundException(); } - $bookmark = $this->container->bookmarkService->get((int) $id); // Read database + $bookmark = $this->container->get('bookmarkService')->get((int) $id); // Read database } catch (BookmarkNotFoundException $e) { $this->saveErrorMessage(sprintf( t('Bookmark with identifier %s could not be found.'), @@ -164,16 +164,16 @@ public function pinBookmark(Request $request, Response $response, array $args): return $this->redirectFromReferer($request, $response, ['/pin'], ['pin']); } - $formatter = $this->container->formatterFactory->getFormatter('raw'); + $formatter = $this->container->get('formatterFactory')->getFormatter('raw'); $bookmark->setSticky(!$bookmark->isSticky()); // To preserve backward compatibility with 3rd parties, plugins still use arrays $data = $formatter->format($bookmark); $this->executePageHooks('save_link', $data); - $bookmark->fromArray($data, $this->container->conf->get('general.tags_separator', ' ')); + $bookmark->fromArray($data, $this->container->get('conf')->get('general.tags_separator', ' ')); - $this->container->bookmarkService->set($bookmark); + $this->container->get('bookmarkService')->set($bookmark); return $this->redirectFromReferer($request, $response, ['/pin'], ['pin']); } @@ -186,7 +186,7 @@ public function sharePrivate(Request $request, Response $response, array $args): $this->checkToken($request); $hash = $args['hash'] ?? ''; - $bookmark = $this->container->bookmarkService->findByHash($hash); + $bookmark = $this->container->get('bookmarkService')->findByHash($hash); if ($bookmark->isPrivate() !== true) { return $this->redirect($response, '/shaare/' . $hash); @@ -195,7 +195,7 @@ public function sharePrivate(Request $request, Response $response, array $args): if (empty($bookmark->getAdditionalContentEntry('private_key'))) { $privateKey = bin2hex(random_bytes(16)); $bookmark->setAdditionalContentEntry('private_key', $privateKey); - $this->container->bookmarkService->set($bookmark); + $this->container->get('bookmarkService')->set($bookmark); } return $this->redirect( @@ -213,7 +213,7 @@ public function addOrDeleteTags(Request $request, Response $response): Response { $this->checkToken($request); - $ids = trim(escape($request->getParam('id') ?? '')); + $ids = trim(escape($request->getParsedBody()['id'] ?? '')); if (empty($ids) || strpos($ids, ' ') !== false) { // multiple, space-separated ids provided $ids = array_values(array_filter(preg_split('/\s+/', $ids), 'ctype_digit')); @@ -230,7 +230,7 @@ public function addOrDeleteTags(Request $request, Response $response): Response } // assert that the action is valid - $action = $request->getParam('action'); + $action = $request->getParsedBody()['action'] ?? null; if (!in_array($action, ['add', 'delete'], true)) { $this->saveErrorMessage(t('Invalid action provided.')); @@ -238,20 +238,20 @@ public function addOrDeleteTags(Request $request, Response $response): Response } // assert that the tag name is valid - $tagString = trim($request->getParam('tag')); + $tagString = trim($request->getParsedBody()['tag'] ?? null); if (empty($tagString)) { $this->saveErrorMessage(t('Invalid tag name provided.')); return $this->redirectFromReferer($request, $response, ['/updateTag'], []); } - $tags = tags_str2array($tagString, $this->container->conf->get('general.tags_separator', ' ')); - $formatter = $this->container->formatterFactory->getFormatter('raw'); + $tags = tags_str2array($tagString, $this->container->get('conf')->get('general.tags_separator', ' ')); + $formatter = $this->container->get('formatterFactory')->getFormatter('raw'); $count = 0; foreach ($ids as $id) { try { - $bookmark = $this->container->bookmarkService->get((int) $id); + $bookmark = $this->container->get('bookmarkService')->get((int) $id); } catch (BookmarkNotFoundException $e) { $this->saveErrorMessage(sprintf( t('Bookmark with identifier %s could not be found.'), @@ -272,14 +272,14 @@ public function addOrDeleteTags(Request $request, Response $response): Response // To preserve backward compatibility with 3rd parties, plugins still use arrays $data = $formatter->format($bookmark); $this->executePageHooks('save_link', $data); - $bookmark->fromArray($data, $this->container->conf->get('general.tags_separator', ' ')); + $bookmark->fromArray($data, $this->container->get('conf')->get('general.tags_separator', ' ')); - $this->container->bookmarkService->set($bookmark, false); + $this->container->get('bookmarkService')->set($bookmark, false); ++$count; } if ($count > 0) { - $this->container->bookmarkService->save(); + $this->container->get('bookmarkService')->save(); } return $this->redirectFromReferer($request, $response, ['/updateTag'], []); diff --git a/application/front/controller/admin/ShaarePublishController.php b/application/front/controller/admin/ShaarePublishController.php index fb9cacc22..232b21216 100644 --- a/application/front/controller/admin/ShaarePublishController.php +++ b/application/front/controller/admin/ShaarePublishController.php @@ -4,14 +4,14 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\Bookmark; use Shaarli\Bookmark\Exception\BookmarkNotFoundException; use Shaarli\Formatter\BookmarkFormatter; use Shaarli\Formatter\BookmarkMarkdownFormatter; use Shaarli\Render\TemplatePage; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; class ShaarePublishController extends ShaarliAdminController { @@ -31,10 +31,11 @@ class ShaarePublishController extends ShaarliAdminController */ public function displayCreateForm(Request $request, Response $response): Response { - $url = cleanup_url($request->getParam('post')); - $link = $this->buildLinkDataFromUrl($request, $url); + $url = cleanup_url($request->getQueryParams()['post'] ?? null); + $link = $this->buildLinkDataFromUrl($request->getQueryParams(), $url); + $soureParam = $request->getQueryParams()['source'] ?? null; - return $this->displayForm($link, $link['linkIsNew'], $request, $response); + return $this->displayForm($link, $link['linkIsNew'], $soureParam, $request, $response); } /** @@ -42,16 +43,21 @@ public function displayCreateForm(Request $request, Response $response): Respons */ public function displayCreateBatchForms(Request $request, Response $response): Response { - $urls = array_map('cleanup_url', explode(PHP_EOL, $request->getParam('urls'))); + $urls = array_map('cleanup_url', explode(PHP_EOL, $request->getParsedBody()['urls'] ?? null)); $links = []; foreach ($urls as $url) { if (empty($url)) { continue; } - $link = $this->buildLinkDataFromUrl($request, $url); - $data = $this->buildFormData($link, $link['linkIsNew'], $request); - $data['token'] = $this->container->sessionManager->generateToken(); + $link = $this->buildLinkDataFromUrl($request->getParsedBody(), $url); + $data = $this->buildFormData( + $link, + $link['linkIsNew'] ?? null, + $request->getParsedBody()['source'] ?? null, + $request + ); + $data['token'] = $this->container->get('sessionManager')->generateToken(); $data['source'] = 'batch'; $this->executePageHooks('render_editlink', $data, TemplatePage::EDIT_LINK); @@ -61,9 +67,9 @@ public function displayCreateBatchForms(Request $request, Response $response): R $this->assignView('links', $links); $this->assignView('batch_mode', true); - $this->assignView('async_metadata', $this->container->conf->get('general.enable_async_metadata', true)); + $this->assignView('async_metadata', $this->container->get('conf')->get('general.enable_async_metadata', true)); - return $response->write($this->render(TemplatePage::EDIT_LINK_BATCH)); + return $this->respondWithTemplate($response, TemplatePage::EDIT_LINK_BATCH); } /** @@ -76,7 +82,7 @@ public function displayEditForm(Request $request, Response $response, array $arg if (false === ctype_digit($id)) { throw new BookmarkNotFoundException(); } - $bookmark = $this->container->bookmarkService->get((int) $id); // Read database + $bookmark = $this->container->get('bookmarkService')->get((int) $id); // Read database } catch (BookmarkNotFoundException $e) { $this->saveErrorMessage(sprintf( t('Bookmark with identifier %s could not be found.'), @@ -88,8 +94,9 @@ public function displayEditForm(Request $request, Response $response, array $arg $formatter = $this->getFormatter('raw'); $link = $formatter->format($bookmark); + $soureParam = $request->getParsedBody()['source'] ?? ''; - return $this->displayForm($link, false, $request, $response); + return $this->displayForm($link, false, $soureParam, $request, $response); } /** @@ -100,50 +107,53 @@ public function save(Request $request, Response $response): Response $this->checkToken($request); // lf_id should only be present if the link exists. - $id = $request->getParam('lf_id') !== null ? intval(escape($request->getParam('lf_id'))) : null; - if (null !== $id && true === $this->container->bookmarkService->exists($id)) { + $id = ($request->getParsedBody()['lf_id'] ?? null) !== null ? + intval(escape($request->getParsedBody()['lf_id'] ?? null)) : null; + if (null !== $id && true === $this->container->get('bookmarkService')->exists($id)) { // Edit - $bookmark = $this->container->bookmarkService->get($id); + $bookmark = $this->container->get('bookmarkService')->get($id); } else { // New link $bookmark = new Bookmark(); } - $bookmark->setTitle($request->getParam('lf_title')); - $bookmark->setDescription($request->getParam('lf_description')); - $bookmark->setUrl($request->getParam('lf_url'), $this->container->conf->get('security.allowed_protocols', [])); - $bookmark->setPrivate(filter_var($request->getParam('lf_private'), FILTER_VALIDATE_BOOLEAN)); + $bookmark->setTitle($request->getParsedBody()['lf_title'] ?? null); + $bookmark->setDescription($request->getParsedBody()['lf_description'] ?? null); + $bookmark->setUrl($request->getParsedBody()['lf_url'] ?? null, $this->container->get('conf') + ->get('security.allowed_protocols', [])); + $bookmark->setPrivate(filter_var($request->getParsedBody()['lf_private'] ?? null, FILTER_VALIDATE_BOOLEAN)); $bookmark->setTagsString( - $request->getParam('lf_tags'), - $this->container->conf->get('general.tags_separator', ' ') + $request->getParsedBody()['lf_tags'] ?? null, + $this->container->get('conf')->get('general.tags_separator', ' ') ); if ( - $this->container->conf->get('thumbnails.mode', Thumbnailer::MODE_NONE) !== Thumbnailer::MODE_NONE - && true !== $this->container->conf->get('general.enable_async_metadata', true) + $this->container->get('conf')->get('thumbnails.mode', Thumbnailer::MODE_NONE) !== Thumbnailer::MODE_NONE + && true !== $this->container->get('conf')->get('general.enable_async_metadata', true) && $bookmark->shouldUpdateThumbnail() ) { - $bookmark->setThumbnail($this->container->thumbnailer->get($bookmark->getUrl())); + $bookmark->setThumbnail($this->container->get('thumbnailer')->get($bookmark->getUrl())); } - $this->container->bookmarkService->addOrSet($bookmark, false); + $this->container->get('bookmarkService')->addOrSet($bookmark, false); // To preserve backward compatibility with 3rd parties, plugins still use arrays $formatter = $this->getFormatter('raw'); $data = $formatter->format($bookmark); $this->executePageHooks('save_link', $data); - $bookmark->fromArray($data, $this->container->conf->get('general.tags_separator', ' ')); - $this->container->bookmarkService->set($bookmark); + $bookmark->fromArray($data, $this->container->get('conf')->get('general.tags_separator', ' ')); + $this->container->get('bookmarkService')->set($bookmark); // If we are called from the bookmarklet, we must close the popup: - if ($request->getParam('source') === 'bookmarklet') { - return $response->write(''); - } elseif ($request->getParam('source') === 'batch') { + if (($request->getParsedBody()['source'] ?? null) === 'bookmarklet') { + return $this->respondWithBody($response, ''); + } elseif (($request->getParsedBody()['source'] ?? null) === 'batch') { return $response; } - if (!empty($request->getParam('returnurl'))) { - $this->container->environment['HTTP_REFERER'] = $request->getParam('returnurl'); + $referer = null; + if (!empty($request->getParsedBody()['returnurl'] ?? null)) { + $referer = $request->getParsedBody()['returnurl'] ?? null; } return $this->redirectFromReferer( @@ -151,7 +161,8 @@ public function save(Request $request, Response $response): Response $response, ['/admin/add-shaare', '/admin/shaare'], ['addlink', 'post', 'edit_link'], - $bookmark->getShortUrl() + $bookmark->getShortUrl(), + $referer ); } @@ -160,9 +171,14 @@ public function save(Request $request, Response $response): Response * * @param array $link data used in template, either from parameters or from the data store */ - protected function displayForm(array $link, bool $isNew, Request $request, Response $response): Response - { - $data = $this->buildFormData($link, $isNew, $request); + protected function displayForm( + array $link, + bool $isNew, + ?string $sourceParam, + Request $request, + Response $response + ): Response { + $data = $this->buildFormData($link, $isNew, $sourceParam, $request); $this->executePageHooks('render_editlink', $data, TemplatePage::EDIT_LINK); @@ -173,39 +189,39 @@ protected function displayForm(array $link, bool $isNew, Request $request, Respo $editLabel = false === $isNew ? t('Edit') . ' ' : ''; $this->assignView( 'pagetitle', - $editLabel . t('Shaare') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + $editLabel . t('Shaare') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); - return $response->write($this->render(TemplatePage::EDIT_LINK)); + return $this->respondWithTemplate($response, TemplatePage::EDIT_LINK); } - protected function buildLinkDataFromUrl(Request $request, string $url): array + protected function buildLinkDataFromUrl(array $params, string $url): array { // Check if URL is not already in database (in this case, we will edit the existing link) - $bookmark = $this->container->bookmarkService->findByUrl($url); + $bookmark = $this->container->get('bookmarkService')->findByUrl($url); if (null === $bookmark) { // Get shaare data if it was provided in URL (e.g.: by the bookmarklet). - $title = $request->getParam('title'); - $description = $request->getParam('description'); - $tags = $request->getParam('tags'); - if ($request->getParam('private') !== null) { - $private = filter_var($request->getParam('private'), FILTER_VALIDATE_BOOLEAN); + $title = $params['title'] ?? null; + $description = $params['description'] ?? null; + $tags = $params['tags'] ?? null; + if (($params['private'] ?? null) !== null) { + $private = filter_var($params['private'], FILTER_VALIDATE_BOOLEAN); } else { - $private = $this->container->conf->get('privacy.default_private_links', false); + $private = $this->container->get('conf')->get('privacy.default_private_links', false); } // If this is an HTTP(S) link, we try go get the page to extract // the title (otherwise we will to straight to the edit form.) if ( - true !== $this->container->conf->get('general.enable_async_metadata', true) + true !== $this->container->get('conf')->get('general.enable_async_metadata', true) && empty($title) && strpos(get_url_scheme($url) ?: '', 'http') !== false ) { - $metadata = $this->container->metadataRetriever->retrieve($url); + $metadata = $this->container->get('metadataRetriever')->retrieve($url); } if (empty($url)) { - $metadata['title'] = $this->container->conf->get('general.default_note_title', t('Note: ')); + $metadata['title'] = $this->container->get('conf')->get('general.default_note_title', t('Note: ')); } return [ @@ -225,22 +241,22 @@ protected function buildLinkDataFromUrl(Request $request, string $url): array return $link; } - protected function buildFormData(array $link, bool $isNew, Request $request): array + protected function buildFormData(array $link, bool $isNew, ?string $sourceParam, Request $request): array { $link['tags'] = $link['tags'] !== null && strlen($link['tags']) > 0 - ? $link['tags'] . $this->container->conf->get('general.tags_separator', ' ') + ? $link['tags'] . $this->container->get('conf')->get('general.tags_separator', ' ') : $link['tags'] ; return escape([ 'link' => $link, 'link_is_new' => $isNew, - 'http_referer' => $this->container->environment['HTTP_REFERER'] ?? '', - 'source' => $request->getParam('source') ?? '', + 'http_referer' => $request->getServerParams()['HTTP_REFERER'] ?? '', + 'source' => $sourceParam ?? '', 'tags' => $this->getTags(), - 'default_private_links' => $this->container->conf->get('privacy.default_private_links', false), - 'async_metadata' => $this->container->conf->get('general.enable_async_metadata', true), - 'retrieve_description' => $this->container->conf->get('general.retrieve_description', false), + 'default_private_links' => $this->container->get('conf')->get('privacy.default_private_links', false), + 'async_metadata' => $this->container->get('conf')->get('general.enable_async_metadata', true), + 'retrieve_description' => $this->container->get('conf')->get('general.retrieve_description', false), ]); } @@ -250,7 +266,7 @@ protected function buildFormData(array $link, bool $isNew, Request $request): ar protected function getFormatter(string $type): BookmarkFormatter { if (!array_key_exists($type, $this->formatters) || $this->formatters[$type] === null) { - $this->formatters[$type] = $this->container->formatterFactory->getFormatter($type); + $this->formatters[$type] = $this->container->get('formatterFactory')->getFormatter($type); } return $this->formatters[$type]; @@ -262,9 +278,9 @@ protected function getFormatter(string $type): BookmarkFormatter protected function getTags(): array { if ($this->tags === null) { - $this->tags = $this->container->bookmarkService->bookmarksCountPerTag(); + $this->tags = $this->container->get('bookmarkService')->bookmarksCountPerTag(); - if ($this->container->conf->get('formatter') === 'markdown') { + if ($this->container->get('conf')->get('formatter') === 'markdown') { $this->tags[BookmarkMarkdownFormatter::NO_MD_TAG] = 1; } } diff --git a/application/front/controller/admin/ShaarliAdminController.php b/application/front/controller/admin/ShaarliAdminController.php index 35fd13946..c046524c4 100644 --- a/application/front/controller/admin/ShaarliAdminController.php +++ b/application/front/controller/admin/ShaarliAdminController.php @@ -4,10 +4,10 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Controller\Visitor\ShaarliVisitorController; use Shaarli\Front\Exception\WrongTokenException; use Shaarli\Security\SessionManager; -use Slim\Http\Request; /** * Class ShaarliAdminController @@ -25,7 +25,8 @@ abstract class ShaarliAdminController extends ShaarliVisitorController */ protected function checkToken(Request $request): bool { - if (!$this->container->sessionManager->checkToken($request->getParam('token'))) { + $token = $request->getParsedBody()['token'] ?? $request->getQueryParams()['token'] ?? null; + if (!$this->container->get('sessionManager')->checkToken($token)) { throw new WrongTokenException(); } @@ -63,9 +64,9 @@ protected function saveErrorMessage(string $message): void */ protected function saveMessage(string $type, string $message): void { - $messages = $this->container->sessionManager->getSessionParameter($type) ?? []; + $messages = $this->container->get('sessionManager')->getSessionParameter($type) ?? []; $messages[] = $message; - $this->container->sessionManager->setSessionParameter($type, $messages); + $this->container->get('sessionManager')->setSessionParameter($type, $messages); } } diff --git a/application/front/controller/admin/ThumbnailsController.php b/application/front/controller/admin/ThumbnailsController.php index 665dfd03e..bd2d664cf 100644 --- a/application/front/controller/admin/ThumbnailsController.php +++ b/application/front/controller/admin/ThumbnailsController.php @@ -4,10 +4,10 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\Exception\BookmarkNotFoundException; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class ToolsController @@ -22,7 +22,7 @@ class ThumbnailsController extends ShaarliAdminController public function index(Request $request, Response $response): Response { $ids = []; - foreach ($this->container->bookmarkService->search()->getBookmarks() as $bookmark) { + foreach ($this->container->get('bookmarkService')->search()->getBookmarks() as $bookmark) { // A note or not HTTP(S) if ($bookmark->isNote() || !startsWith(strtolower($bookmark->getUrl()), 'http')) { continue; @@ -34,10 +34,10 @@ public function index(Request $request, Response $response): Response $this->assignView('ids', $ids); $this->assignView( 'pagetitle', - t('Thumbnails update') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + t('Thumbnails update') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); - return $response->write($this->render(TemplatePage::THUMBNAILS)); + return $this->respondWithTemplate($response, TemplatePage::THUMBNAILS); } /** @@ -52,14 +52,17 @@ public function ajaxUpdate(Request $request, Response $response, array $args): R } try { - $bookmark = $this->container->bookmarkService->get((int) $id); + $bookmark = $this->container->get('bookmarkService')->get((int) $id); } catch (BookmarkNotFoundException $e) { return $response->withStatus(404); } - $bookmark->setThumbnail($this->container->thumbnailer->get($bookmark->getUrl())); - $this->container->bookmarkService->set($bookmark); + $bookmark->setThumbnail($this->container->get('thumbnailer')->get($bookmark->getUrl())); + $this->container->get('bookmarkService')->set($bookmark); - return $response->withJson($this->container->formatterFactory->getFormatter('raw')->format($bookmark)); + return $this->respondWithJson( + $response, + $this->container->get('formatterFactory')->getFormatter('raw')->format($bookmark) + ); } } diff --git a/application/front/controller/admin/TokenController.php b/application/front/controller/admin/TokenController.php index 08d68d0a1..c73784c4f 100644 --- a/application/front/controller/admin/TokenController.php +++ b/application/front/controller/admin/TokenController.php @@ -4,8 +4,8 @@ namespace Shaarli\Front\Controller\Admin; -use Slim\Http\Request; -use Slim\Http\Response; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; /** * Class TokenController @@ -21,6 +21,6 @@ public function getToken(Request $request, Response $response): Response { $response = $response->withHeader('Content-Type', 'text/plain'); - return $response->write($this->container->sessionManager->generateToken()); + return $this->respondWithBody($response, $this->container->get('sessionManager')->generateToken()); } } diff --git a/application/front/controller/admin/ToolsController.php b/application/front/controller/admin/ToolsController.php index 560e5e3e7..16d2bc690 100644 --- a/application/front/controller/admin/ToolsController.php +++ b/application/front/controller/admin/ToolsController.php @@ -4,9 +4,9 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class ToolsController @@ -18,8 +18,8 @@ class ToolsController extends ShaarliAdminController public function index(Request $request, Response $response): Response { $data = [ - 'pageabsaddr' => index_url($this->container->environment), - 'sslenabled' => is_https($this->container->environment), + 'pageabsaddr' => index_url($request->getServerParams()), + 'sslenabled' => is_https($request->getServerParams()), ]; $this->executePageHooks('render_tools', $data, TemplatePage::TOOLS); @@ -28,8 +28,11 @@ public function index(Request $request, Response $response): Response $this->assignView($key, $value); } - $this->assignView('pagetitle', t('Tools') . ' - ' . $this->container->conf->get('general.title', 'Shaarli')); + $this->assignView( + 'pagetitle', + t('Tools') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') + ); - return $response->write($this->render(TemplatePage::TOOLS)); + return $this->respondWithTemplate($response, TemplatePage::TOOLS); } } diff --git a/application/front/controller/visitor/BookmarkListController.php b/application/front/controller/visitor/BookmarkListController.php index 4aae26528..03c642c66 100644 --- a/application/front/controller/visitor/BookmarkListController.php +++ b/application/front/controller/visitor/BookmarkListController.php @@ -4,14 +4,14 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\Bookmark; use Shaarli\Bookmark\Exception\BookmarkNotFoundException; use Shaarli\Legacy\LegacyController; use Shaarli\Legacy\UnknowLegacyRouteException; use Shaarli\Render\TemplatePage; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class BookmarkListController @@ -31,30 +31,30 @@ public function index(Request $request, Response $response): Response return $legacyResponse; } - $formatter = $this->container->formatterFactory->getFormatter(); - $formatter->addContextData('base_path', $this->container->basePath); - $formatter->addContextData('index_url', index_url($this->container->environment)); + $formatter = $this->container->get('formatterFactory')->getFormatter(); + $formatter->addContextData('base_path', $this->container->get('basePath')); + $formatter->addContextData('index_url', index_url($request->getServerParams())); - $searchTags = normalize_spaces($request->getParam('searchtags') ?? ''); - $searchTerm = escape(normalize_spaces($request->getParam('searchterm') ?? '')); + $searchTags = normalize_spaces($request->getQueryParams()['searchtags'] ?? ''); + $searchTerm = escape(normalize_spaces($request->getQueryParams()['searchterm'] ?? '')); // Filter bookmarks according search parameters. - $visibility = $this->container->sessionManager->getSessionParameter('visibility'); + $visibility = $this->container->get('sessionManager')->getSessionParameter('visibility'); $search = [ 'searchtags' => $searchTags, 'searchterm' => $searchTerm, ]; // Select articles according to paging. - $page = (int) ($request->getParam('page') ?? 1); + $page = (int) ($request->getQueryParams()['page'] ?? 1); $page = $page < 1 ? 1 : $page; - $linksPerPage = $this->container->sessionManager->getSessionParameter('LINKS_PER_PAGE', 20) ?: 20; + $linksPerPage = $this->container->get('sessionManager')->getSessionParameter('LINKS_PER_PAGE', 20) ?: 20; - $searchResult = $this->container->bookmarkService->search( + $searchResult = $this->container->get('bookmarkService')->search( $search, $visibility, false, - !!$this->container->sessionManager->getSessionParameter('untaggedonly'), + !!$this->container->get('sessionManager')->getSessionParameter('untaggedonly'), false, ['offset' => $linksPerPage * ($page - 1), 'limit' => $linksPerPage] ) ?? []; @@ -67,7 +67,7 @@ public function index(Request $request, Response $response): Response } if ($save) { - $this->container->bookmarkService->save(); + $this->container->get('bookmarkService')->save(); } // Compute paging navigation @@ -78,7 +78,7 @@ public function index(Request $request, Response $response): Response $previousPageUrl = !$searchResult->isLastPage() ? '?page=' . ($page + 1) . $searchtermUrl . $searchtagsUrl : ''; $nextPageUrl = !$searchResult->isFirstPage() ? '?page=' . ($page - 1) . $searchtermUrl . $searchtagsUrl : ''; - $tagsSeparator = $this->container->conf->get('general.tags_separator', ' '); + $tagsSeparator = $this->container->get('conf')->get('general.tags_separator', ' '); $searchTagsUrlEncoded = array_map('urlencode', tags_str2array($searchTags, $tagsSeparator)); $searchTags = !empty($searchTags) ? trim($searchTags, $tagsSeparator) . $tagsSeparator : ''; @@ -112,12 +112,12 @@ public function index(Request $request, Response $response): Response $data['pagetitle'] .= '- '; } - $data['pagetitle'] = ($data['pagetitle'] ?? '') . $this->container->conf->get('general.title', 'Shaarli'); + $data['pagetitle'] = ($data['pagetitle'] ?? '') . $this->container->get('conf')->get('general.title', 'Shaarli'); $this->executePageHooks('render_linklist', $data, TemplatePage::LINKLIST); $this->assignAllView($data); - return $response->write($this->render(TemplatePage::LINKLIST)); + return $this->respondWithTemplate($response, TemplatePage::LINKLIST); } /** @@ -125,26 +125,26 @@ public function index(Request $request, Response $response): Response */ public function permalink(Request $request, Response $response, array $args): Response { - $privateKey = $request->getParam('key'); + $privateKey = $request->getQueryParams()['key'] ?? null; try { - $bookmark = $this->container->bookmarkService->findByHash($args['hash'], $privateKey); + $bookmark = $this->container->get('bookmarkService')->findByHash($args['hash'], $privateKey); } catch (BookmarkNotFoundException $e) { $this->assignView('error_message', $e->getMessage()); - return $response->write($this->render(TemplatePage::ERROR_404)); + return $this->respondWithTemplate($response, TemplatePage::ERROR_404); } $this->updateThumbnail($bookmark); - $formatter = $this->container->formatterFactory->getFormatter(); - $formatter->addContextData('base_path', $this->container->basePath); - $formatter->addContextData('index_url', index_url($this->container->environment)); + $formatter = $this->container->get('formatterFactory')->getFormatter(); + $formatter->addContextData('base_path', $this->container->get('basePath')); + $formatter->addContextData('index_url', index_url($request->getServerParams())); $data = array_merge( $this->initializeTemplateVars(), [ - 'pagetitle' => $bookmark->getTitle() . ' - ' . $this->container->conf->get('general.title', 'Shaarli'), + 'pagetitle' => $bookmark->getTitle() . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli'), 'links' => [$formatter->format($bookmark)], ] ); @@ -152,7 +152,7 @@ public function permalink(Request $request, Response $response, array $args): Re $this->executePageHooks('render_linklist', $data, TemplatePage::LINKLIST); $this->assignAllView($data); - return $response->write($this->render(TemplatePage::LINKLIST)); + return $this->respondWithTemplate($response, TemplatePage::LINKLIST); } /** @@ -160,7 +160,7 @@ public function permalink(Request $request, Response $response, array $args): Re */ protected function updateThumbnail(Bookmark $bookmark, bool $writeDatastore = true): bool { - if (false === $this->container->loginManager->isLoggedIn()) { + if (false === $this->container->get('loginManager')->isLoggedIn()) { return false; } @@ -171,11 +171,11 @@ protected function updateThumbnail(Bookmark $bookmark, bool $writeDatastore = tr // Requires an update, not async retrieval, thumbnails enabled if ( $bookmark->shouldUpdateThumbnail() - && true !== $this->container->conf->get('general.enable_async_metadata', true) - && $this->container->conf->get('thumbnails.mode', Thumbnailer::MODE_NONE) !== Thumbnailer::MODE_NONE + && true !== $this->container->get('conf')->get('general.enable_async_metadata', true) + && $this->container->get('conf')->get('thumbnails.mode', Thumbnailer::MODE_NONE) !== Thumbnailer::MODE_NONE ) { - $bookmark->setThumbnail($this->container->thumbnailer->get($bookmark->getUrl())); - $this->container->bookmarkService->set($bookmark, $writeDatastore); + $bookmark->setThumbnail($this->container->get('thumbnailer')->get($bookmark->getUrl())); + $this->container->get('bookmarkService')->set($bookmark, $writeDatastore); return true; } @@ -195,7 +195,7 @@ protected function initializeTemplateVars(): array 'page_max' => '', 'search_tags' => '', 'result_count' => '', - 'async_metadata' => $this->container->conf->get('general.enable_async_metadata', true) + 'async_metadata' => $this->container->get('conf')->get('general.enable_async_metadata', true) ]; } @@ -206,17 +206,17 @@ protected function initializeTemplateVars(): array protected function processLegacyController(Request $request, Response $response): ?Response { // Legacy smallhash filter - $queryString = $this->container->environment['QUERY_STRING'] ?? null; + $queryString = $request->getServerParams()['QUERY_STRING'] ?? null; if (null !== $queryString && 1 === preg_match('/^([a-zA-Z0-9-_@]{6})($|&|#)/', $queryString, $match)) { return $this->redirect($response, '/shaare/' . $match[1]); } // Legacy controllers (mostly used for redirections) - if (null !== $request->getQueryParam('do')) { + if (null !== ($request->getQueryParams()['do'] ?? null)) { $legacyController = new LegacyController($this->container); try { - return $legacyController->process($request, $response, $request->getQueryParam('do')); + return $legacyController->process($request, $response, $request->getQueryParams()['do'] ?? null); } catch (UnknowLegacyRouteException $e) { // We ignore legacy 404 return null; diff --git a/application/front/controller/visitor/DailyController.php b/application/front/controller/visitor/DailyController.php index 3739ec168..a43c49af8 100644 --- a/application/front/controller/visitor/DailyController.php +++ b/application/front/controller/visitor/DailyController.php @@ -5,11 +5,11 @@ namespace Shaarli\Front\Controller\Visitor; use DateTime; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\Bookmark; use Shaarli\Helper\DailyPageHelper; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class DailyController @@ -27,22 +27,27 @@ class DailyController extends ShaarliVisitorController public function index(Request $request, Response $response): Response { $type = DailyPageHelper::extractRequestedType($request); + $format = DailyPageHelper::getFormatByType($type); - $latestBookmark = $this->container->bookmarkService->getLatest(); - $dateTime = DailyPageHelper::extractRequestedDateTime($type, $request->getQueryParam($type), $latestBookmark); + $latestBookmark = $this->container->get('bookmarkService')->getLatest(); + $dateTime = DailyPageHelper::extractRequestedDateTime( + $type, + $request->getQueryParams()[$type] ?? null, + $latestBookmark + ); $start = DailyPageHelper::getStartDateTimeByType($type, $dateTime); $end = DailyPageHelper::getEndDateTimeByType($type, $dateTime); $dailyDesc = DailyPageHelper::getDescriptionByType($type, $dateTime); - $linksToDisplay = $this->container->bookmarkService->findByDate( + $linksToDisplay = $this->container->get('bookmarkService')->findByDate( $start, $end, $previousDay, $nextDay ); - $formatter = $this->container->formatterFactory->getFormatter(); - $formatter->addContextData('base_path', $this->container->basePath); + $formatter = $this->container->get('formatterFactory')->getFormatter(); + $formatter->addContextData('base_path', $this->container->get('basePath')); // We pre-format some fields for proper output. foreach ($linksToDisplay as $key => $bookmark) { $linksToDisplay[$key] = $formatter->format($bookmark); @@ -69,13 +74,13 @@ public function index(Request $request, Response $response): Response $this->assignAllView($data); - $mainTitle = $this->container->conf->get('general.title', 'Shaarli'); + $mainTitle = $this->container->get('conf')->get('general.title', 'Shaarli'); $this->assignView( 'pagetitle', $data['localizedType'] . ' - ' . $data['dayDesc'] . ' - ' . $mainTitle ); - return $response->write($this->render(TemplatePage::DAILY)); + return $this->respondWithTemplate($response, TemplatePage::DAILY); } /** @@ -89,18 +94,18 @@ public function rss(Request $request, Response $response): Response $type = DailyPageHelper::extractRequestedType($request); $cacheDuration = DailyPageHelper::getCacheDatePeriodByType($type); - $pageUrl = page_url($this->container->environment); - $cache = $this->container->pageCacheManager->getCachePage($pageUrl, $cacheDuration); + $pageUrl = page_url($request->getServerParams()); + $cache = $this->container->get('pageCacheManager')->getCachePage($pageUrl, $cacheDuration); $cached = $cache->cachedVersion(); if (!empty($cached)) { - return $response->write($cached); + return $this->respondWithBody($response, $cached); } $days = []; $format = DailyPageHelper::getFormatByType($type); $length = DailyPageHelper::getRssLengthByType($type); - foreach ($this->container->bookmarkService->search()->getBookmarks() as $bookmark) { + foreach ($this->container->get('bookmarkService')->search()->getBookmarks() as $bookmark) { $day = $bookmark->getCreated()->format($format); // Stop iterating after DAILY_RSS_NB_DAYS entries @@ -112,9 +117,9 @@ public function rss(Request $request, Response $response): Response } // Build the RSS feed. - $indexUrl = escape(index_url($this->container->environment)); + $indexUrl = escape(index_url($request->getServerParams())); - $formatter = $this->container->formatterFactory->getFormatter(); + $formatter = $this->container->get('formatterFactory')->getFormatter(); $formatter->addContextData('index_url', $indexUrl); $dataPerDay = []; @@ -148,10 +153,10 @@ public function rss(Request $request, Response $response): Response } $this->assignAllView([ - 'title' => $this->container->conf->get('general.title', 'Shaarli'), + 'title' => $this->container->get('conf')->get('general.title', 'Shaarli'), 'index_url' => $indexUrl, 'page_url' => $pageUrl, - 'hide_timestamps' => $this->container->conf->get('privacy.hide_timestamps', false), + 'hide_timestamps' => $this->container->get('conf')->get('privacy.hide_timestamps', false), 'days' => $dataPerDay, 'type' => $type, 'localizedType' => $this->translateType($type), @@ -161,7 +166,7 @@ public function rss(Request $request, Response $response): Response $cache->cache($rssContent); - return $response->write($rssContent); + return $this->respondWithBody($response, $rssContent); } /** diff --git a/application/front/controller/visitor/ErrorController.php b/application/front/controller/visitor/ErrorController.php index 428e82542..d3dde12fd 100644 --- a/application/front/controller/visitor/ErrorController.php +++ b/application/front/controller/visitor/ErrorController.php @@ -4,9 +4,10 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Exception\ShaarliFrontException; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Render\TemplatePage; /** * Controller used to render the error page, with a provided exception. @@ -17,7 +18,7 @@ class ErrorController extends ShaarliVisitorController public function __invoke(Request $request, Response $response, \Throwable $throwable): Response { // Unknown error encountered - $this->container->pageBuilder->reset(); + $this->container->get('pageBuilder')->reset(); if ($throwable instanceof ShaarliFrontException) { // Functional error @@ -26,7 +27,10 @@ public function __invoke(Request $request, Response $response, \Throwable $throw $response = $response->withStatus($throwable->getCode()); } else { // Internal error (any other Throwable) - if ($this->container->conf->get('dev.debug', false) || $this->container->loginManager->isLoggedIn()) { + if ( + $this->container->get('conf')->get('dev.debug', false) || + $this->container->get('loginManager')->isLoggedIn() + ) { $this->assignView('message', t('Error: ') . $throwable->getMessage()); $this->assignView( 'text', @@ -42,6 +46,6 @@ public function __invoke(Request $request, Response $response, \Throwable $throw $response = $response->withStatus(500); } - return $response->write($this->render('error')); + return $this->respondWithTemplate($response, TemplatePage::ERROR); } } diff --git a/application/front/controller/visitor/ErrorNotFoundController.php b/application/front/controller/visitor/ErrorNotFoundController.php index 758dd83ba..7fd30916d 100644 --- a/application/front/controller/visitor/ErrorNotFoundController.php +++ b/application/front/controller/visitor/ErrorNotFoundController.php @@ -4,8 +4,11 @@ namespace Shaarli\Front\Controller\Visitor; -use Slim\Http\Request; -use Slim\Http\Response; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; +use Shaarli\Render\TemplatePage; +use Slim\Psr7\Response as SlimResponse; +use Slim\Routing\RouteContext; /** * Controller used to render the 404 error page. @@ -14,16 +17,19 @@ class ErrorNotFoundController extends ShaarliVisitorController { public function __invoke(Request $request, Response $response): Response { + $response = new SlimResponse(); // Request from the API if (false !== strpos($request->getRequestTarget(), '/api/v1')) { return $response->withStatus(404); } + $basePathFromRequest = $request->getAttribute(RouteContext::BASE_PATH); // This is required because the middleware is ignored if the route is not found. - $this->container->basePath = rtrim($request->getUri()->getBasePath(), '/'); + $this->container->set('basePath', rtrim($basePathFromRequest, '/')); $this->assignView('error_message', t('Requested page could not be found.')); - return $response->withStatus(404)->write($this->render('404')); + $response = $response->withStatus(404); + return $this->respondWithTemplate($response, TemplatePage::ERROR_404); } } diff --git a/application/front/controller/visitor/FeedController.php b/application/front/controller/visitor/FeedController.php index edc7ef43a..622fe767e 100644 --- a/application/front/controller/visitor/FeedController.php +++ b/application/front/controller/visitor/FeedController.php @@ -4,9 +4,9 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Feed\FeedBuilder; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class FeedController @@ -29,22 +29,25 @@ protected function processRequest(string $feedType, Request $request, Response $ { $response = $response->withHeader('Content-Type', 'application/' . $feedType . '+xml; charset=utf-8'); - $pageUrl = page_url($this->container->environment); - $cache = $this->container->pageCacheManager->getCachePage($pageUrl); + $pageUrl = page_url($request->getServerParams()); + $cache = $this->container->get('pageCacheManager')->getCachePage($pageUrl); $cached = $cache->cachedVersion(); if (!empty($cached)) { - return $response->write($cached); + return $this->respondWithBody($response, $cached); } // Generate data. - $this->container->feedBuilder->setLocale(strtolower(setlocale(LC_COLLATE, 0))); - $this->container->feedBuilder->setHideDates($this->container->conf->get('privacy.hide_timestamps', false)); - $this->container->feedBuilder->setUsePermalinks( - null !== $request->getParam('permalinks') || !$this->container->conf->get('feed.rss_permalinks') + $this->container->get('feedBuilder')->setLocale(strtolower(setlocale(LC_COLLATE, 0))); + $this->container->get('feedBuilder')->setHideDates($this->container->get('conf') + ->get('privacy.hide_timestamps', false)); + $this->container->get('feedBuilder')->setUsePermalinks( + null !== ($request->getQueryParams()['permalinks'] ?? null) + || !$this->container->get('conf')->get('feed.rss_permalinks') ); - $data = $this->container->feedBuilder->buildData($feedType, $request->getParams()); + $data = $this->container->get('feedBuilder') + ->buildData($feedType, $request->getQueryParams(), $request->getServerParams()); $this->executePageHooks('render_feed', $data, 'feed.' . $feedType); $this->assignAllView($data); @@ -53,6 +56,6 @@ protected function processRequest(string $feedType, Request $request, Response $ $cache->cache($content); - return $response->write($content); + return $this->respondWithBody($response, $content); } } diff --git a/application/front/controller/visitor/InstallController.php b/application/front/controller/visitor/InstallController.php index 6ffeb2dbd..59cb01512 100644 --- a/application/front/controller/visitor/InstallController.php +++ b/application/front/controller/visitor/InstallController.php @@ -4,14 +4,15 @@ namespace Shaarli\Front\Controller\Visitor; -use Shaarli\Container\ShaarliContainer; +use Psr\Container\ContainerInterface as Container; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Exception\AlreadyInstalledException; use Shaarli\Front\Exception\ResourcePermissionException; use Shaarli\Helper\ApplicationUtils; use Shaarli\Languages; +use Shaarli\Render\TemplatePage; use Shaarli\Security\SessionManager; -use Slim\Http\Request; -use Slim\Http\Response; /** * Slim controller used to render install page, and create initial configuration file. @@ -21,11 +22,11 @@ class InstallController extends ShaarliVisitorController public const SESSION_TEST_KEY = 'session_tested'; public const SESSION_TEST_VALUE = 'Working'; - public function __construct(ShaarliContainer $container) + public function __construct(Container $container) { parent::__construct($container); - if (is_file($this->container->conf->getConfigFileExt())) { + if (is_file($this->container->get('conf')->getConfigFileExt())) { throw new AlreadyInstalledException(); } } @@ -41,9 +42,9 @@ public function index(Request $request, Response $response): Response if ( static::SESSION_TEST_VALUE - !== $this->container->sessionManager->getSessionParameter(static::SESSION_TEST_KEY) + !== $this->container->get('sessionManager')->getSessionParameter(static::SESSION_TEST_KEY) ) { - $this->container->sessionManager->setSessionParameter(static::SESSION_TEST_KEY, static::SESSION_TEST_VALUE); + $this->container->get('sessionManager')->setSessionParameter(static::SESSION_TEST_KEY, static::SESSION_TEST_VALUE); return $this->redirect($response, '/install/session-test'); } @@ -57,7 +58,7 @@ public function index(Request $request, Response $response): Response $phpEol = new \DateTimeImmutable(ApplicationUtils::getPhpEol(PHP_VERSION)); $permissions = array_merge( - ApplicationUtils::checkResourcePermissions($this->container->conf), + ApplicationUtils::checkResourcePermissions($this->container->get('conf')), ApplicationUtils::checkDatastoreMutex() ); @@ -69,7 +70,7 @@ public function index(Request $request, Response $response): Response $this->assignView('pagetitle', t('Install Shaarli')); - return $response->write($this->render('install')); + return $this->respondWithTemplate($response, TemplatePage::INSTALL); } /** @@ -83,7 +84,7 @@ public function sessionTest(Request $request, Response $response): Response // or we may not have write access to it.) if ( static::SESSION_TEST_VALUE - !== $this->container->sessionManager->getSessionParameter(static::SESSION_TEST_KEY) + !== $this->container->get('sessionManager')->getSessionParameter(static::SESSION_TEST_KEY) ) { // Step 2: Check if data in session is correct. $msg = t( @@ -95,11 +96,11 @@ public function sessionTest(Request $request, Response $response): Response 'or any custom hostname without a dot causes cookie storage to fail. ' . 'We recommend accessing your server via it\'s IP address or Fully Qualified Domain Name.
' ); - $msg = sprintf($msg, $this->container->sessionManager->getSavePath()); + $msg = sprintf($msg, $this->container->get('sessionManager')->getSavePath()); $this->assignView('message', $msg); - return $response->write($this->render('error')); + return $this->respondWithTemplate($response, TemplatePage::ERROR); } return $this->redirect($response, '/install'); @@ -112,52 +113,58 @@ public function save(Request $request, Response $response): Response { $timezone = 'UTC'; if ( - !empty($request->getParam('continent')) - && !empty($request->getParam('city')) - && isTimeZoneValid($request->getParam('continent'), $request->getParam('city')) + !empty($request->getParsedBody()['continent'] ?? null) + && !empty($request->getParsedBody()['city'] ?? null) + && isTimeZoneValid( + $request->getParsedBody()['continent'] ?? null, + $request->getParsedBody()['city'] ?? null + ) ) { - $timezone = $request->getParam('continent') . '/' . $request->getParam('city'); + $timezone = $request->getParsedBody()['continent'] . '/' . $request->getParsedBody()['city']; } - $this->container->conf->set('general.timezone', $timezone); + $this->container->get('conf')->set('general.timezone', $timezone); - $login = $request->getParam('setlogin'); - $this->container->conf->set('credentials.login', $login); + $login = $request->getParsedBody()['setlogin'] ?? null; + $this->container->get('conf')->set('credentials.login', $login); $salt = sha1(uniqid('', true) . '_' . mt_rand()); - $this->container->conf->set('credentials.salt', $salt); - $this->container->conf->set('credentials.hash', sha1($request->getParam('setpassword') . $login . $salt)); + $this->container->get('conf')->set('credentials.salt', $salt); + $this->container->get('conf') + ->set('credentials.hash', sha1(($request->getParsedBody()['setpassword'] ?? null) . $login . $salt)); - if (!empty($request->getParam('title'))) { - $this->container->conf->set('general.title', escape($request->getParam('title'))); + if (!empty($request->getParsedBody()['title'] ?? null)) { + $this->container->get('conf')->set('general.title', escape($request->getParsedBody()['title'] ?? null)); } else { - $this->container->conf->set( + $this->container->get('conf')->set( 'general.title', t('Shared Bookmarks') ); } - $this->container->conf->set('translation.language', escape($request->getParam('language'))); - $this->container->conf->set('updates.check_updates', !empty($request->getParam('updateCheck'))); - $this->container->conf->set('api.enabled', !empty($request->getParam('enableApi'))); - $this->container->conf->set( + $this->container->get('conf') + ->set('translation.language', escape($request->getParsedBody()['language'] ?? null)); + $this->container->get('conf') + ->set('updates.check_updates', !empty($request->getParsedBody()['updateCheck'] ?? null)); + $this->container->get('conf')->set('api.enabled', !empty($request->getParsedBody()['enableApi'] ?? null)); + $this->container->get('conf')->set( 'api.secret', generate_api_secret( - $this->container->conf->get('credentials.login'), - $this->container->conf->get('credentials.salt') + $this->container->get('conf')->get('credentials.login'), + $this->container->get('conf')->get('credentials.salt') ) ); - $this->container->conf->set('general.header_link', $this->container->basePath . '/'); + $this->container->get('conf')->set('general.header_link', $this->container->get('basePath') . '/'); try { // Everything is ok, let's create config file. - $this->container->conf->write($this->container->loginManager->isLoggedIn()); + $this->container->get('conf')->write($this->container->get('loginManager')->isLoggedIn()); } catch (\Exception $e) { $this->assignView('message', t('Error while writing config file after configuration update.')); $this->assignView('stacktrace', $e->getMessage() . PHP_EOL . $e->getTraceAsString()); - return $response->write($this->render('error')); + return $this->respondWithTemplate($response, TemplatePage::ERROR); } - $this->container->sessionManager->setSessionParameter( + $this->container->get('sessionManager')->setSessionParameter( SessionManager::KEY_SUCCESS_MESSAGES, [t('Shaarli is now configured. Please login and start shaaring your bookmarks!')] ); @@ -168,7 +175,7 @@ public function save(Request $request, Response $response): Response protected function checkPermissions(): bool { // Ensure Shaarli has proper access to its resources - $errors = ApplicationUtils::checkResourcePermissions($this->container->conf, true); + $errors = ApplicationUtils::checkResourcePermissions($this->container->get('conf'), true); if (empty($errors)) { return true; } diff --git a/application/front/controller/visitor/LoginController.php b/application/front/controller/visitor/LoginController.php index 4b881535c..a62cc4200 100644 --- a/application/front/controller/visitor/LoginController.php +++ b/application/front/controller/visitor/LoginController.php @@ -4,14 +4,14 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Exception\CantLoginException; use Shaarli\Front\Exception\LoginBannedException; use Shaarli\Front\Exception\WrongTokenException; use Shaarli\Render\TemplatePage; use Shaarli\Security\CookieManager; use Shaarli\Security\SessionManager; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class LoginController @@ -29,24 +29,28 @@ class LoginController extends ShaarliVisitorController public function index(Request $request, Response $response): Response { try { - $this->checkLoginState(); + $this->checkLoginState($request->getServerParams()); } catch (CantLoginException $e) { return $this->redirect($response, '/'); } - if ($request->getParam('login') !== null) { - $this->assignView('username', escape($request->getParam('login'))); + if (($request->getQueryParams()['login'] ?? null) !== null) { + $this->assignView('username', escape($request->getQueryParams()['login'] ?? null)); } - $returnUrl = $request->getParam('returnurl') ?? $this->container->environment['HTTP_REFERER'] ?? null; + $returnUrl = $request->getQueryParams()['returnurl'] ?? $request->getServerParams()['HTTP_REFERER'] ?? null; - $this - ->assignView('returnurl', escape($returnUrl)) - ->assignView('remember_user_default', $this->container->conf->get('privacy.remember_user_default', true)) - ->assignView('pagetitle', t('Login') . ' - ' . $this->container->conf->get('general.title', 'Shaarli')) + $this->assignView('returnurl', escape($returnUrl)) + ->assignView( + 'remember_user_default', + $this->container->get('conf')->get('privacy.remember_user_default', true) + )->assignView( + 'pagetitle', + t('Login') . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') + ) ; - return $response->write($this->render(TemplatePage::LOGIN)); + return $this->respondWithTemplate($response, TemplatePage::LOGIN); } /** @@ -54,26 +58,26 @@ public function index(Request $request, Response $response): Response */ public function login(Request $request, Response $response): Response { - if (!$this->container->sessionManager->checkToken($request->getParam('token'))) { + if (!$this->container->get('sessionManager')->checkToken($request->getParsedBody()['token'] ?? null)) { throw new WrongTokenException(); } try { - $this->checkLoginState(); + $this->checkLoginState($request->getServerParams()); } catch (CantLoginException $e) { return $this->redirect($response, '/'); } if ( - !$this->container->loginManager->checkCredentials( - client_ip_id($this->container->environment), - $request->getParam('login'), - $request->getParam('password') + !$this->container->get('loginManager')->checkCredentials( + client_ip_id($request->getServerParams()), + $request->getParsedBody()['login'] ?? null, + $request->getParsedBody()['password'] ?? null ) ) { - $this->container->loginManager->handleFailedLogin($this->container->environment); + $this->container->get('loginManager')->handleFailedLogin($request->getServerParams()); - $this->container->sessionManager->setSessionParameter( + $this->container->get('sessionManager')->setSessionParameter( SessionManager::KEY_ERROR_MESSAGES, [t('Wrong login/password.')] ); @@ -82,16 +86,16 @@ public function login(Request $request, Response $response): Response return $this->index($request, $response); } - $this->container->loginManager->handleSuccessfulLogin($this->container->environment); + $this->container->get('loginManager')->handleSuccessfulLogin($request->getServerParams()); - $cookiePath = $this->container->basePath . '/'; + $cookiePath = $this->container->get('basePath') . '/'; $expirationTime = $this->saveLongLastingSession($request, $cookiePath); - $this->renewUserSession($cookiePath, $expirationTime); + $this->renewUserSession($request->getServerParams()['SERVER_NAME'] ?? null, $cookiePath, $expirationTime); // Force referer from given return URL - $this->container->environment['HTTP_REFERER'] = $request->getParam('returnurl'); + $referer = $request->getParsedBody()['returnurl'] ?? null; - return $this->redirectFromReferer($request, $response, ['login', 'install']); + return $this->redirectFromReferer($request, $response, ['login', 'install'], [], null, $referer); } /** @@ -100,16 +104,16 @@ public function login(Request $request, Response $response): Response * - not open shaarli * - not banned */ - protected function checkLoginState(): bool + protected function checkLoginState(array $serverParams): bool { if ( - $this->container->loginManager->isLoggedIn() - || $this->container->conf->get('security.open_shaarli', false) + $this->container->get('loginManager')->isLoggedIn() + || $this->container->get('conf')->get('security.open_shaarli', false) ) { throw new CantLoginException(); } - if (true !== $this->container->loginManager->canLogin($this->container->environment)) { + if (true !== $this->container->get('loginManager')->canLogin($serverParams)) { throw new LoginBannedException(); } @@ -121,18 +125,18 @@ protected function checkLoginState(): bool */ protected function saveLongLastingSession(Request $request, string $cookiePath): int { - if (empty($request->getParam('longlastingsession'))) { + if (empty($request->getParsedBody()['longlastingsession']) ?? null) { // Standard session expiration (=when browser closes) $expirationTime = 0; } else { // Keep the session cookie even after the browser closes - $this->container->sessionManager->setStaySignedIn(true); - $expirationTime = $this->container->sessionManager->extendSession(); + $this->container->get('sessionManager')->setStaySignedIn(true); + $expirationTime = $this->container->get('sessionManager')->extendSession(); } - $this->container->cookieManager->setCookieParameter( + $this->container->get('cookieManager')->setCookieParameter( CookieManager::STAY_SIGNED_IN, - $this->container->loginManager->getStaySignedInToken(), + $this->container->get('loginManager')->getStaySignedInToken(), $expirationTime, $cookiePath ); @@ -140,16 +144,16 @@ protected function saveLongLastingSession(Request $request, string $cookiePath): return $expirationTime; } - protected function renewUserSession(string $cookiePath, int $expirationTime): void + protected function renewUserSession(string $serverName, string $cookiePath, int $expirationTime): void { // Send cookie with the new expiration date to the browser - $this->container->sessionManager->destroy(); - $this->container->sessionManager->cookieParameters( + $this->container->get('sessionManager')->destroy(); + $this->container->get('sessionManager')->cookieParameters( $expirationTime, $cookiePath, - $this->container->environment['SERVER_NAME'] + $serverName ); - $this->container->sessionManager->start(); - $this->container->sessionManager->regenerateId(true); + $this->container->get('sessionManager')->start(); + $this->container->get('sessionManager')->regenerateId(true); } } diff --git a/application/front/controller/visitor/OpenSearchController.php b/application/front/controller/visitor/OpenSearchController.php index 36d60acf1..eb8840960 100644 --- a/application/front/controller/visitor/OpenSearchController.php +++ b/application/front/controller/visitor/OpenSearchController.php @@ -4,9 +4,9 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Render\TemplatePage; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class OpenSearchController @@ -20,8 +20,8 @@ public function index(Request $request, Response $response): Response { $response = $response->withHeader('Content-Type', 'application/opensearchdescription+xml; charset=utf-8'); - $this->assignView('serverurl', index_url($this->container->environment)); + $this->assignView('serverurl', index_url($request->getServerParams())); - return $response->write($this->render(TemplatePage::OPEN_SEARCH)); + return $this->respondWithTemplate($response, TemplatePage::OPEN_SEARCH); } } diff --git a/application/front/controller/visitor/PictureWallController.php b/application/front/controller/visitor/PictureWallController.php index 9c8f07d7a..8c9f026ed 100644 --- a/application/front/controller/visitor/PictureWallController.php +++ b/application/front/controller/visitor/PictureWallController.php @@ -4,11 +4,11 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Exception\ThumbnailsDisabledException; use Shaarli\Render\TemplatePage; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class PicturesWallController @@ -20,22 +20,20 @@ class PictureWallController extends ShaarliVisitorController { public function index(Request $request, Response $response): Response { - if ($this->container->conf->get('thumbnails.mode', Thumbnailer::MODE_NONE) === Thumbnailer::MODE_NONE) { + if ($this->container->get('conf')->get('thumbnails.mode', Thumbnailer::MODE_NONE) === Thumbnailer::MODE_NONE) { throw new ThumbnailsDisabledException(); } - $this->assignView( - 'pagetitle', - t('Picture wall') . ' - ' . $this->container->conf->get('general.title', 'Shaarli') - ); + $this->assignView('pagetitle', t('Picture wall') . ' - ' . $this->container->get('conf') + ->get('general.title', 'Shaarli')); // Optionally filter the results: - $bookmarks = $this->container->bookmarkService->search($request->getQueryParams())->getBookmarks(); + $bookmarks = $this->container->get('bookmarkService')->search($request->getQueryParams())->getBookmarks(); $links = []; // Get only bookmarks which have a thumbnail. // Note: we do not retrieve thumbnails here, the request is too heavy. - $formatter = $this->container->formatterFactory->getFormatter('raw'); + $formatter = $this->container->get('formatterFactory')->getFormatter('raw'); foreach ($bookmarks as $key => $bookmark) { if (!empty($bookmark->getThumbnail())) { $links[] = $formatter->format($bookmark); @@ -48,7 +46,6 @@ public function index(Request $request, Response $response): Response foreach ($data as $key => $value) { $this->assignView($key, $value); } - - return $response->write($this->render(TemplatePage::PICTURE_WALL)); + return $this->respondWithTemplate($response, TemplatePage::PICTURE_WALL); } } diff --git a/application/front/controller/visitor/PublicSessionFilterController.php b/application/front/controller/visitor/PublicSessionFilterController.php index 1a66362dc..f0bf0b669 100644 --- a/application/front/controller/visitor/PublicSessionFilterController.php +++ b/application/front/controller/visitor/PublicSessionFilterController.php @@ -4,9 +4,9 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Security\SessionManager; -use Slim\Http\Request; -use Slim\Http\Response; /** * Slim controller used to handle filters stored in the visitor session, links per page, etc. @@ -18,12 +18,12 @@ class PublicSessionFilterController extends ShaarliVisitorController */ public function linksPerPage(Request $request, Response $response): Response { - $linksPerPage = $request->getParam('nb') ?? null; + $linksPerPage = $request->getQueryParams()['nb'] ?? null; if (null === $linksPerPage || false === is_numeric($linksPerPage)) { - $linksPerPage = $this->container->conf->get('general.links_per_page', 20); + $linksPerPage = $this->container->get('conf')->get('general.links_per_page', 20); } - $this->container->sessionManager->setSessionParameter( + $this->container->get('sessionManager')->setSessionParameter( SessionManager::KEY_LINKS_PER_PAGE, abs(intval($linksPerPage)) ); @@ -36,9 +36,9 @@ public function linksPerPage(Request $request, Response $response): Response */ public function untaggedOnly(Request $request, Response $response): Response { - $this->container->sessionManager->setSessionParameter( + $this->container->get('sessionManager')->setSessionParameter( SessionManager::KEY_UNTAGGED_ONLY, - empty($this->container->sessionManager->getSessionParameter(SessionManager::KEY_UNTAGGED_ONLY)) + empty($this->container->get('sessionManager')->getSessionParameter(SessionManager::KEY_UNTAGGED_ONLY)) ); return $this->redirectFromReferer($request, $response, ['untaggedonly', 'untagged-only']); diff --git a/application/front/controller/visitor/ShaarliVisitorController.php b/application/front/controller/visitor/ShaarliVisitorController.php index d3f28f2f7..c1f0ed9ff 100644 --- a/application/front/controller/visitor/ShaarliVisitorController.php +++ b/application/front/controller/visitor/ShaarliVisitorController.php @@ -4,10 +4,10 @@ namespace Shaarli\Front\Controller\Visitor; +use DI\Container; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\BookmarkFilter; -use Shaarli\Container\ShaarliContainer; -use Slim\Http\Request; -use Slim\Http\Response; /** * Class ShaarliVisitorController @@ -19,11 +19,11 @@ */ abstract class ShaarliVisitorController { - /** @var ShaarliContainer */ + /** @var Container */ protected $container; - /** @param ShaarliContainer $container Slim container (extended for attribute completion). */ - public function __construct(ShaarliContainer $container) + /** @param Container $container Slim container (extended for attribute completion). */ + public function __construct(Container $container) { $this->container = $container; } @@ -35,7 +35,7 @@ public function __construct(ShaarliContainer $container) */ protected function assignView(string $name, $value): self { - $this->container->pageBuilder->assign($name, $value); + $this->container->get('pageBuilder')->assign($name, $value); return $this; } @@ -60,14 +60,15 @@ protected function render(string $template): string $this->assignView('_PAGE_', $template); $this->assignView('template', $template); - $this->assignView('linkcount', $this->container->bookmarkService->count(BookmarkFilter::$ALL)); - $this->assignView('privateLinkcount', $this->container->bookmarkService->count(BookmarkFilter::$PRIVATE)); + $this->assignView('linkcount', $this->container->get('bookmarkService')->count(BookmarkFilter::$ALL)); + $this->assignView('privateLinkcount', $this->container->get('bookmarkService') + ->count(BookmarkFilter::$PRIVATE)); $this->executeDefaultHooks($template); - $this->assignView('plugin_errors', $this->container->pluginManager->getErrors()); + $this->assignView('plugin_errors', $this->container->get('pluginManager')->getErrors()); - return $this->container->pageBuilder->render($template, $this->container->basePath); + return $this->container->get('pageBuilder')->render($template, $this->container->get('basePath')); } /** @@ -86,7 +87,7 @@ protected function executeDefaultHooks(string $template): void foreach ($common_hooks as $name) { $pluginData = []; - $this->container->pluginManager->executeHooks( + $this->container->get('pluginManager')->executeHooks( 'render_' . $name, $pluginData, $parameters @@ -97,7 +98,7 @@ protected function executeDefaultHooks(string $template): void protected function executePageHooks(string $hook, array &$data, string $template = null): void { - $this->container->pluginManager->executeHooks( + $this->container->get('pluginManager')->executeHooks( $hook, $data, $this->buildPluginParameters($template) @@ -108,10 +109,10 @@ protected function buildPluginParameters(?string $template): array { return [ 'target' => $template, - 'loggedin' => $this->container->loginManager->isLoggedIn(), - 'basePath' => $this->container->basePath, - 'rootPath' => preg_replace('#/index\.php$#', '', $this->container->basePath), - 'bookmarkService' => $this->container->bookmarkService + 'loggedin' => $this->container->get('loginManager')->isLoggedIn(), + 'basePath' => $this->container->get('basePath'), + 'rootPath' => preg_replace('#/index\.php$#', '', $this->container->get('basePath')), + 'bookmarkService' => $this->container->get('bookmarkService') ]; } @@ -123,9 +124,12 @@ protected function buildPluginParameters(?string $template): array * * @return Response updated */ - protected function redirect(Response $response, string $path): Response + protected function redirect(Response $response, string $path, bool $addBasePath = true): Response { - return $response->withRedirect($this->container->basePath . $path); + $basePath = $addBasePath ? $this->container->get('basePath') : ''; + return $response + ->withHeader('Location', $basePath . $path) + ->withStatus(302); } /** @@ -140,19 +144,20 @@ protected function redirectFromReferer( Response $response, array $loopTerms = [], array $clearParams = [], - string $anchor = null + string $anchor = null, + string $referer = null ): Response { - $defaultPath = $this->container->basePath . '/'; - $referer = $this->container->environment['HTTP_REFERER'] ?? null; + $defaultPath = $this->container->get('basePath') . '/'; + $referer = $referer ?? $request->getServerParams()['HTTP_REFERER'] ?? null; if (null !== $referer) { $currentUrl = parse_url($referer); // If the referer is not related to Shaarli instance, redirect to default if ( isset($currentUrl['host']) - && strpos(index_url($this->container->environment), $currentUrl['host']) === false + && strpos(index_url($request->getServerParams() ?? null), $currentUrl['host']) === false ) { - return $response->withRedirect($defaultPath); + return $this->redirect($response, $defaultPath, false); } parse_str($currentUrl['query'] ?? '', $params); @@ -181,6 +186,46 @@ protected function redirectFromReferer( $queryString = count($params) > 0 ? '?' . http_build_query($params) : ''; $anchor = $anchor ? '#' . $anchor : ''; - return $response->withRedirect($path . $queryString . $anchor); + return $this->redirect($response, $path . $queryString . $anchor, false); + } + + /** + * Simple helper, which writes data as JSON to the body + * + * @param Response $response + * @param mixed $data + * @param int $jsonStyle + * @return Response + */ + protected function respondWithJson(Response $response, mixed $data, int $jsonStyle = 0): Response + { + $response->getBody()->write(json_encode($data, $jsonStyle)); + return $response->withHeader('Content-Type', 'application/json'); + } + + /** + * Simple helper, which writes data to the body + * + * @param Response $response + * @param string $data + * @return Response + */ + protected function respondWithBody(Response $response, string $data): Response + { + $response->getBody()->write($data); + return $response; + } + + /** + * Simple helper, which uses a template + * + * @param Response $response + * @param string $template + * @return Response + */ + protected function respondWithTemplate(Response $response, string $template): Response + { + $response->getBody()->write($this->render($template)); + return $response; } } diff --git a/application/front/controller/visitor/TagCloudController.php b/application/front/controller/visitor/TagCloudController.php index 46d62779d..6ae6b299a 100644 --- a/application/front/controller/visitor/TagCloudController.php +++ b/application/front/controller/visitor/TagCloudController.php @@ -4,8 +4,8 @@ namespace Shaarli\Front\Controller\Visitor; -use Slim\Http\Request; -use Slim\Http\Response; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; /** * Class TagCloud @@ -47,16 +47,16 @@ public function list(Request $request, Response $response): Response */ protected function processRequest(string $type, Request $request, Response $response): Response { - $tagsSeparator = $this->container->conf->get('general.tags_separator', ' '); - if ($this->container->loginManager->isLoggedIn() === true) { - $visibility = $this->container->sessionManager->getSessionParameter('visibility'); + $tagsSeparator = $this->container->get('conf')->get('general.tags_separator', ' '); + if ($this->container->get('loginManager')->isLoggedIn() === true) { + $visibility = $this->container->get('sessionManager')->getSessionParameter('visibility'); } - $sort = $request->getQueryParam('sort'); - $searchTags = $request->getQueryParam('searchtags'); + $sort = $request->getQueryParams()['sort'] ?? null; + $searchTags = $request->getQueryParams()['searchtags'] ?? null; $filteringTags = $searchTags !== null ? explode($tagsSeparator, $searchTags) : []; - $tags = $this->container->bookmarkService->bookmarksCountPerTag($filteringTags, $visibility ?? null); + $tags = $this->container->get('bookmarkService')->bookmarksCountPerTag($filteringTags, $visibility ?? null); if (static::TYPE_CLOUD === $type || 'alpha' === $sort) { // TODO: the sorting should be handled by bookmarkService instead of the controller @@ -87,10 +87,10 @@ protected function processRequest(string $type, Request $request, Response $resp $searchTags = !empty($searchTags) ? trim(str_replace($tagsSeparator, ' ', $searchTags)) . ' - ' : ''; $this->assignView( 'pagetitle', - $searchTags . t('Tag ' . $type) . ' - ' . $this->container->conf->get('general.title', 'Shaarli') + $searchTags . t('Tag ' . $type) . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli') ); - return $response->write($this->render('tag.' . $type)); + return $this->respondWithTemplate($response, 'tag.' . $type); } /** diff --git a/application/front/controller/visitor/TagController.php b/application/front/controller/visitor/TagController.php index 3aa58542b..b1cffe608 100644 --- a/application/front/controller/visitor/TagController.php +++ b/application/front/controller/visitor/TagController.php @@ -4,8 +4,8 @@ namespace Shaarli\Front\Controller\Visitor; -use Slim\Http\Request; -use Slim\Http\Response; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; /** * Class TagController @@ -22,7 +22,7 @@ class TagController extends ShaarliVisitorController public function addTag(Request $request, Response $response, array $args): Response { $newTag = $args['newTag'] ?? null; - $referer = $this->container->environment['HTTP_REFERER'] ?? null; + $referer = $request->getServerParams()['HTTP_REFERER'] ?? null; // In case browser does not send HTTP_REFERER, we search a single tag if (null === $referer) { @@ -37,7 +37,7 @@ public function addTag(Request $request, Response $response, array $args): Respo parse_str($currentUrl['query'] ?? '', $params); if (null === $newTag) { - return $response->withRedirect(($currentUrl['path'] ?? './') . '?' . http_build_query($params)); + return $this->redirect($response, ($currentUrl['path'] ?? './') . '?' . http_build_query($params), false); } // Prevent redirection loop @@ -45,7 +45,7 @@ public function addTag(Request $request, Response $response, array $args): Respo unset($params['addtag']); } - $tagsSeparator = $this->container->conf->get('general.tags_separator', ' '); + $tagsSeparator = $this->container->get('conf')->get('general.tags_separator', ' '); // Check if this tag is already in the search query and ignore it if it is. // Each tag is always separated by a space $currentTags = tags_str2array($params['searchtags'] ?? '', $tagsSeparator); @@ -68,7 +68,7 @@ public function addTag(Request $request, Response $response, array $args): Respo // We also remove page (keeping the same page has no sense, since the results are different) unset($params['page']); - return $response->withRedirect(($currentUrl['path'] ?? './') . '?' . http_build_query($params)); + return $this->redirect($response, ($currentUrl['path'] ?? './') . '?' . http_build_query($params), false); } /** @@ -78,7 +78,7 @@ public function addTag(Request $request, Response $response, array $args): Respo */ public function removeTag(Request $request, Response $response, array $args): Response { - $referer = $this->container->environment['HTTP_REFERER'] ?? null; + $referer = $request->getServerParams()['HTTP_REFERER'] ?? null; // If the referrer is not provided, we can update the search, so we failback on the bookmark list if (empty($referer)) { @@ -90,7 +90,7 @@ public function removeTag(Request $request, Response $response, array $args): Re parse_str($currentUrl['query'] ?? '', $params); if (null === $tagToRemove) { - return $response->withRedirect(($currentUrl['path'] ?? './') . '?' . http_build_query($params)); + return $this->redirect($response, ($currentUrl['path'] ?? './') . '?' . http_build_query($params), false); } // Prevent redirection loop @@ -99,7 +99,7 @@ public function removeTag(Request $request, Response $response, array $args): Re } if (isset($params['searchtags'])) { - $tagsSeparator = $this->container->conf->get('general.tags_separator', ' '); + $tagsSeparator = $this->container->get('conf')->get('general.tags_separator', ' '); $tags = tags_str2array($params['searchtags'] ?? '', $tagsSeparator); // Remove value from array $tags. $tags = array_diff($tags, [$tagToRemove]); @@ -115,6 +115,6 @@ public function removeTag(Request $request, Response $response, array $args): Re $queryParams = count($params) > 0 ? '?' . http_build_query($params) : ''; - return $response->withRedirect(($currentUrl['path'] ?? './') . $queryParams); + return $this->redirect($response, ($currentUrl['path'] ?? './') . $queryParams, false); } } diff --git a/application/helper/DailyPageHelper.php b/application/helper/DailyPageHelper.php index cb4494a83..80dbbe508 100644 --- a/application/helper/DailyPageHelper.php +++ b/application/helper/DailyPageHelper.php @@ -7,8 +7,8 @@ use DatePeriod; use DateTimeImmutable; use Exception; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\Bookmark; -use Slim\Http\Request; class DailyPageHelper { @@ -21,13 +21,13 @@ class DailyPageHelper * * @param Request $request HTTP request * - * @return string month/week/day + * @return string|null month/week/day */ public static function extractRequestedType(Request $request): string { - if ($request->getQueryParam(static::MONTH) !== null) { + if (!is_null($request->getQueryParams()[static::MONTH] ?? null)) { return static::MONTH; - } elseif ($request->getQueryParam(static::WEEK) !== null) { + } elseif (!is_null($request->getQueryParams()[static::WEEK] ?? null)) { return static::WEEK; } diff --git a/application/legacy/LegacyController.php b/application/legacy/LegacyController.php index 1fed418b7..f61138060 100644 --- a/application/legacy/LegacyController.php +++ b/application/legacy/LegacyController.php @@ -4,10 +4,10 @@ namespace Shaarli\Legacy; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Feed\FeedBuilder; use Shaarli\Front\Controller\Visitor\ShaarliVisitorController; -use Slim\Http\Request; -use Slim\Http\Response; /** * We use this to maintain legacy routes, and redirect requests to the corresponding Slim route. @@ -49,7 +49,7 @@ public function post(Request $request, Response $response): Response }; - if (!$this->container->loginManager->isLoggedIn()) { + if (!$this->container->get('loginManager')->isLoggedIn()) { $parameters = $buildParameters($request->getQueryParams(), true); return $this->redirect($response, '/login?returnurl=' . $this->getBasePath() . $route . $parameters); } @@ -64,7 +64,7 @@ protected function addlink(Request $request, Response $response): Response { $route = '/admin/add-shaare'; - if (!$this->container->loginManager->isLoggedIn()) { + if (!$this->container->get('loginManager')->isLoggedIn()) { return $this->redirect($response, '/login?returnurl=' . $this->getBasePath() . $route); } @@ -74,7 +74,7 @@ protected function addlink(Request $request, Response $response): Response /** Legacy route: ?do=login */ protected function login(Request $request, Response $response): Response { - $returnUrl = $request->getQueryParam('returnurl'); + $returnUrl = $request->getQueryParams()['returnurl'] ?? null; return $this->redirect($response, '/login' . ($returnUrl ? '?returnurl=' . $returnUrl : '')); } @@ -106,7 +106,8 @@ protected function taglist(Request $request, Response $response): Response /** Legacy route: ?do=daily */ protected function daily(Request $request, Response $response): Response { - $dayParam = !empty($request->getParam('day')) ? '?day=' . escape($request->getParam('day')) : ''; + $dayParam = !empty($request->getQueryParams()['day'] ?? null) ? + '?day=' . escape($request->getQueryParams()['day']) : ''; return $this->redirect($response, '/daily' . $dayParam); } @@ -148,7 +149,7 @@ protected function configure(Request $request, Response $response): Response { $route = '/admin/configure'; - if (!$this->container->loginManager->isLoggedIn()) { + if (!$this->container->get('loginManager')->isLoggedIn()) { return $this->redirect($response, '/login?returnurl=' . $this->getBasePath() . $route); } @@ -157,6 +158,6 @@ protected function configure(Request $request, Response $response): Response protected function getBasePath(): string { - return $this->container->basePath ?: ''; + return $this->container->get('basePath') ?: ''; } } diff --git a/application/render/TemplatePage.php b/application/render/TemplatePage.php index 03b424f3c..c318ab145 100644 --- a/application/render/TemplatePage.php +++ b/application/render/TemplatePage.php @@ -27,6 +27,8 @@ interface TemplatePage public const OPEN_SEARCH = 'opensearch'; public const PICTURE_WALL = 'picwall'; public const PLUGINS_ADMIN = 'pluginsadmin'; + public const PLUGINS_CONTENT = 'pluginscontent'; + public const SERVER = 'server'; public const TAG_CLOUD = 'tag.cloud'; public const TAG_LIST = 'tag.list'; public const THUMBNAILS = 'thumbnails'; diff --git a/composer.json b/composer.json index a2d378c76..ad75bcf31 100644 --- a/composer.json +++ b/composer.json @@ -25,9 +25,11 @@ "gettext/gettext": "^4.4", "katzgrau/klogger": "^1.2", "malkusch/lock": "^2.1", + "php-di/php-di": "^6.4", "pubsubhubbub/publisher": "dev-master", "shaarli/netscape-bookmark-parser": "^4.0", - "slim/slim": "^3.0" + "slim/psr7": "^1.6", + "slim/slim": "4.*" }, "require-dev": { "roave/security-advisories": "dev-master", diff --git a/composer.lock b/composer.lock index 1aaa4d77f..882e418b0 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "e37830ae8a7cbd6670f0493c3d90c618", + "content-hash": "f528234eae54fec2c08e480246366930", "packages": [ { "name": "arthurhoaro/web-thumbnailer", @@ -155,6 +155,62 @@ }, "time": "2019-12-30T23:20:37+00:00" }, + { + "name": "fig/http-message-util", + "version": "1.1.5", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-message-util.git", + "reference": "9d94dc0154230ac39e5bf89398b324a86f63f765" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-message-util/zipball/9d94dc0154230ac39e5bf89398b324a86f63f765", + "reference": "9d94dc0154230ac39e5bf89398b324a86f63f765", + "shasum": "" + }, + "require": { + "php": "^5.3 || ^7.0 || ^8.0" + }, + "suggest": { + "psr/http-message": "The package containing the PSR-7 interfaces" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.1.x-dev" + } + }, + "autoload": { + "psr-4": { + "Fig\\Http\\Message\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Utility classes and constants for use with PSR-7 (psr/http-message)", + "keywords": [ + "http", + "http-message", + "psr", + "psr-7", + "request", + "response" + ], + "support": { + "issues": "https://github.com/php-fig/http-message-util/issues", + "source": "https://github.com/php-fig/http-message-util/tree/1.1.5" + }, + "time": "2020-11-24T22:02:12+00:00" + }, { "name": "gettext/gettext", "version": "v4.8.8", @@ -364,6 +420,66 @@ }, "time": "2022-07-29T20:41:14+00:00" }, + { + "name": "laravel/serializable-closure", + "version": "v1.3.0", + "source": { + "type": "git", + "url": "https://github.com/laravel/serializable-closure.git", + "reference": "f23fe9d4e95255dacee1bf3525e0810d1a1b0f37" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/laravel/serializable-closure/zipball/f23fe9d4e95255dacee1bf3525e0810d1a1b0f37", + "reference": "f23fe9d4e95255dacee1bf3525e0810d1a1b0f37", + "shasum": "" + }, + "require": { + "php": "^7.3|^8.0" + }, + "require-dev": { + "nesbot/carbon": "^2.61", + "pestphp/pest": "^1.21.3", + "phpstan/phpstan": "^1.8.2", + "symfony/var-dumper": "^5.4.11" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.x-dev" + } + }, + "autoload": { + "psr-4": { + "Laravel\\SerializableClosure\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Taylor Otwell", + "email": "taylor@laravel.com" + }, + { + "name": "Nuno Maduro", + "email": "nuno@laravel.com" + } + ], + "description": "Laravel Serializable Closure provides an easy and secure way to serialize closures in PHP.", + "keywords": [ + "closure", + "laravel", + "serializable" + ], + "support": { + "issues": "https://github.com/laravel/serializable-closure/issues", + "source": "https://github.com/laravel/serializable-closure" + }, + "time": "2023-01-30T18:31:20+00:00" + }, { "name": "malkusch/lock", "version": "v2.2.1", @@ -503,6 +619,179 @@ }, "time": "2018-02-13T20:26:39+00:00" }, + { + "name": "php-di/invoker", + "version": "2.3.3", + "source": { + "type": "git", + "url": "https://github.com/PHP-DI/Invoker.git", + "reference": "cd6d9f267d1a3474bdddf1be1da079f01b942786" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHP-DI/Invoker/zipball/cd6d9f267d1a3474bdddf1be1da079f01b942786", + "reference": "cd6d9f267d1a3474bdddf1be1da079f01b942786", + "shasum": "" + }, + "require": { + "php": ">=7.3", + "psr/container": "^1.0|^2.0" + }, + "require-dev": { + "athletic/athletic": "~0.1.8", + "mnapoli/hard-mode": "~0.3.0", + "phpunit/phpunit": "^9.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Invoker\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Generic and extensible callable invoker", + "homepage": "https://github.com/PHP-DI/Invoker", + "keywords": [ + "callable", + "dependency", + "dependency-injection", + "injection", + "invoke", + "invoker" + ], + "support": { + "issues": "https://github.com/PHP-DI/Invoker/issues", + "source": "https://github.com/PHP-DI/Invoker/tree/2.3.3" + }, + "funding": [ + { + "url": "https://github.com/mnapoli", + "type": "github" + } + ], + "time": "2021-12-13T09:22:56+00:00" + }, + { + "name": "php-di/php-di", + "version": "6.4.0", + "source": { + "type": "git", + "url": "https://github.com/PHP-DI/PHP-DI.git", + "reference": "ae0f1b3b03d8b29dff81747063cbfd6276246cc4" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHP-DI/PHP-DI/zipball/ae0f1b3b03d8b29dff81747063cbfd6276246cc4", + "reference": "ae0f1b3b03d8b29dff81747063cbfd6276246cc4", + "shasum": "" + }, + "require": { + "laravel/serializable-closure": "^1.0", + "php": ">=7.4.0", + "php-di/invoker": "^2.0", + "php-di/phpdoc-reader": "^2.0.1", + "psr/container": "^1.0" + }, + "provide": { + "psr/container-implementation": "^1.0" + }, + "require-dev": { + "doctrine/annotations": "~1.10", + "friendsofphp/php-cs-fixer": "^2.4", + "mnapoli/phpunit-easymock": "^1.2", + "ocramius/proxy-manager": "^2.11.2", + "phpstan/phpstan": "^0.12", + "phpunit/phpunit": "^9.5" + }, + "suggest": { + "doctrine/annotations": "Install it if you want to use annotations (version ~1.2)", + "ocramius/proxy-manager": "Install it if you want to use lazy injection (version ~2.0)" + }, + "type": "library", + "autoload": { + "files": [ + "src/functions.php" + ], + "psr-4": { + "DI\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "The dependency injection container for humans", + "homepage": "https://php-di.org/", + "keywords": [ + "PSR-11", + "container", + "container-interop", + "dependency injection", + "di", + "ioc", + "psr11" + ], + "support": { + "issues": "https://github.com/PHP-DI/PHP-DI/issues", + "source": "https://github.com/PHP-DI/PHP-DI/tree/6.4.0" + }, + "funding": [ + { + "url": "https://github.com/mnapoli", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/php-di/php-di", + "type": "tidelift" + } + ], + "time": "2022-04-09T16:46:38+00:00" + }, + { + "name": "php-di/phpdoc-reader", + "version": "2.2.1", + "source": { + "type": "git", + "url": "https://github.com/PHP-DI/PhpDocReader.git", + "reference": "66daff34cbd2627740ffec9469ffbac9f8c8185c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHP-DI/PhpDocReader/zipball/66daff34cbd2627740ffec9469ffbac9f8c8185c", + "reference": "66daff34cbd2627740ffec9469ffbac9f8c8185c", + "shasum": "" + }, + "require": { + "php": ">=7.2.0" + }, + "require-dev": { + "mnapoli/hard-mode": "~0.3.0", + "phpunit/phpunit": "^8.5|^9.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "PhpDocReader\\": "src/PhpDocReader" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "PhpDocReader parses @var and @param values in PHP docblocks (supports namespaced class names with the same resolution rules as PHP)", + "keywords": [ + "phpdoc", + "reflection" + ], + "support": { + "issues": "https://github.com/PHP-DI/PhpDocReader/issues", + "source": "https://github.com/PHP-DI/PhpDocReader/tree/2.2.1" + }, + "time": "2020-10-12T12:39:22+00:00" + }, { "name": "phpunit/php-text-template", "version": "2.0.4", @@ -563,35 +852,26 @@ "time": "2020-10-26T05:33:50+00:00" }, { - "name": "pimple/pimple", - "version": "v3.5.0", + "name": "psr/container", + "version": "1.1.2", "source": { "type": "git", - "url": "https://github.com/silexphp/Pimple.git", - "reference": "a94b3a4db7fb774b3d78dad2315ddc07629e1bed" + "url": "https://github.com/php-fig/container.git", + "reference": "513e0666f7216c7459170d56df27dfcefe1689ea" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/silexphp/Pimple/zipball/a94b3a4db7fb774b3d78dad2315ddc07629e1bed", - "reference": "a94b3a4db7fb774b3d78dad2315ddc07629e1bed", + "url": "https://api.github.com/repos/php-fig/container/zipball/513e0666f7216c7459170d56df27dfcefe1689ea", + "reference": "513e0666f7216c7459170d56df27dfcefe1689ea", "shasum": "" }, "require": { - "php": ">=7.2.5", - "psr/container": "^1.1 || ^2.0" - }, - "require-dev": { - "symfony/phpunit-bridge": "^5.4@dev" + "php": ">=7.4.0" }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.4.x-dev" - } - }, "autoload": { - "psr-0": { - "Pimple": "src/" + "psr-4": { + "Psr\\Container\\": "src/" } }, "notification-url": "https://packagist.org/downloads/", @@ -600,42 +880,52 @@ ], "authors": [ { - "name": "Fabien Potencier", - "email": "fabien@symfony.com" + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" } ], - "description": "Pimple, a simple Dependency Injection Container", - "homepage": "https://pimple.symfony.com", + "description": "Common Container Interface (PHP FIG PSR-11)", + "homepage": "https://github.com/php-fig/container", "keywords": [ + "PSR-11", "container", - "dependency injection" + "container-interface", + "container-interop", + "psr" ], "support": { - "source": "https://github.com/silexphp/Pimple/tree/v3.5.0" + "issues": "https://github.com/php-fig/container/issues", + "source": "https://github.com/php-fig/container/tree/1.1.2" }, - "time": "2021-10-28T11:13:42+00:00" + "time": "2021-11-05T16:50:12+00:00" }, { - "name": "psr/container", - "version": "1.1.2", + "name": "psr/http-factory", + "version": "1.0.2", "source": { "type": "git", - "url": "https://github.com/php-fig/container.git", - "reference": "513e0666f7216c7459170d56df27dfcefe1689ea" + "url": "https://github.com/php-fig/http-factory.git", + "reference": "e616d01114759c4c489f93b099585439f795fe35" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/php-fig/container/zipball/513e0666f7216c7459170d56df27dfcefe1689ea", - "reference": "513e0666f7216c7459170d56df27dfcefe1689ea", + "url": "https://api.github.com/repos/php-fig/http-factory/zipball/e616d01114759c4c489f93b099585439f795fe35", + "reference": "e616d01114759c4c489f93b099585439f795fe35", "shasum": "" }, "require": { - "php": ">=7.4.0" + "php": ">=7.0.0", + "psr/http-message": "^1.0 || ^2.0" }, "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, "autoload": { "psr-4": { - "Psr\\Container\\": "src/" + "Psr\\Http\\Message\\": "src/" } }, "notification-url": "https://packagist.org/downloads/", @@ -648,42 +938,43 @@ "homepage": "https://www.php-fig.org/" } ], - "description": "Common Container Interface (PHP FIG PSR-11)", - "homepage": "https://github.com/php-fig/container", + "description": "Common interfaces for PSR-7 HTTP message factories", "keywords": [ - "PSR-11", - "container", - "container-interface", - "container-interop", - "psr" + "factory", + "http", + "message", + "psr", + "psr-17", + "psr-7", + "request", + "response" ], "support": { - "issues": "https://github.com/php-fig/container/issues", - "source": "https://github.com/php-fig/container/tree/1.1.2" + "source": "https://github.com/php-fig/http-factory/tree/1.0.2" }, - "time": "2021-11-05T16:50:12+00:00" + "time": "2023-04-10T20:10:41+00:00" }, { "name": "psr/http-message", - "version": "1.0.1", + "version": "1.1", "source": { "type": "git", "url": "https://github.com/php-fig/http-message.git", - "reference": "f6561bf28d520154e4b0ec72be95418abe6d9363" + "reference": "cb6ce4845ce34a8ad9e68117c10ee90a29919eba" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/php-fig/http-message/zipball/f6561bf28d520154e4b0ec72be95418abe6d9363", - "reference": "f6561bf28d520154e4b0ec72be95418abe6d9363", + "url": "https://api.github.com/repos/php-fig/http-message/zipball/cb6ce4845ce34a8ad9e68117c10ee90a29919eba", + "reference": "cb6ce4845ce34a8ad9e68117c10ee90a29919eba", "shasum": "" }, "require": { - "php": ">=5.3.0" + "php": "^7.2 || ^8.0" }, "type": "library", "extra": { "branch-alias": { - "dev-master": "1.0.x-dev" + "dev-master": "1.1.x-dev" } }, "autoload": { @@ -712,9 +1003,122 @@ "response" ], "support": { - "source": "https://github.com/php-fig/http-message/tree/master" + "source": "https://github.com/php-fig/http-message/tree/1.1" + }, + "time": "2023-04-04T09:50:52+00:00" + }, + { + "name": "psr/http-server-handler", + "version": "1.0.2", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-server-handler.git", + "reference": "84c4fb66179be4caaf8e97bd239203245302e7d4" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-server-handler/zipball/84c4fb66179be4caaf8e97bd239203245302e7d4", + "reference": "84c4fb66179be4caaf8e97bd239203245302e7d4", + "shasum": "" + }, + "require": { + "php": ">=7.0", + "psr/http-message": "^1.0 || ^2.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Http\\Server\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for HTTP server-side request handler", + "keywords": [ + "handler", + "http", + "http-interop", + "psr", + "psr-15", + "psr-7", + "request", + "response", + "server" + ], + "support": { + "source": "https://github.com/php-fig/http-server-handler/tree/1.0.2" + }, + "time": "2023-04-10T20:06:20+00:00" + }, + { + "name": "psr/http-server-middleware", + "version": "1.0.2", + "source": { + "type": "git", + "url": "https://github.com/php-fig/http-server-middleware.git", + "reference": "c1481f747daaa6a0782775cd6a8c26a1bf4a3829" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/http-server-middleware/zipball/c1481f747daaa6a0782775cd6a8c26a1bf4a3829", + "reference": "c1481f747daaa6a0782775cd6a8c26a1bf4a3829", + "shasum": "" + }, + "require": { + "php": ">=7.0", + "psr/http-message": "^1.0 || ^2.0", + "psr/http-server-handler": "^1.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Http\\Server\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for HTTP server-side middleware", + "keywords": [ + "http", + "http-interop", + "middleware", + "psr", + "psr-15", + "psr-7", + "request", + "response" + ], + "support": { + "issues": "https://github.com/php-fig/http-server-middleware/issues", + "source": "https://github.com/php-fig/http-server-middleware/tree/1.0.2" }, - "time": "2016-08-06T14:39:51+00:00" + "time": "2023-04-11T06:14:47+00:00" }, { "name": "psr/log", @@ -816,6 +1220,50 @@ }, "time": "2021-12-07T05:38:17+00:00" }, + { + "name": "ralouphie/getallheaders", + "version": "3.0.3", + "source": { + "type": "git", + "url": "https://github.com/ralouphie/getallheaders.git", + "reference": "120b605dfeb996808c31b6477290a714d356e822" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/ralouphie/getallheaders/zipball/120b605dfeb996808c31b6477290a714d356e822", + "reference": "120b605dfeb996808c31b6477290a714d356e822", + "shasum": "" + }, + "require": { + "php": ">=5.6" + }, + "require-dev": { + "php-coveralls/php-coveralls": "^2.1", + "phpunit/phpunit": "^5 || ^6.5" + }, + "type": "library", + "autoload": { + "files": [ + "src/getallheaders.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ralph Khattar", + "email": "ralph.khattar@gmail.com" + } + ], + "description": "A polyfill for getallheaders.", + "support": { + "issues": "https://github.com/ralouphie/getallheaders/issues", + "source": "https://github.com/ralouphie/getallheaders/tree/develop" + }, + "time": "2019-03-08T08:55:37+00:00" + }, { "name": "shaarli/netscape-bookmark-parser", "version": "v4.0.0", @@ -885,35 +1333,134 @@ "time": "2022-08-13T09:57:26+00:00" }, { - "name": "slim/slim", - "version": "3.12.4", + "name": "slim/psr7", + "version": "1.6", "source": { "type": "git", - "url": "https://github.com/slimphp/Slim.git", - "reference": "ce3cb65a06325fc9fe3d0223f2ae23113a767304" + "url": "https://github.com/slimphp/Slim-Psr7.git", + "reference": "3471c22c1a0d26c51c78f6aeb06489d38cf46a4d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/slimphp/Slim/zipball/ce3cb65a06325fc9fe3d0223f2ae23113a767304", - "reference": "ce3cb65a06325fc9fe3d0223f2ae23113a767304", + "url": "https://api.github.com/repos/slimphp/Slim-Psr7/zipball/3471c22c1a0d26c51c78f6aeb06489d38cf46a4d", + "reference": "3471c22c1a0d26c51c78f6aeb06489d38cf46a4d", "shasum": "" }, "require": { - "ext-json": "*", - "ext-libxml": "*", - "ext-simplexml": "*", - "nikic/fast-route": "^1.0", - "php": ">=5.5.0", - "pimple/pimple": "^3.0", - "psr/container": "^1.0", - "psr/http-message": "^1.0" + "fig/http-message-util": "^1.1.5", + "php": "^7.4 || ^8.0", + "psr/http-factory": "^1.0", + "psr/http-message": "^1.0", + "ralouphie/getallheaders": "^3.0", + "symfony/polyfill-php80": "^1.26" }, "provide": { + "psr/http-factory-implementation": "1.0", "psr/http-message-implementation": "1.0" }, "require-dev": { - "phpunit/phpunit": "^4.0", - "squizlabs/php_codesniffer": "^3.6.0" + "adriansuter/php-autoload-override": "^1.3", + "ext-json": "*", + "http-interop/http-factory-tests": "^0.9.0", + "php-http/psr7-integration-tests": "dev-master", + "phpspec/prophecy": "^1.15", + "phpspec/prophecy-phpunit": "^2.0", + "phpstan/phpstan": "^1.8", + "phpunit/phpunit": "^9.5", + "squizlabs/php_codesniffer": "^3.7" + }, + "type": "library", + "autoload": { + "psr-4": { + "Slim\\Psr7\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Josh Lockhart", + "email": "hello@joshlockhart.com", + "homepage": "http://joshlockhart.com" + }, + { + "name": "Andrew Smith", + "email": "a.smith@silentworks.co.uk", + "homepage": "http://silentworks.co.uk" + }, + { + "name": "Rob Allen", + "email": "rob@akrabat.com", + "homepage": "http://akrabat.com" + }, + { + "name": "Pierre Berube", + "email": "pierre@lgse.com", + "homepage": "http://www.lgse.com" + } + ], + "description": "Strict PSR-7 implementation", + "homepage": "https://www.slimframework.com", + "keywords": [ + "http", + "psr-7", + "psr7" + ], + "support": { + "issues": "https://github.com/slimphp/Slim-Psr7/issues", + "source": "https://github.com/slimphp/Slim-Psr7/tree/1.6" + }, + "time": "2022-11-05T18:50:24+00:00" + }, + { + "name": "slim/slim", + "version": "4.11.0", + "source": { + "type": "git", + "url": "https://github.com/slimphp/Slim.git", + "reference": "b0f4ca393ea037be9ac7292ba7d0a34d18bac0c7" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/slimphp/Slim/zipball/b0f4ca393ea037be9ac7292ba7d0a34d18bac0c7", + "reference": "b0f4ca393ea037be9ac7292ba7d0a34d18bac0c7", + "shasum": "" + }, + "require": { + "ext-json": "*", + "nikic/fast-route": "^1.3", + "php": "^7.4 || ^8.0", + "psr/container": "^1.0 || ^2.0", + "psr/http-factory": "^1.0", + "psr/http-message": "^1.0", + "psr/http-server-handler": "^1.0", + "psr/http-server-middleware": "^1.0", + "psr/log": "^1.1 || ^2.0 || ^3.0" + }, + "require-dev": { + "adriansuter/php-autoload-override": "^1.3", + "ext-simplexml": "*", + "guzzlehttp/psr7": "^2.4", + "httpsoft/http-message": "^1.0", + "httpsoft/http-server-request": "^1.0", + "laminas/laminas-diactoros": "^2.17", + "nyholm/psr7": "^1.5", + "nyholm/psr7-server": "^1.0", + "phpspec/prophecy": "^1.15", + "phpspec/prophecy-phpunit": "^2.0", + "phpstan/phpstan": "^1.8", + "phpunit/phpunit": "^9.5", + "slim/http": "^1.2", + "slim/psr7": "^1.5", + "squizlabs/php_codesniffer": "^3.7" + }, + "suggest": { + "ext-simplexml": "Needed to support XML format in BodyParsingMiddleware", + "ext-xml": "Needed to support XML format in BodyParsingMiddleware", + "php-di/php-di": "PHP-DI is the recommended container library to be used with Slim", + "slim/psr7": "Slim PSR-7 implementation. See https://www.slimframework.com/docs/v4/start/installation.html for more information." }, "type": "library", "autoload": { @@ -941,6 +1488,11 @@ "email": "rob@akrabat.com", "homepage": "http://akrabat.com" }, + { + "name": "Pierre Berube", + "email": "pierre@lgse.com", + "homepage": "http://www.lgse.com" + }, { "name": "Gabriel Manricks", "email": "gmanricks@me.com", @@ -948,7 +1500,7 @@ } ], "description": "Slim is a PHP micro framework that helps you quickly write simple yet powerful web applications and APIs", - "homepage": "https://slimframework.com", + "homepage": "https://www.slimframework.com", "keywords": [ "api", "framework", @@ -956,8 +1508,14 @@ "router" ], "support": { + "docs": "https://www.slimframework.com/docs/v4/", + "forum": "https://discourse.slimframework.com/", + "irc": "irc://irc.freenode.net:6667/slimphp", "issues": "https://github.com/slimphp/Slim/issues", - "source": "https://github.com/slimphp/Slim/tree/3.12.4" + "rss": "https://www.slimframework.com/blog/feed.rss", + "slack": "https://slimphp.slack.com/", + "source": "https://github.com/slimphp/Slim", + "wiki": "https://github.com/slimphp/Slim/wiki" }, "funding": [ { @@ -969,7 +1527,90 @@ "type": "tidelift" } ], - "time": "2021-10-02T19:38:22+00:00" + "time": "2022-11-06T16:33:39+00:00" + }, + { + "name": "symfony/polyfill-php80", + "version": "v1.27.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-php80.git", + "reference": "7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936", + "reference": "7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936", + "shasum": "" + }, + "require": { + "php": ">=7.1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "1.27-dev" + }, + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Php80\\": "" + }, + "classmap": [ + "Resources/stubs" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ion Bazan", + "email": "ion.bazan@gmail.com" + }, + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill backporting some PHP 8.0+ features to lower PHP versions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-php80/tree/v1.27.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2022-11-03T14:55:06+00:00" } ], "packages-dev": [ @@ -1530,16 +2171,16 @@ }, { "name": "phpunit/phpunit", - "version": "9.6.5", + "version": "9.6.6", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit.git", - "reference": "86e761949019ae83f49240b2f2123fb5ab3b2fc5" + "reference": "b65d59a059d3004a040c16a82e07bbdf6cfdd115" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/86e761949019ae83f49240b2f2123fb5ab3b2fc5", - "reference": "86e761949019ae83f49240b2f2123fb5ab3b2fc5", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/b65d59a059d3004a040c16a82e07bbdf6cfdd115", + "reference": "b65d59a059d3004a040c16a82e07bbdf6cfdd115", "shasum": "" }, "require": { @@ -1612,7 +2253,8 @@ ], "support": { "issues": "https://github.com/sebastianbergmann/phpunit/issues", - "source": "https://github.com/sebastianbergmann/phpunit/tree/9.6.5" + "security": "https://github.com/sebastianbergmann/phpunit/security/policy", + "source": "https://github.com/sebastianbergmann/phpunit/tree/9.6.6" }, "funding": [ { @@ -1628,7 +2270,7 @@ "type": "tidelift" } ], - "time": "2023-03-09T06:34:10+00:00" + "time": "2023-03-27T11:43:46+00:00" }, { "name": "roave/security-advisories", @@ -1636,12 +2278,12 @@ "source": { "type": "git", "url": "https://github.com/Roave/SecurityAdvisories.git", - "reference": "ad434708152844968e15adf8eb3f4a2d7066242e" + "reference": "892a245d17587a4a3749d0b4faf99b60f3ba22e8" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/Roave/SecurityAdvisories/zipball/ad434708152844968e15adf8eb3f4a2d7066242e", - "reference": "ad434708152844968e15adf8eb3f4a2d7066242e", + "url": "https://api.github.com/repos/Roave/SecurityAdvisories/zipball/892a245d17587a4a3749d0b4faf99b60f3ba22e8", + "reference": "892a245d17587a4a3749d0b4faf99b60f3ba22e8", "shasum": "" }, "conflict": { @@ -1659,9 +2301,10 @@ "amphp/http-client": ">=4,<4.4", "anchorcms/anchor-cms": "<=0.12.7", "andreapollastri/cipi": "<=3.1.15", + "andrewhaine/silverstripe-form-capture": ">=0.2,<=0.2.3|>=1,<=1.0.1|>=2,<=2.2.4", "apereo/phpcas": "<1.6", "api-platform/core": ">=2.2,<2.2.10|>=2.3,<2.3.6|>=2.6,<2.7.10|>=3,<3.0.12|>=3.1,<3.1.3", - "appwrite/server-ce": "<0.11.1|>=0.12,<0.12.2", + "appwrite/server-ce": "<=1.2.1", "arc/web": "<3", "area17/twill": "<1.2.5|>=2,<2.5.3", "asymmetricrypt/asymmetricrypt": ">=0,<9.9.99", @@ -1675,8 +2318,9 @@ "barrelstrength/sprout-forms": "<3.9", "barryvdh/laravel-translation-manager": "<0.6.2", "barzahlen/barzahlen-php": "<2.0.1", - "baserproject/basercms": "<4.7.2", + "baserproject/basercms": "<4.7.5", "bassjobsen/bootstrap-3-typeahead": ">4.0.2", + "bigfork/silverstripe-form-capture": ">=3,<=3.1", "billz/raspap-webgui": "<=2.6.6", "bk2k/bootstrap-package": ">=7.1,<7.1.2|>=8,<8.0.8|>=9,<9.0.4|>=9.1,<9.1.3|>=10,<10.0.10|>=11,<11.0.3", "bmarshall511/wordpress_zero_spam": "<5.2.13", @@ -1760,7 +2404,7 @@ "ezsystems/ezplatform-graphql": ">=1-rc.1,<1.0.13|>=2-beta.1,<2.3.12", "ezsystems/ezplatform-kernel": "<1.2.5.1|>=1.3,<1.3.26", "ezsystems/ezplatform-rest": ">=1.2,<=1.2.2|>=1.3,<1.3.8", - "ezsystems/ezplatform-richtext": ">=2.3,<=2.3.7", + "ezsystems/ezplatform-richtext": ">=2.3,<2.3.7.1", "ezsystems/ezplatform-user": ">=1,<1.0.1", "ezsystems/ezpublish-kernel": "<6.13.8.2|>=7,<7.5.30", "ezsystems/ezpublish-legacy": "<=2017.12.7.3|>=2018.6,<=2019.3.5.1", @@ -1808,7 +2452,7 @@ "gos/web-socket-bundle": "<1.10.4|>=2,<2.6.1|>=3,<3.3", "gree/jose": "<2.2.1", "gregwar/rst": "<1.0.3", - "grumpydictator/firefly-iii": "<5.8", + "grumpydictator/firefly-iii": "<6", "guzzlehttp/guzzle": "<6.5.8|>=7,<7.4.5", "guzzlehttp/psr7": "<1.8.4|>=2,<2.1.1", "harvesthq/chosen": "<1.8.7", @@ -1853,7 +2497,7 @@ "kimai/kimai": "<1.1", "kitodo/presentation": "<3.1.2", "klaviyo/magento2-extension": ">=1,<3", - "knplabs/knp-snappy": "<=1.4.1", + "knplabs/knp-snappy": "<1.4.2", "krayin/laravel-crm": "<1.2.2", "kreait/firebase-php": ">=3.2,<3.8.1", "la-haute-societe/tcpdf": "<6.2.22", @@ -1893,14 +2537,14 @@ "melisplatform/melis-front": "<5.0.1", "mezzio/mezzio-swoole": "<3.7|>=4,<4.3", "mgallegos/laravel-jqgrid": "<=1.3", - "microweber/microweber": "<=1.3.2", + "microweber/microweber": "<1.3.3", "miniorange/miniorange-saml": "<1.4.3", "mittwald/typo3_forum": "<1.2.1", "mobiledetect/mobiledetectlib": "<2.8.32", "modx/revolution": "<= 2.8.3-pl|<2.8", "mojo42/jirafeau": "<4.4", "monolog/monolog": ">=1.8,<1.12", - "moodle/moodle": "<4.0.6|= 3.11|>=4.1-beta,<4.1.1", + "moodle/moodle": "<4.0.7|>=4.1-beta,<4.1.2|= 3.11", "mustache/mustache": ">=2,<2.14.1", "namshi/jose": "<2.2", "neoan3-apps/template": "<1.1.1", @@ -1955,12 +2599,14 @@ "phpoffice/phpspreadsheet": "<1.16", "phpseclib/phpseclib": "<2.0.31|>=3,<3.0.19", "phpservermon/phpservermon": "<=3.5.2", + "phpsysinfo/phpsysinfo": "<3.2.5", "phpunit/phpunit": ">=4.8.19,<4.8.28|>=5,<5.6.3", "phpwhois/phpwhois": "<=4.2.5", "phpxmlrpc/extras": "<0.6.1", "phpxmlrpc/phpxmlrpc": "<4.9.2", "pimcore/data-hub": "<1.2.4", - "pimcore/pimcore": "<11", + "pimcore/perspective-editor": "<1.5.1", + "pimcore/pimcore": "<10.5.20", "pixelfed/pixelfed": "<=0.11.4", "pocketmine/bedrock-protocol": "<8.0.2", "pocketmine/pocketmine-mp": "<4.12.5|>= 4.0.0-BETA5, < 4.4.2", @@ -1986,6 +2632,7 @@ "rainlab/debugbar-plugin": "<3.1", "rankmath/seo-by-rank-math": "<=1.0.95", "react/http": ">=0.7,<1.7", + "really-simple-plugins/complianz-gdpr": "<6.4.2", "remdex/livehelperchat": "<3.99", "rmccue/requests": ">=1.6,<1.8", "robrichards/xmlseclibs": "<3.0.4", @@ -2027,8 +2674,9 @@ "simplesamlphp/simplesamlphp-module-openid": "<1", "simplesamlphp/simplesamlphp-module-openidprovider": "<0.9", "simplito/elliptic-php": "<1.0.6", + "sitegeist/fluid-components": "<3.5", "slim/slim": "<2.6", - "smarty/smarty": "<3.1.47|>=4,<4.2.1", + "smarty/smarty": "<3.1.48|>=4,<4.3.1", "snipe/snipe-it": "<=6.0.14|>= 6.0.0-RC-1, <= 6.0.0-RC-5", "socalnick/scn-social-auth": "<1.15.2", "socialiteproviders/steam": "<1.1", @@ -2094,7 +2742,7 @@ "thelia/thelia": ">=2.1-beta.1,<2.1.3", "theonedemon/phpwhois": "<=4.2.5", "thinkcmf/thinkcmf": "<=5.1.7", - "thorsten/phpmyfaq": "<3.1.11", + "thorsten/phpmyfaq": "<3.1.12", "tinymce/tinymce": "<5.10.7|>=6,<6.3.1", "tinymighty/wiki-seo": "<1.2.2", "titon/framework": ">=0,<9.9.99", @@ -2221,7 +2869,7 @@ "type": "tidelift" } ], - "time": "2023-03-17T19:03:58+00:00" + "time": "2023-04-10T17:04:04+00:00" }, { "name": "sebastian/cli-parser", diff --git a/doc/md/dev/Plugin-system.md b/doc/md/dev/Plugin-system.md index 0ada57ea5..addc9e62e 100644 --- a/doc/md/dev/Plugin-system.md +++ b/doc/md/dev/Plugin-system.md @@ -151,8 +151,8 @@ This method must return an array of routes, each entry must contain the followin It will be later prefixed by `/plugin//`. - `callable` string, function name or FQN class's method to execute, e.g. `demo_plugin_custom_controller`. -Callable functions or methods must have `Slim\Http\Request` and `Slim\Http\Response` parameters -and return a `Slim\Http\Response`. We recommend creating a dedicated class and extend either +Callable functions or methods must have `ServerRequestInterface as Request` and `ResponseInterface as Response` parameters +and return a `ResponseInterface`. We recommend creating a dedicated class and extend either `ShaarliVisitorController` or `ShaarliAdminController` to use helper functions they provide. A dedicated plugin template is available for rendering content: `pluginscontent.html` using `content` placeholder. diff --git a/index.php b/index.php index f4210aed3..c9445da1a 100644 --- a/index.php +++ b/index.php @@ -27,22 +27,31 @@ require_once __DIR__ . '/init.php'; use Katzgrau\KLogger\Logger; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Psr\Log\LogLevel; +use Shaarli\Api\Controllers as ApiControllers; use Shaarli\Config\ConfigManager; use Shaarli\Container\ContainerBuilder; +use Shaarli\Front\Controller; +use Shaarli\Front\ShaarliErrorHandler; use Shaarli\Languages; use Shaarli\Plugin\PluginManager; use Shaarli\Security\BanManager; use Shaarli\Security\CookieManager; use Shaarli\Security\LoginManager; use Shaarli\Security\SessionManager; -use Slim\App; +use Slim\Factory\AppFactory; +use Slim\Routing\RouteCollectorProxy; $conf = new ConfigManager(); // Manually override root URL for complex server configurations define('SHAARLI_ROOT_URL', $conf->get('general.root_url', null)); +// In dev mode, throw exception on any warning +$displayErrorDetails = $conf->get('dev.debug', false); // // See all errors (for debugging only) + // In dev mode, throw exception on any warning if ($conf->get('dev.debug', false)) { // See all errors (for debugging only) @@ -105,102 +114,114 @@ $logger ); $container = $containerBuilder->build(); -$app = new App($container); +AppFactory::setContainer($container); +$app = AppFactory::create(); // Main Shaarli routes -$app->group('', function () { - $this->get('/install', '\Shaarli\Front\Controller\Visitor\InstallController:index')->setName('displayInstall'); - $this->get('/install/session-test', '\Shaarli\Front\Controller\Visitor\InstallController:sessionTest'); - $this->post('/install', '\Shaarli\Front\Controller\Visitor\InstallController:save')->setName('saveInstall'); +$app->get('/hello', function (Request $request, Response $response, $args) { + throw new Exception('abc'); + $response->getBody()->write("Hello world!"); + return $response; +}); + +$app->group('', function (RouteCollectorProxy $group) { + $group->get('/install', Controller\Visitor\InstallController::class . ':index')->setName('displayInstall'); + $group->get('/install/session-test', Controller\Visitor\InstallController::class . ':sessionTest'); + $group->post('/install', Controller\Visitor\InstallController::class . ':save')->setName('saveInstall'); /* -- PUBLIC --*/ - $this->get('/', '\Shaarli\Front\Controller\Visitor\BookmarkListController:index'); - $this->get('/shaare/{hash}', '\Shaarli\Front\Controller\Visitor\BookmarkListController:permalink'); - $this->get('/login', '\Shaarli\Front\Controller\Visitor\LoginController:index')->setName('login'); - $this->post('/login', '\Shaarli\Front\Controller\Visitor\LoginController:login')->setName('processLogin'); - $this->get('/picture-wall', '\Shaarli\Front\Controller\Visitor\PictureWallController:index'); - $this->get('/tags/cloud', '\Shaarli\Front\Controller\Visitor\TagCloudController:cloud'); - $this->get('/tags/list', '\Shaarli\Front\Controller\Visitor\TagCloudController:list'); - $this->get('/daily', '\Shaarli\Front\Controller\Visitor\DailyController:index'); - $this->get('/daily-rss', '\Shaarli\Front\Controller\Visitor\DailyController:rss')->setName('rss'); - $this->get('/feed/atom', '\Shaarli\Front\Controller\Visitor\FeedController:atom')->setName('atom'); - $this->get('/feed/rss', '\Shaarli\Front\Controller\Visitor\FeedController:rss'); - $this->get('/open-search', '\Shaarli\Front\Controller\Visitor\OpenSearchController:index'); - - $this->get('/add-tag/{newTag}', '\Shaarli\Front\Controller\Visitor\TagController:addTag'); - $this->get('/remove-tag/{tag}', '\Shaarli\Front\Controller\Visitor\TagController:removeTag'); - $this->get('/links-per-page', '\Shaarli\Front\Controller\Visitor\PublicSessionFilterController:linksPerPage'); - $this->get('/untagged-only', '\Shaarli\Front\Controller\Visitor\PublicSessionFilterController:untaggedOnly'); -})->add('\Shaarli\Front\ShaarliMiddleware'); - -$app->group('/admin', function () { - $this->get('/logout', '\Shaarli\Front\Controller\Admin\LogoutController:index'); - $this->get('/tools', '\Shaarli\Front\Controller\Admin\ToolsController:index'); - $this->get('/password', '\Shaarli\Front\Controller\Admin\PasswordController:index'); - $this->post('/password', '\Shaarli\Front\Controller\Admin\PasswordController:change'); - $this->get('/configure', '\Shaarli\Front\Controller\Admin\ConfigureController:index'); - $this->post('/configure', '\Shaarli\Front\Controller\Admin\ConfigureController:save'); - $this->get('/tags', '\Shaarli\Front\Controller\Admin\ManageTagController:index'); - $this->post('/tags', '\Shaarli\Front\Controller\Admin\ManageTagController:save'); - $this->post('/tags/change-separator', '\Shaarli\Front\Controller\Admin\ManageTagController:changeSeparator'); - $this->get('/add-shaare', '\Shaarli\Front\Controller\Admin\ShaareAddController:addShaare'); - $this->get('/shaare', '\Shaarli\Front\Controller\Admin\ShaarePublishController:displayCreateForm'); - $this->get('/shaare/{id:[0-9]+}', '\Shaarli\Front\Controller\Admin\ShaarePublishController:displayEditForm'); - $this->get('/shaare/private/{hash}', '\Shaarli\Front\Controller\Admin\ShaareManageController:sharePrivate'); - $this->post('/shaare-batch', '\Shaarli\Front\Controller\Admin\ShaarePublishController:displayCreateBatchForms'); - $this->post('/shaare', '\Shaarli\Front\Controller\Admin\ShaarePublishController:save'); - $this->get('/shaare/delete', '\Shaarli\Front\Controller\Admin\ShaareManageController:deleteBookmark'); - $this->get('/shaare/visibility', '\Shaarli\Front\Controller\Admin\ShaareManageController:changeVisibility'); - $this->post('/shaare/update-tags', '\Shaarli\Front\Controller\Admin\ShaareManageController:addOrDeleteTags'); - $this->get('/shaare/{id:[0-9]+}/pin', '\Shaarli\Front\Controller\Admin\ShaareManageController:pinBookmark'); - $this->patch( + $group->get('/', Controller\Visitor\BookmarkListController::class . ':index'); + $group->get('/shaare/{hash}', Controller\Visitor\BookmarkListController::class . ':permalink'); + $group->get('/login', Controller\Visitor\LoginController::class . ':index')->setName('login'); + $group->post('/login', Controller\Visitor\LoginController::class . ':login')->setName('processLogin'); + $group->get('/picture-wall', Controller\Visitor\PictureWallController::class . ':index'); + $group->get('/tags/cloud', Controller\Visitor\TagCloudController::class . ':cloud'); + $group->get('/tags/list', Controller\Visitor\TagCloudController::class . ':list'); + $group->get('/daily', Controller\Visitor\DailyController::class . ':index'); + $group->get('/daily-rss', Controller\Visitor\DailyController::class . ':rss')->setName('rss'); + $group->get('/feed/atom', Controller\Visitor\FeedController::class . ':atom')->setName('atom'); + $group->get('/feed/rss', Controller\Visitor\FeedController::class . ':rss'); + $group->get('/open-search', Controller\Visitor\OpenSearchController::class . ':index'); + + $group->get('/add-tag/{newTag}', Controller\Visitor\TagController::class . ':addTag'); + $group->get('/remove-tag/{tag}', Controller\Visitor\TagController::class . ':removeTag'); + $group->get('/links-per-page', Controller\Visitor\PublicSessionFilterController::class . ':linksPerPage'); + $group->get('/untagged-only', Controller\Visitor\PublicSessionFilterController::class . ':untaggedOnly'); +})->add(\Shaarli\Front\ShaarliMiddleware::class); + +$app->group('/admin', function (RouteCollectorProxy $group) { + $group->get('/logout', Controller\Admin\LogoutController::class . ':index'); + $group->get('/tools', Controller\Admin\ToolsController::class . ':index'); + $group->get('/password', Controller\Admin\PasswordController::class . ':index'); + $group->post('/password', Controller\Admin\PasswordController::class . ':change'); + $group->get('/configure', Controller\Admin\ConfigureController::class . ':index'); + $group->post('/configure', Controller\Admin\ConfigureController::class . ':save'); + $group->get('/tags', Controller\Admin\ManageTagController::class . ':index'); + $group->post('/tags', Controller\Admin\ManageTagController::class . ':save'); + $group->post('/tags/change-separator', Controller\Admin\ManageTagController::class . ':changeSeparator'); + $group->get('/add-shaare', Controller\Admin\ShaareAddController::class . ':addShaare'); + $group->get('/shaare', Controller\Admin\ShaarePublishController::class . ':displayCreateForm'); + $group->get('/shaare/{id:[0-9]+}', Controller\Admin\ShaarePublishController::class . ':displayEditForm'); + $group->get('/shaare/private/{hash}', Controller\Admin\ShaareManageController::class . ':sharePrivate'); + $group->post('/shaare-batch', Controller\Admin\ShaarePublishController::class . ':displayCreateBatchForms'); + $group->post('/shaare', Controller\Admin\ShaarePublishController::class . ':save'); + $group->get('/shaare/delete', Controller\Admin\ShaareManageController::class . ':deleteBookmark'); + $group->get('/shaare/visibility', Controller\Admin\ShaareManageController::class . ':changeVisibility'); + $group->post('/shaare/update-tags', Controller\Admin\ShaareManageController::class . ':addOrDeleteTags'); + $group->get('/shaare/{id:[0-9]+}/pin', Controller\Admin\ShaareManageController::class . ':pinBookmark'); + $group->patch( '/shaare/{id:[0-9]+}/update-thumbnail', - '\Shaarli\Front\Controller\Admin\ThumbnailsController:ajaxUpdate' + Controller\Admin\ThumbnailsController::class . ':ajaxUpdate' ); - $this->get('/export', '\Shaarli\Front\Controller\Admin\ExportController:index'); - $this->post('/export', '\Shaarli\Front\Controller\Admin\ExportController:export'); - $this->get('/import', '\Shaarli\Front\Controller\Admin\ImportController:index'); - $this->post('/import', '\Shaarli\Front\Controller\Admin\ImportController:import'); - $this->get('/plugins', '\Shaarli\Front\Controller\Admin\PluginsController:index'); - $this->post('/plugins', '\Shaarli\Front\Controller\Admin\PluginsController:save'); - $this->get('/token', '\Shaarli\Front\Controller\Admin\TokenController:getToken'); - $this->get('/server', '\Shaarli\Front\Controller\Admin\ServerController:index'); - $this->get('/clear-cache', '\Shaarli\Front\Controller\Admin\ServerController:clearCache'); - $this->get('/thumbnails', '\Shaarli\Front\Controller\Admin\ThumbnailsController:index'); - $this->get('/metadata', '\Shaarli\Front\Controller\Admin\MetadataController:ajaxRetrieveTitle'); - $this->get('/visibility/{visibility}', '\Shaarli\Front\Controller\Admin\SessionFilterController:visibility'); -})->add('\Shaarli\Front\ShaarliAdminMiddleware'); - -$app->group('/plugin', function () use ($pluginManager) { + $group->get('/export', Controller\Admin\ExportController::class . ':index'); + $group->post('/export', Controller\Admin\ExportController::class . ':export'); + $group->get('/import', Controller\Admin\ImportController::class . ':index'); + $group->post('/import', Controller\Admin\ImportController::class . ':import'); + $group->get('/plugins', Controller\Admin\PluginsController::class . ':index'); + $group->post('/plugins', Controller\Admin\PluginsController::class . ':save'); + $group->get('/token', Controller\Admin\TokenController::class . ':getToken'); + $group->get('/server', Controller\Admin\ServerController::class . ':index'); + $group->get('/clear-cache', Controller\Admin\ServerController::class . ':clearCache'); + $group->get('/thumbnails', Controller\Admin\ThumbnailsController::class . ':index'); + $group->get('/metadata', Controller\Admin\MetadataController::class . ':ajaxRetrieveTitle'); + $group->get('/visibility/{visibility}', Controller\Admin\SessionFilterController::class . ':visibility'); +})->add(\Shaarli\Front\ShaarliAdminMiddleware::class); + +$app->group('/plugin', function (RouteCollectorProxy $group) use ($pluginManager) { foreach ($pluginManager->getRegisteredRoutes() as $pluginName => $routes) { - $this->group('/' . $pluginName, function () use ($routes) { + $group->group('/' . $pluginName, function (RouteCollectorProxy $subgroup) use ($routes) { foreach ($routes as $route) { - $this->{strtolower($route['method'])}('/' . ltrim($route['route'], '/'), $route['callable']); + $subgroup->{strtolower($route['method'])}('/' . ltrim($route['route'], '/'), $route['callable']); } }); } -})->add('\Shaarli\Front\ShaarliMiddleware'); +})->add(\Shaarli\Front\ShaarliMiddleware::class); // REST API routes -$app->group('/api/v1', function () { - $this->get('/info', '\Shaarli\Api\Controllers\Info:getInfo')->setName('getInfo'); - $this->get('/links', '\Shaarli\Api\Controllers\Links:getLinks')->setName('getLinks'); - $this->get('/links/{id:[\d]+}', '\Shaarli\Api\Controllers\Links:getLink')->setName('getLink'); - $this->post('/links', '\Shaarli\Api\Controllers\Links:postLink')->setName('postLink'); - $this->put('/links/{id:[\d]+}', '\Shaarli\Api\Controllers\Links:putLink')->setName('putLink'); - $this->delete('/links/{id:[\d]+}', '\Shaarli\Api\Controllers\Links:deleteLink')->setName('deleteLink'); - - $this->get('/tags', '\Shaarli\Api\Controllers\Tags:getTags')->setName('getTags'); - $this->get('/tags/{tagName:[\w]+}', '\Shaarli\Api\Controllers\Tags:getTag')->setName('getTag'); - $this->put('/tags/{tagName:[\w]+}', '\Shaarli\Api\Controllers\Tags:putTag')->setName('putTag'); - $this->delete('/tags/{tagName:[\w]+}', '\Shaarli\Api\Controllers\Tags:deleteTag')->setName('deleteTag'); - - $this->get('/history', '\Shaarli\Api\Controllers\HistoryController:getHistory')->setName('getHistory'); -})->add('\Shaarli\Api\ApiMiddleware'); +$app->group('/api/v1', function (RouteCollectorProxy $group) { + $group->get('/info', ApiControllers\Info::class . ':getInfo')->setName('getInfo'); + $group->get('/links', ApiControllers\Links::class . ':getLinks')->setName('getLinks'); + $group->get('/links/{id:[\d]+}', ApiControllers\Links::class . ':getLink')->setName('getLink'); + $group->post('/links', ApiControllers\Links::class . ':postLink')->setName('postLink'); + $group->put('/links/{id:[\d]+}', ApiControllers\Links::class . ':putLink')->setName('putLink'); + $group->delete('/links/{id:[\d]+}', ApiControllers\Links::class . ':deleteLink')->setName('deleteLink'); + + $group->get('/tags', ApiControllers\Tags::class . ':getTags')->setName('getTags'); + $group->get('/tags/{tagName:[\w]+}', ApiControllers\Tags::class . ':getTag')->setName('getTag'); + $group->put('/tags/{tagName:[\w]+}', ApiControllers\Tags::class . ':putTag')->setName('putTag'); + $group->delete('/tags/{tagName:[\w]+}', ApiControllers\Tags::class . ':deleteTag')->setName('deleteTag'); + + $group->get('/history', ApiControllers\HistoryController::class . ':getHistory')->setName('getHistory'); +})->add(\Shaarli\Api\ApiMiddleware::class); + +$errorMiddleware = $app->addErrorMiddleware($displayErrorDetails, true, true); +$errorMiddleware->setDefaultErrorHandler( + new ShaarliErrorHandler($app->getCallableResolver(), $app->getResponseFactory(), $logger, $container) +); + try { - $response = $app->run(true); - $app->respond($response); + $app->run(); } catch (Throwable $e) { die(nl2br( 'An unexpected error happened, and the error template could not be displayed.' . PHP_EOL . PHP_EOL . diff --git a/plugins/demo_plugin/DemoPluginController.php b/plugins/demo_plugin/DemoPluginController.php index b8ace9c80..de40c405c 100644 --- a/plugins/demo_plugin/DemoPluginController.php +++ b/plugins/demo_plugin/DemoPluginController.php @@ -4,9 +4,9 @@ namespace Shaarli\DemoPlugin; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Controller\Admin\ShaarliAdminController; -use Slim\Http\Request; -use Slim\Http\Response; class DemoPluginController extends ShaarliAdminController { diff --git a/plugins/readitlater/ReadItLaterController.php b/plugins/readitlater/ReadItLaterController.php index 9e1a4a8ed..c7f953fe4 100644 --- a/plugins/readitlater/ReadItLaterController.php +++ b/plugins/readitlater/ReadItLaterController.php @@ -4,9 +4,9 @@ namespace Shaarli\Plugin\ReadItLater; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Controller\Admin\ShaarliAdminController; -use Slim\Http\Request; -use Slim\Http\Response; class ReadItLaterController extends ShaarliAdminController { @@ -15,9 +15,9 @@ class ReadItLaterController extends ShaarliAdminController */ public function toggleFilterBookmarkList(Request $request, Response $response): Response { - $this->container->sessionManager->setSessionParameter( + $this->container->get('sessionManager')->setSessionParameter( 'readitlater-only', - !$this->container->sessionManager->getSessionParameter('readitlater-only', false) + !$this->container->get('sessionManager')->getSessionParameter('readitlater-only', false) ); return $this->redirectFromReferer($request, $response, ['readitlater']); @@ -28,18 +28,18 @@ public function toggleFilterBookmarkList(Request $request, Response $response): */ public function toggleBookmark(Request $request, Response $response, array $args): Response { - if (!array_key_exists('id', $args) || !$this->container->bookmarkService->exists((int) $args['id'])) { + if (!array_key_exists('id', $args) || !$this->container->get('bookmarkService')->exists((int) $args['id'])) { $this->saveErrorMessage('Invalid ID provided.'); return $this->redirectFromReferer($request, $response, ['readitlater']); } - $bookmark = $this->container->bookmarkService->get((int) $args['id']); + $bookmark = $this->container->get('bookmarkService')->get((int) $args['id']); $bookmark->setAdditionalContentEntry( 'readitlater', !$bookmark->getAdditionalContentEntry('readitlater', false) ); - $this->container->bookmarkService->save(); + $this->container->get('bookmarkService')->save(); return $this->redirectFromReferer($request, $response, ['readitlater']); } diff --git a/tests/api/ApiMiddlewareTest.php b/tests/api/ApiMiddlewareTest.php index 6e2226816..443ebab59 100644 --- a/tests/api/ApiMiddlewareTest.php +++ b/tests/api/ApiMiddlewareTest.php @@ -2,14 +2,15 @@ namespace Shaarli\Api; +use DI\Container as DIContainer; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; +use Shaarli\Tests\Utils\FakeRequestHandler; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; -use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Headers; +use Slim\Psr7\Uri; /** * Class ApiMiddlewareTest @@ -39,7 +40,7 @@ class ApiMiddlewareTest extends \Shaarli\TestCase protected $refDB = null; /** - * @var Container instance. + * @var DIContainer instance. */ protected $container; @@ -56,10 +57,10 @@ protected function setUp(): void $history = new History('sandbox/history.php'); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['history'] = $history; - $this->container['pluginManager'] = new PluginManager($this->conf); + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('history', $history); + $this->container->set('pluginManager', new PluginManager($this->conf)); } /** @@ -75,19 +76,15 @@ protected function tearDown(): void */ public function testInvokeMiddlewareWithValidToken(): void { - $next = function (Request $request, Response $response): Response { - return $response; - }; $mw = new ApiMiddleware($this->container); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'REQUEST_URI' => '/echo', - 'HTTP_AUTHORIZATION' => 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard'), - ]); - $request = Request::createFromEnvironment($env); - $response = new Response(); - /** @var Response $response */ - $response = $mw($request, $response, $next); + $request = new FakeRequest( + 'GET', + (new Uri('', ''))->withPath('/hello'), + new Headers([ + 'HTTP_AUTHORIZATION' => 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard') + ]) + ); + $response = $mw($request, new FakeRequestHandler()); $this->assertEquals(200, $response->getStatusCode()); } @@ -98,21 +95,18 @@ public function testInvokeMiddlewareWithValidToken(): void */ public function testInvokeMiddlewareWithValidTokenFromRedirectedHeader(): void { - $next = function (Request $request, Response $response): Response { - return $response; - }; - $token = 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard'); - $this->container->environment['REDIRECT_HTTP_AUTHORIZATION'] = $token; $mw = new ApiMiddleware($this->container); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'REQUEST_URI' => '/echo', - ]); - $request = Request::createFromEnvironment($env); - $response = new Response(); - /** @var Response $response */ - $response = $mw($request, $response, $next); + $request = new FakeRequest( + 'GET', + (new Uri('', ''))->withPath('/hello'), + new Headers([]), + [], + [ + 'REDIRECT_HTTP_AUTHORIZATION' => $token, + ] + ); + $response = $mw($request, new FakeRequestHandler()); $this->assertEquals(200, $response->getStatusCode()); } @@ -124,15 +118,17 @@ public function testInvokeMiddlewareWithValidTokenFromRedirectedHeader(): void public function testInvokeMiddlewareApiDisabled() { $this->conf->set('api.enabled', false); + $this->container->set('conf', $this->conf); + $mw = new ApiMiddleware($this->container); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'REQUEST_URI' => '/echo', - ]); - $request = Request::createFromEnvironment($env); - $response = new Response(); - /** @var Response $response */ - $response = $mw($request, $response, null); + $request = new FakeRequest( + 'GET', + (new Uri('', ''))->withPath('/hello'), + new Headers([ + 'HTTP_AUTHORIZATION' => 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard') + ]) + ); + $response = $mw($request, new FakeRequestHandler()); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -147,15 +143,17 @@ public function testInvokeMiddlewareApiDisabledDebug() { $this->conf->set('api.enabled', false); $this->conf->set('dev.debug', true); + $this->container->set('conf', $this->conf); + $mw = new ApiMiddleware($this->container); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'REQUEST_URI' => '/echo', - ]); - $request = Request::createFromEnvironment($env); - $response = new Response(); - /** @var Response $response */ - $response = $mw($request, $response, null); + $request = new FakeRequest( + 'GET', + (new Uri('', ''))->withPath('/hello'), + new Headers([ + 'HTTP_AUTHORIZATION' => 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard') + ]) + ); + $response = $mw($request, new FakeRequestHandler()); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -170,15 +168,14 @@ public function testInvokeMiddlewareApiDisabledDebug() public function testInvokeMiddlewareNoTokenProvidedDebug() { $this->conf->set('dev.debug', true); + $this->container->set('conf', $this->conf); + $mw = new ApiMiddleware($this->container); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'REQUEST_URI' => '/echo', - ]); - $request = Request::createFromEnvironment($env); - $response = new Response(); - /** @var Response $response */ - $response = $mw($request, $response, null); + $request = new FakeRequest( + 'GET', + (new Uri('', ''))->withPath('/hello') + ); + $response = $mw($request, new FakeRequestHandler()); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -194,16 +191,17 @@ public function testInvokeMiddlewareNoSecretSetDebug() { $this->conf->set('dev.debug', true); $this->conf->set('api.secret', ''); + $this->container->set('conf', $this->conf); + $mw = new ApiMiddleware($this->container); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'REQUEST_URI' => '/echo', - 'HTTP_AUTHORIZATION' => 'Bearer jwt', - ]); - $request = Request::createFromEnvironment($env); - $response = new Response(); - /** @var Response $response */ - $response = $mw($request, $response, null); + $request = new FakeRequest( + 'GET', + (new Uri('', ''))->withPath('/hello'), + new Headers([ + 'HTTP_AUTHORIZATION' => 'Bearer jwt' + ]) + ); + $response = $mw($request, new FakeRequestHandler()); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -217,16 +215,17 @@ public function testInvokeMiddlewareNoSecretSetDebug() public function testInvalidJwtAuthHeaderDebug() { $this->conf->set('dev.debug', true); + $this->container->set('conf', $this->conf); + $mw = new ApiMiddleware($this->container); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'REQUEST_URI' => '/echo', - 'HTTP_AUTHORIZATION' => 'PolarBearer jwt', - ]); - $request = Request::createFromEnvironment($env); - $response = new Response(); - /** @var Response $response */ - $response = $mw($request, $response, null); + $request = new FakeRequest( + 'GET', + (new Uri('', ''))->withPath('/hello'), + new Headers([ + 'HTTP_AUTHORIZATION' => 'PolarBearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard') + ]) + ); + $response = $mw($request, new FakeRequestHandler()); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -243,16 +242,17 @@ public function testInvalidJwtAuthHeaderDebug() public function testInvokeMiddlewareInvalidJwtDebug() { $this->conf->set('dev.debug', true); + $this->container->set('conf', $this->conf); + $mw = new ApiMiddleware($this->container); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'REQUEST_URI' => '/echo', - 'HTTP_AUTHORIZATION' => 'Bearer jwt', - ]); - $request = Request::createFromEnvironment($env); - $response = new Response(); - /** @var Response $response */ - $response = $mw($request, $response, null); + $request = new FakeRequest( + 'GET', + (new Uri('', ''))->withPath('/hello'), + new Headers([ + 'HTTP_AUTHORIZATION' => 'Bearer jwt' + ]) + ); + $response = $mw($request, new FakeRequestHandler()); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); diff --git a/tests/api/controllers/history/HistoryTest.php b/tests/api/controllers/history/HistoryTest.php index f0596b913..4e89b6d9b 100644 --- a/tests/api/controllers/history/HistoryTest.php +++ b/tests/api/controllers/history/HistoryTest.php @@ -2,14 +2,15 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; +use Psr\Container\ContainerInterface as Container; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceHistory; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; class HistoryTest extends TestCase { @@ -46,10 +47,10 @@ protected function setUp(): void $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->refHistory = new ReferenceHistory(); $this->refHistory->write(self::$testHistory); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['db'] = true; - $this->container['history'] = new History(self::$testHistory); + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('db', true); + $this->container->set('history', new History(self::$testHistory)); $this->controller = new HistoryController($this->container); } @@ -67,12 +68,11 @@ protected function tearDown(): void */ public function testGetHistory() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = new FakeRequest( + 'GET' + ); - $response = $this->controller->getHistory($request, new Response()); + $response = $this->controller->getHistory($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -119,13 +119,11 @@ public function testGetHistory() */ public function testGetHistoryLimit() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'limit=1' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET' + ))->withQueryParams(['limit' => '1']); - $response = $this->controller->getHistory($request, new Response()); + $response = $this->controller->getHistory($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -144,13 +142,11 @@ public function testGetHistoryLimit() */ public function testGetHistoryOffset() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'offset=4' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET' + ))->withQueryParams(['offset' => '4']); - $response = $this->controller->getHistory($request, new Response()); + $response = $this->controller->getHistory($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -169,13 +165,11 @@ public function testGetHistoryOffset() */ public function testGetHistorySince() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'since=2017-03-03T00:00:00%2B00:00' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET' + ))->withQueryParams(['since' => '2017-03-03T00:00:00+00:00']); - $response = $this->controller->getHistory($request, new Response()); + $response = $this->controller->getHistory($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -194,13 +188,11 @@ public function testGetHistorySince() */ public function testGetHistorySinceOffsetLimit() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'since=2017-02-01T00:00:00%2B00:00&offset=1&limit=1' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET' + ))->withQueryParams(['since' => '2017-02-01T00:00:00%2B00:00', 'offset' => '1', 'limit' => '1']); - $response = $this->controller->getHistory($request, new Response()); + $response = $this->controller->getHistory($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); diff --git a/tests/api/controllers/info/InfoTest.php b/tests/api/controllers/info/InfoTest.php index 2b0fd5107..82d618513 100644 --- a/tests/api/controllers/info/InfoTest.php +++ b/tests/api/controllers/info/InfoTest.php @@ -2,17 +2,18 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; /** * Class InfoTest @@ -48,6 +49,11 @@ class InfoTest extends TestCase */ protected $controller; + /** + * @var PluginManager plugin Manager + */ + protected $pluginManager; + /** * Before every test, instantiate a new Api with its config, plugins and bookmarks. */ @@ -61,16 +67,16 @@ protected function setUp(): void $this->pluginManager = new PluginManager($this->conf); $history = new History('sandbox/history.php'); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['db'] = new BookmarkFileService( + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('db', new BookmarkFileService( $this->conf, $this->pluginManager, $history, $mutex, true - ); - $this->container['history'] = null; + )); + $this->container->set('history', null); $this->controller = new Info($this->container); } @@ -88,12 +94,11 @@ protected function tearDown(): void */ public function testGetInfo() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = new FakeRequest( + 'GET' + ); - $response = $this->controller->getInfo($request, new Response()); + $response = $this->controller->getInfo($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -116,7 +121,7 @@ public function testGetInfo() $this->conf->set('general.enabled_plugins', $enabledPlugins); $this->conf->set('privacy.default_private_links', $defaultPrivateLinks); - $response = $this->controller->getInfo($request, new Response()); + $response = $this->controller->getInfo($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); diff --git a/tests/api/controllers/links/DeleteLinkTest.php b/tests/api/controllers/links/DeleteLinkTest.php index 2c3c3eccf..f8715ab8a 100644 --- a/tests/api/controllers/links/DeleteLinkTest.php +++ b/tests/api/controllers/links/DeleteLinkTest.php @@ -2,17 +2,18 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; class DeleteLinkTest extends \Shaarli\TestCase { @@ -42,7 +43,7 @@ class DeleteLinkTest extends \Shaarli\TestCase protected $bookmarkService; /** - * @var HistoryController instance. + * @var History instance. */ protected $history; @@ -84,10 +85,10 @@ protected function setUp(): void true ); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['db'] = $this->bookmarkService; - $this->container['history'] = $this->history; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('db', $this->bookmarkService); + $this->container->set('history', $this->history); $this->controller = new Links($this->container); } @@ -108,12 +109,11 @@ public function testDeleteLinkValid() { $id = '41'; $this->assertTrue($this->bookmarkService->exists($id)); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'DELETE', - ]); - $request = Request::createFromEnvironment($env); + $request = new FakeRequest( + 'DELETE' + ); - $response = $this->controller->deleteLink($request, new Response(), ['id' => $id]); + $response = $this->controller->deleteLink($request, new SlimResponse(), ['id' => $id]); $this->assertEquals(204, $response->getStatusCode()); $this->assertEmpty((string) $response->getBody()); @@ -143,11 +143,10 @@ public function testDeleteLink404() $id = -1; $this->assertFalse($this->bookmarkService->exists($id)); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'DELETE', - ]); - $request = Request::createFromEnvironment($env); + $request = new FakeRequest( + 'DELETE' + ); - $this->controller->deleteLink($request, new Response(), ['id' => $id]); + $this->controller->deleteLink($request, new SlimResponse(), ['id' => $id]); } } diff --git a/tests/api/controllers/links/GetLinkIdTest.php b/tests/api/controllers/links/GetLinkIdTest.php index 5fbb75051..78238db46 100644 --- a/tests/api/controllers/links/GetLinkIdTest.php +++ b/tests/api/controllers/links/GetLinkIdTest.php @@ -2,17 +2,18 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\Bookmark; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; /** * Class GetLinkIdTest @@ -67,17 +68,17 @@ protected function setUp(): void $this->refDB->write(self::$testDatastore); $history = new History('sandbox/history.php'); - $this->container = new Container(); - $this->container['conf'] = $this->conf; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); $pluginManager = new PluginManager($this->conf); - $this->container['db'] = new BookmarkFileService( + $this->container->set('db', new BookmarkFileService( $this->conf, $pluginManager, $history, $mutex, true - ); - $this->container['history'] = null; + )); + $this->container->set('history', null); $this->controller = new Links($this->container); } @@ -101,12 +102,11 @@ public function testGetLinkId() $_SERVER['SCRIPT_NAME'] = '/'; $id = 41; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET' + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLink($request, new Response(), ['id' => $id]); + $response = $this->controller->getLink($request, new SlimResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); @@ -137,11 +137,8 @@ public function testGetLink404() $this->expectException(\Shaarli\Api\Exceptions\ApiLinkNotFoundException::class); $this->expectExceptionMessage('Link not found'); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = new FakeRequest(); - $this->controller->getLink($request, new Response(), ['id' => -1]); + $this->controller->getLink($request, new SlimResponse(), ['id' => -1]); } } diff --git a/tests/api/controllers/links/GetLinksTest.php b/tests/api/controllers/links/GetLinksTest.php index 217eb5d16..ca78dcde4 100644 --- a/tests/api/controllers/links/GetLinksTest.php +++ b/tests/api/controllers/links/GetLinksTest.php @@ -2,18 +2,20 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\Bookmark; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Bookmark\LinkDB; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; /** * Class GetLinksTest @@ -68,17 +70,17 @@ protected function setUp(): void $this->refDB->write(self::$testDatastore); $history = new History('sandbox/history.php'); - $this->container = new Container(); - $this->container['conf'] = $this->conf; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); $pluginManager = new PluginManager($this->conf); - $this->container['db'] = new BookmarkFileService( + $this->container->set('db', new BookmarkFileService( $this->conf, $pluginManager, $history, $mutex, true - ); - $this->container['history'] = null; + )); + $this->container->set('history', null); $this->controller = new Links($this->container); } @@ -96,17 +98,11 @@ protected function tearDown(): void */ public function testGetLinks() { - // Used by index_url(). - $_SERVER['SERVER_NAME'] = 'domain.tld'; - $_SERVER['SERVER_PORT'] = 80; - $_SERVER['SCRIPT_NAME'] = '/'; - - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET' + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new Response()); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals($this->refDB->countLinks(), count($data)); @@ -153,12 +149,12 @@ public function testGetLinks() */ public function testGetLinksOffsetLimit() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'offset=3&limit=1' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'offset=3&limit=1'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -171,12 +167,11 @@ public function testGetLinksOffsetLimit() */ public function testGetLinksLimitAll() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'limit=all' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'limit=all'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals($this->refDB->countLinks(), count($data)); @@ -195,12 +190,11 @@ public function testGetLinksLimitAll() */ public function testGetLinksOffsetTooHigh() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'offset=100' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'offset=100'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEmpty(count($data)); @@ -211,14 +205,11 @@ public function testGetLinksOffsetTooHigh() */ public function testGetLinksVisibilityAll() { - $env = Environment::mock( - [ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'visibility=all' - ] - ); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'visibility=all'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string)$response->getBody(), true); $this->assertEquals($this->refDB->countLinks(), count($data)); @@ -232,12 +223,11 @@ public function testGetLinksVisibilityAll() */ public function testGetLinksVisibilityPrivate() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'visibility=private' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'visibility=private'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals($this->refDB->countPrivateLinks(), count($data)); @@ -250,14 +240,11 @@ public function testGetLinksVisibilityPrivate() */ public function testGetLinksVisibilityPublic() { - $env = Environment::mock( - [ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'visibility=public' - ] - ); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'visibility=public'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string)$response->getBody(), true); $this->assertEquals($this->refDB->countPublicLinks(), count($data)); @@ -273,12 +260,14 @@ public function testGetLinksVisibilityPublic() public function testGetLinksSearchTerm() { // Only in description - 1 result - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchterm=Tropical' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchterm=Tropical'), + null, + [], + ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80] + ); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -286,12 +275,11 @@ public function testGetLinksSearchTerm() $this->assertEquals(self::NB_FIELDS_LINK, count($data[0])); // Only in tags - 1 result - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchterm=tag3' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchterm=tag3'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -299,12 +287,14 @@ public function testGetLinksSearchTerm() $this->assertEquals(self::NB_FIELDS_LINK, count($data[0])); // Multiple results (2) - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchterm=stallman' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchterm=stallman'), + null, + [], + ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80] + ); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); @@ -314,12 +304,11 @@ public function testGetLinksSearchTerm() $this->assertEquals(self::NB_FIELDS_LINK, count($data[1])); // Multiword - 2 results - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchterm=stallman+software' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchterm=stallman+software'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); @@ -329,12 +318,11 @@ public function testGetLinksSearchTerm() $this->assertEquals(self::NB_FIELDS_LINK, count($data[1])); // URL encoding - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchterm=' . urlencode('@web') - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchterm=' . urlencode('@web')), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); @@ -346,12 +334,11 @@ public function testGetLinksSearchTerm() public function testGetLinksSearchTermNoResult() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchterm=nope' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchterm=nope'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(0, count($data)); @@ -360,12 +347,11 @@ public function testGetLinksSearchTermNoResult() public function testGetLinksSearchTags() { // Single tag - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=dev', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=dev'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); @@ -375,12 +361,11 @@ public function testGetLinksSearchTags() $this->assertEquals(self::NB_FIELDS_LINK, count($data[1])); // Multitag + exclude - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=stuff+-gnu', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=stuff+-gnu') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -388,48 +373,50 @@ public function testGetLinksSearchTags() $this->assertEquals(self::NB_FIELDS_LINK, count($data[0])); // wildcard: placeholder at the start - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=*Tuff', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=*Tuff'), + null, + [], + ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80] + ); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); $this->assertEquals(41, $data[0]['id']); // wildcard: placeholder at the end - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=c*', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=c*') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(5, count($data)); $this->assertEquals(6, $data[0]['id']); // wildcard: placeholder at the middle - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=w*b', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=w*b'), + null, + [], + ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80] + ); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(4, count($data)); $this->assertEquals(6, $data[0]['id']); // wildcard: match all - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=*', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=*') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(ReferenceLinkDB::$NB_LINKS_TOTAL, count($data)); @@ -437,36 +424,33 @@ public function testGetLinksSearchTags() $this->assertEquals(41, $data[2]['id']); // wildcard: optional ('*' does not need to expand) - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=*stuff*', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=*stuff*') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); $this->assertEquals(41, $data[0]['id']); // wildcard: exclusions - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=*a*+-*e*', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=*a*+-*e*') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); $this->assertEquals(41, $data[0]['id']); // finds '#hashtag' in descr. // wildcard: exclude all - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchtags=-*', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchtags=-*'), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(0, count($data)); @@ -477,12 +461,11 @@ public function testGetLinksSearchTags() */ public function testGetLinksSearchTermsAndTags() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'searchterm=poke&searchtags=dev', - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getLinks($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'searchterm=poke&searchtags=dev') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $response = $this->controller->getLinks($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); diff --git a/tests/api/controllers/links/PostLinkTest.php b/tests/api/controllers/links/PostLinkTest.php index faf43ee10..aba5c30cc 100644 --- a/tests/api/controllers/links/PostLinkTest.php +++ b/tests/api/controllers/links/PostLinkTest.php @@ -2,20 +2,24 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\Bookmark; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; +use Shaarli\Tests\Utils\FakeRouteCollector; use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; use Slim\Router; +use Slim\Routing\RouteContext; /** * Class PostLinkTest @@ -52,10 +56,16 @@ class PostLinkTest extends TestCase protected $bookmarkService; /** - * @var HistoryController instance. + * @var History instance. */ protected $history; + + /** + * @var RouteParser instance. + */ + protected $routeParser; + /** * @var Container instance. */ @@ -92,27 +102,15 @@ protected function setUp(): void $mutex, true ); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['db'] = $this->bookmarkService; - $this->container['history'] = $this->history; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('db', $this->bookmarkService); + $this->container->set('history', $this->history); $this->controller = new Links($this->container); - - $mock = $this->createMock(Router::class); - $mock->expects($this->any()) - ->method('pathFor') - ->willReturn('/api/v1/bookmarks/1'); - - // affect @property-read... seems to work - $this->controller->getCi()->router = $mock; - - // Used by index_url(). - $this->controller->getCi()['environment'] = [ - 'SERVER_NAME' => 'domain.tld', - 'SERVER_PORT' => 80, - 'SCRIPT_NAME' => '/', - ]; + $this->routeParser = (new FakeRouteCollector()) + ->addRoute('POST', '/api/v1/bookmarks/{id:[\d]+}', 'getLink') + ->getRouteParser(); } /** @@ -129,15 +127,15 @@ protected function tearDown(): void */ public function testPostLinkMinimal() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'POST', - ]); - - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $response = $this->controller->postLink($request, new Response()); + $response = $this->controller->postLink($request, new SlimResponse()); $this->assertEquals(201, $response->getStatusCode()); - $this->assertEquals('/api/v1/bookmarks/1', $response->getHeader('Location')[0]); + $this->assertEquals('/api/v1/bookmarks/43', $response->getHeader('Location')[0]); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); $this->assertEquals(43, $data['id']); @@ -147,8 +145,9 @@ public function testPostLinkMinimal() $this->assertEquals('', $data['description']); $this->assertEquals([], $data['tags']); $this->assertEquals(true, $data['private']); + $dt = new \DateTime('5 seconds ago'); $this->assertTrue( - new \DateTime('5 seconds ago') < \DateTime::createFromFormat(\DateTime::ATOM, $data['created']) + $dt < \DateTime::createFromFormat(\DateTime::ATOM, $data['created']) ); $this->assertEquals('', $data['updated']); @@ -174,17 +173,17 @@ public function testPostLinkFull() 'created' => '2015-05-05T12:30:00+03:00', 'updated' => '2016-06-05T14:32:10+03:00', ]; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'POST', - 'CONTENT_TYPE' => 'application/json' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'website.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($link); - $response = $this->controller->postLink($request, new Response()); + $response = $this->controller->postLink($request, new SlimResponse()); $this->assertEquals(201, $response->getStatusCode()); - $this->assertEquals('/api/v1/bookmarks/1', $response->getHeader('Location')[0]); + $this->assertEquals('/api/v1/bookmarks/43', $response->getHeader('Location')[0]); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); $this->assertEquals(43, $data['id']); @@ -210,14 +209,14 @@ public function testPostLinkDuplicate() 'tags' => ['one', 'two'], 'private' => true, ]; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'POST', - 'CONTENT_TYPE' => 'application/json' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($link); - $response = $this->controller->postLink($request, new Response()); + $response = $this->controller->postLink($request, new SlimResponse()); $this->assertEquals(409, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -247,17 +246,16 @@ public function testPostLinkWithTagString(): void $link = [ 'tags' => 'one two', ]; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'POST', - 'CONTENT_TYPE' => 'application/json' - ]); - - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($link); - $response = $this->controller->postLink($request, new Response()); + $response = $this->controller->postLink($request, new SlimResponse()); $this->assertEquals(201, $response->getStatusCode()); - $this->assertEquals('/api/v1/bookmarks/1', $response->getHeader('Location')[0]); + $this->assertEquals('/api/v1/bookmarks/43', $response->getHeader('Location')[0]); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); $this->assertEquals(['one', 'two'], $data['tags']); @@ -271,17 +269,16 @@ public function testPostLinkWithTagString2(): void $link = [ 'tags' => ['one two'], ]; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'POST', - 'CONTENT_TYPE' => 'application/json' - ]); - - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'POST', + new Uri('', ''), + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($link); - $response = $this->controller->postLink($request, new Response()); + $response = $this->controller->postLink($request, new SlimResponse()); $this->assertEquals(201, $response->getStatusCode()); - $this->assertEquals('/api/v1/bookmarks/1', $response->getHeader('Location')[0]); + $this->assertEquals('/api/v1/bookmarks/43', $response->getHeader('Location')[0]); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); $this->assertEquals(['one', 'two'], $data['tags']); diff --git a/tests/api/controllers/links/PutLinkTest.php b/tests/api/controllers/links/PutLinkTest.php index 9bd196db8..b697360a0 100644 --- a/tests/api/controllers/links/PutLinkTest.php +++ b/tests/api/controllers/links/PutLinkTest.php @@ -2,18 +2,22 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\Bookmark; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; +use Shaarli\Tests\Utils\FakeRouteCollector; use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; +use Slim\Routing\RouteContext; class PutLinkTest extends \Shaarli\TestCase { @@ -43,10 +47,15 @@ class PutLinkTest extends \Shaarli\TestCase protected $bookmarkService; /** - * @var HistoryController instance. + * @var History instance. */ protected $history; + /** + * @var RouteParser instance. + */ + protected $routeParser; + /** * @var Container instance. */ @@ -83,19 +92,16 @@ protected function setUp(): void $mutex, true ); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['db'] = $this->bookmarkService; - $this->container['history'] = $this->history; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('db', $this->bookmarkService); + $this->container->set('history', $this->history); $this->controller = new Links($this->container); - // Used by index_url(). - $this->controller->getCi()['environment'] = [ - 'SERVER_NAME' => 'domain.tld', - 'SERVER_PORT' => 80, - 'SCRIPT_NAME' => '/', - ]; + $this->routeParser = (new FakeRouteCollector()) + ->addRoute('POST', '/api/v1/bookmarks/{id:[\d]+}', 'getLink') + ->getRouteParser(); } /** @@ -112,13 +118,14 @@ protected function tearDown(): void */ public function testPutLinkMinimal() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - ]); $id = '41'; - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'PUT', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $response = $this->controller->putLink($request, new Response(), ['id' => $id]); + $response = $this->controller->putLink($request, new SlimResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); @@ -150,10 +157,6 @@ public function testPutLinkMinimal() */ public function testPutLinkWithValues() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - 'CONTENT_TYPE' => 'application/json' - ]); $id = 41; $update = [ 'url' => 'http://somewhere.else', @@ -162,10 +165,14 @@ public function testPutLinkWithValues() 'tags' => ['corneille', 'rodrigue'], 'private' => true, ]; - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'PUT', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($update); - $response = $this->controller->putLink($request, new Response(), ['id' => $id]); + $response = $this->controller->putLink($request, new SlimResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); @@ -197,14 +204,14 @@ public function testPutLinkDuplicate() 'tags' => ['one', 'two'], 'private' => true, ]; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - 'CONTENT_TYPE' => 'application/json' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'PUT', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($link); - $response = $this->controller->putLink($request, new Response(), ['id' => 41]); + $response = $this->controller->putLink($request, new SlimResponse(), ['id' => 41]); $this->assertEquals(409, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -234,12 +241,13 @@ public function testGetLink404() $this->expectException(\Shaarli\Api\Exceptions\ApiLinkNotFoundException::class); $this->expectExceptionMessage('Link not found'); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'PUT', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $this->controller->putLink($request, new Response(), ['id' => -1]); + $this->controller->putLink($request, new SlimResponse(), ['id' => -1]); } /** @@ -251,14 +259,14 @@ public function testPutLinkWithTagString(): void 'tags' => 'one two', ]; $id = '41'; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - 'CONTENT_TYPE' => 'application/json' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'PUT', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($link); - $response = $this->controller->putLink($request, new Response(), ['id' => $id]); + $response = $this->controller->putLink($request, new SlimResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -275,14 +283,13 @@ public function testPutLinkWithTagString2(): void 'tags' => ['one two'], ]; $id = '41'; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - 'CONTENT_TYPE' => 'application/json' - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'DELETE', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); $request = $request->withParsedBody($link); - $response = $this->controller->putLink($request, new Response(), ['id' => $id]); + $response = $this->controller->putLink($request, new SlimResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); diff --git a/tests/api/controllers/tags/DeleteTagTest.php b/tests/api/controllers/tags/DeleteTagTest.php index 63a3e2645..83f212ac1 100644 --- a/tests/api/controllers/tags/DeleteTagTest.php +++ b/tests/api/controllers/tags/DeleteTagTest.php @@ -2,18 +2,20 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Bookmark\LinkDB; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class DeleteTagTest extends \Shaarli\TestCase { @@ -43,7 +45,7 @@ class DeleteTagTest extends \Shaarli\TestCase protected $bookmarkService; /** - * @var HistoryController instance. + * @var History instance. */ protected $history; @@ -85,10 +87,10 @@ protected function setUp(): void true ); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['db'] = $this->bookmarkService; - $this->container['history'] = $this->history; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('db', $this->bookmarkService); + $this->container->set('history', $this->history); $this->controller = new Tags($this->container); } @@ -110,12 +112,12 @@ public function testDeleteTagValid() $tagName = 'gnu'; $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertTrue($tags[$tagName] > 0); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'DELETE', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'DELETE', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - $response = $this->controller->deleteTag($request, new Response(), ['tagName' => $tagName]); + $response = $this->controller->deleteTag($request, new SlimResponse(), ['tagName' => $tagName]); $this->assertEquals(204, $response->getStatusCode()); $this->assertEmpty((string) $response->getBody()); @@ -150,12 +152,12 @@ public function testDeleteTagCaseSensitivity() $tagName = 'sTuff'; $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertTrue($tags[$tagName] > 0); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'DELETE', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'DELETE', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - $response = $this->controller->deleteTag($request, new Response(), ['tagName' => $tagName]); + $response = $this->controller->deleteTag($request, new SlimResponse(), ['tagName' => $tagName]); $this->assertEquals(204, $response->getStatusCode()); $this->assertEmpty((string) $response->getBody()); @@ -188,11 +190,11 @@ public function testDeleteLink404() $tagName = 'nopenope'; $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertFalse(isset($tags[$tagName])); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'DELETE', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'DELETE', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - $this->controller->deleteTag($request, new Response(), ['tagName' => $tagName]); + $this->controller->deleteTag($request, new SlimResponse(), ['tagName' => $tagName]); } } diff --git a/tests/api/controllers/tags/GetTagNameTest.php b/tests/api/controllers/tags/GetTagNameTest.php index 8ba4b83ca..2ed279804 100644 --- a/tests/api/controllers/tags/GetTagNameTest.php +++ b/tests/api/controllers/tags/GetTagNameTest.php @@ -2,17 +2,19 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Bookmark\LinkDB; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; /** * Class GetTagNameTest @@ -68,17 +70,17 @@ protected function setUp(): void $this->refDB->write(self::$testDatastore); $history = new History('sandbox/history.php'); - $this->container = new Container(); - $this->container['conf'] = $this->conf; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); $this->pluginManager = new PluginManager($this->conf); - $this->container['db'] = new BookmarkFileService( + $this->container->set('db', new BookmarkFileService( $this->conf, $this->pluginManager, $history, $mutex, true - ); - $this->container['history'] = null; + )); + $this->container->set('history', null); $this->controller = new Tags($this->container); } @@ -97,12 +99,12 @@ protected function tearDown(): void public function testGetTag() { $tagName = 'gnu'; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - $response = $this->controller->getTag($request, new Response(), ['tagName' => $tagName]); + $response = $this->controller->getTag($request, new SlimResponse(), ['tagName' => $tagName]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_TAG, count($data)); @@ -116,12 +118,12 @@ public function testGetTag() public function testGetTagNotCaseSensitive() { $tagName = 'sTuff'; - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - $response = $this->controller->getTag($request, new Response(), ['tagName' => $tagName]); + $response = $this->controller->getTag($request, new SlimResponse(), ['tagName' => $tagName]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_TAG, count($data)); @@ -137,11 +139,11 @@ public function testGetTag404() $this->expectException(\Shaarli\Api\Exceptions\ApiTagNotFoundException::class); $this->expectExceptionMessage('Tag not found'); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - $this->controller->getTag($request, new Response(), ['tagName' => 'nopenope']); + $this->controller->getTag($request, new SlimResponse(), ['tagName' => 'nopenope']); } } diff --git a/tests/api/controllers/tags/GetTagsTest.php b/tests/api/controllers/tags/GetTagsTest.php index 1a1830816..0d15529c9 100644 --- a/tests/api/controllers/tags/GetTagsTest.php +++ b/tests/api/controllers/tags/GetTagsTest.php @@ -2,17 +2,19 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Bookmark\LinkDB; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; /** * Class GetTagsTest @@ -80,10 +82,10 @@ protected function setUp(): void $mutex, true ); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['db'] = $this->bookmarkService; - $this->container['history'] = null; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('db', $this->bookmarkService); + $this->container->set('history', null); $this->controller = new Tags($this->container); } @@ -102,12 +104,11 @@ protected function tearDown(): void public function testGetTagsAll() { $tags = $this->bookmarkService->bookmarksCountPerTag(); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - ]); - $request = Request::createFromEnvironment($env); + $request = (new FakeRequest( + 'GET' + )); - $response = $this->controller->getTags($request, new Response()); + $response = $this->controller->getTags($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(count($tags), count($data)); @@ -135,12 +136,11 @@ public function testGetTagsAll() */ public function testGetTagsOffsetLimit() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'offset=1&limit=1' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getTags($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'offset=1&limit=1') + )); + $response = $this->controller->getTags($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -155,12 +155,11 @@ public function testGetTagsOffsetLimit() public function testGetTagsLimitAll() { $tags = $this->bookmarkService->bookmarksCountPerTag(); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'limit=all' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getTags($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'limit=all') + )); + $response = $this->controller->getTags($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(count($tags), count($data)); @@ -172,12 +171,11 @@ public function testGetTagsLimitAll() */ public function testGetTagsOffsetTooHigh() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'offset=100' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getTags($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'offset=100') + )); + $response = $this->controller->getTags($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEmpty(count($data)); @@ -189,12 +187,11 @@ public function testGetTagsOffsetTooHigh() public function testGetTagsVisibilityPrivate() { $tags = $this->bookmarkService->bookmarksCountPerTag([], 'private'); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'visibility=private' - ]); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getTags($request, new Response()); + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'visibility=private') + )); + $response = $this->controller->getTags($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(count($tags), count($data)); @@ -209,14 +206,12 @@ public function testGetTagsVisibilityPrivate() public function testGetTagsVisibilityPublic() { $tags = $this->bookmarkService->bookmarksCountPerTag([], 'public'); - $env = Environment::mock( - [ - 'REQUEST_METHOD' => 'GET', - 'QUERY_STRING' => 'visibility=public' - ] - ); - $request = Request::createFromEnvironment($env); - $response = $this->controller->getTags($request, new Response()); + + $request = (new FakeRequest( + 'GET', + new Uri('', '', 80, '', 'visibility=public') + )); + $response = $this->controller->getTags($request, new SlimResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string)$response->getBody(), true); $this->assertEquals(count($tags), count($data)); diff --git a/tests/api/controllers/tags/PutTagTest.php b/tests/api/controllers/tags/PutTagTest.php index b2ebcd523..701c5eabb 100644 --- a/tests/api/controllers/tags/PutTagTest.php +++ b/tests/api/controllers/tags/PutTagTest.php @@ -2,19 +2,20 @@ namespace Shaarli\Api\Controllers; +use DI\Container as DIContainer; use malkusch\lock\mutex\NoMutex; +use Psr\Container\ContainerInterface as Container; use Shaarli\Api\Exceptions\ApiBadParametersException; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Bookmark\LinkDB; use Shaarli\Config\ConfigManager; use Shaarli\History; use Shaarli\Plugin\PluginManager; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Container; use Slim\Http\Environment; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; class PutTagTest extends \Shaarli\TestCase { @@ -39,7 +40,7 @@ class PutTagTest extends \Shaarli\TestCase protected $refDB = null; /** - * @var HistoryController instance. + * @var History instance. */ protected $history; @@ -88,10 +89,10 @@ protected function setUp(): void true ); - $this->container = new Container(); - $this->container['conf'] = $this->conf; - $this->container['db'] = $this->bookmarkService; - $this->container['history'] = $this->history; + $this->container = new DIContainer(); + $this->container->set('conf', $this->conf); + $this->container->set('db', $this->bookmarkService); + $this->container->set('history', $this->history); $this->controller = new Tags($this->container); } @@ -110,15 +111,14 @@ protected function tearDown(): void */ public function testPutLinkValid() { - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - ]); $tagName = 'gnu'; $update = ['name' => $newName = 'newtag']; - $request = Request::createFromEnvironment($env); + $request = new FakeRequest( + 'PUT' + ); $request = $request->withParsedBody($update); - $response = $this->controller->putTag($request, new Response(), ['tagName' => $tagName]); + $response = $this->controller->putTag($request, new SlimResponse(), ['tagName' => $tagName]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_TAG, count($data)); @@ -153,14 +153,13 @@ public function testPutTagMerge() $this->assertEquals(1, $tags[$newName]); $this->assertEquals(2, $tags[$tagName]); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - ]); $update = ['name' => $newName]; - $request = Request::createFromEnvironment($env); + $request = new FakeRequest( + 'PUT' + ); $request = $request->withParsedBody($update); - $response = $this->controller->putTag($request, new Response(), ['tagName' => $tagName]); + $response = $this->controller->putTag($request, new SlimResponse(), ['tagName' => $tagName]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_TAG, count($data)); @@ -186,20 +185,15 @@ public function testPutTagEmpty() $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertEquals(2, $tags[$tagName]); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - ]); - $request = Request::createFromEnvironment($env); + $request = new FakeRequest( + 'PUT' + ); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - ]); $update = ['name' => $newName]; - $request = Request::createFromEnvironment($env); $request = $request->withParsedBody($update); try { - $this->controller->putTag($request, new Response(), ['tagName' => $tagName]); + $this->controller->putTag($request, new SlimResponse(), ['tagName' => $tagName]); } catch (ApiBadParametersException $e) { $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertEquals(2, $tags[$tagName]); @@ -215,11 +209,10 @@ public function testPutTag404() $this->expectException(\Shaarli\Api\Exceptions\ApiTagNotFoundException::class); $this->expectExceptionMessage('Tag not found'); - $env = Environment::mock([ - 'REQUEST_METHOD' => 'PUT', - ]); - $request = Request::createFromEnvironment($env); + $request = new FakeRequest( + 'PUT' + ); - $this->controller->putTag($request, new Response(), ['tagName' => 'nopenope']); + $this->controller->putTag($request, new SlimResponse(), ['tagName' => 'nopenope']); } } diff --git a/tests/bootstrap.php b/tests/bootstrap.php index 5c33f7bba..ed35878c8 100644 --- a/tests/bootstrap.php +++ b/tests/bootstrap.php @@ -1,9 +1,11 @@ containerBuilder->build(); - static::assertInstanceOf(BookmarkServiceInterface::class, $container->bookmarkService); - static::assertInstanceOf(CookieManager::class, $container->cookieManager); - static::assertInstanceOf(ConfigManager::class, $container->conf); - static::assertInstanceOf(ErrorController::class, $container->errorHandler); - static::assertInstanceOf(Environment::class, $container->environment); - static::assertInstanceOf(FeedBuilder::class, $container->feedBuilder); - static::assertInstanceOf(FormatterFactory::class, $container->formatterFactory); - static::assertInstanceOf(History::class, $container->history); - static::assertInstanceOf(HttpAccess::class, $container->httpAccess); - static::assertInstanceOf(LoginManager::class, $container->loginManager); - static::assertInstanceOf(LoggerInterface::class, $container->logger); - static::assertInstanceOf(MetadataRetriever::class, $container->metadataRetriever); - static::assertInstanceOf(NetscapeBookmarkUtils::class, $container->netscapeBookmarkUtils); - static::assertInstanceOf(PageBuilder::class, $container->pageBuilder); - static::assertInstanceOf(PageCacheManager::class, $container->pageCacheManager); - static::assertInstanceOf(ErrorController::class, $container->phpErrorHandler); - static::assertInstanceOf(ErrorNotFoundController::class, $container->notFoundHandler); - static::assertInstanceOf(PluginManager::class, $container->pluginManager); - static::assertInstanceOf(SessionManager::class, $container->sessionManager); - static::assertInstanceOf(Thumbnailer::class, $container->thumbnailer); - static::assertInstanceOf(Updater::class, $container->updater); + static::assertInstanceOf(BookmarkServiceInterface::class, $container->get('bookmarkService')); + static::assertInstanceOf(CookieManager::class, $container->get('cookieManager')); + static::assertInstanceOf(ConfigManager::class, $container->get('conf')); + static::assertInstanceOf(FeedBuilder::class, $container->get('feedBuilder')); + static::assertInstanceOf(FormatterFactory::class, $container->get('formatterFactory')); + static::assertInstanceOf(History::class, $container->get('history')); + static::assertInstanceOf(HttpAccess::class, $container->get('httpAccess')); + static::assertInstanceOf(LoginManager::class, $container->get('loginManager')); + static::assertInstanceOf(LoggerInterface::class, $container->get('logger')); + static::assertInstanceOf(MetadataRetriever::class, $container->get('metadataRetriever')); + static::assertInstanceOf(NetscapeBookmarkUtils::class, $container->get('netscapeBookmarkUtils')); + static::assertInstanceOf(PageBuilder::class, $container->get('pageBuilder')); + static::assertInstanceOf(PageCacheManager::class, $container->get('pageCacheManager')); + static::assertInstanceOf(PluginManager::class, $container->get('pluginManager')); + static::assertInstanceOf(SessionManager::class, $container->get('sessionManager')); + static::assertInstanceOf(Thumbnailer::class, $container->get('thumbnailer')); + static::assertInstanceOf(Updater::class, $container->get('updater')); // Set by the middleware - static::assertNull($container->basePath); + static::assertNull($container->get('basePath')); } } diff --git a/tests/container/ShaarliTestContainer.php b/tests/container/ShaarliTestContainer.php deleted file mode 100644 index 60d339a03..000000000 --- a/tests/container/ShaarliTestContainer.php +++ /dev/null @@ -1,41 +0,0 @@ -setLocale(self::$LOCALE); - $data = $feedBuilder->buildData(FeedBuilder::$FEED_RSS, null); + $data = $feedBuilder->buildData(FeedBuilder::$FEED_RSS, null, self::$serverInfo); // Test headers (RSS) $this->assertEquals(self::$RSS_LANGUAGE, $data['language']); $this->assertRegExp('/Wed, 03 Aug 2016 09:30:33 \+\d{4}/', $data['last_update']); @@ -139,7 +139,7 @@ public function testAtomBuildData() false ); $feedBuilder->setLocale(self::$LOCALE); - $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null); + $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null, self::$serverInfo); $this->assertEquals(ReferenceLinkDB::$NB_LINKS_TOTAL, count($data['links'])); $this->assertRegExp('/2016-08-03T09:30:33\+\d{2}:\d{2}/', $data['last_update']); $link = $data['links'][array_keys($data['links'])[0]]; @@ -163,7 +163,7 @@ public function testBuildDataFiltered() false ); $feedBuilder->setLocale(self::$LOCALE); - $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, $criteria); + $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, $criteria, self::$serverInfo); $this->assertEquals(1, count($data['links'])); $link = array_shift($data['links']); $this->assertEquals(41, $link['id']); @@ -188,7 +188,7 @@ public function testBuildDataCount() false ); $feedBuilder->setLocale(self::$LOCALE); - $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, $criteria); + $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, $criteria, self::$serverInfo); $this->assertEquals(3, count($data['links'])); $link = $data['links'][array_keys($data['links'])[0]]; $this->assertEquals(41, $link['id']); @@ -211,7 +211,7 @@ public function testBuildDataPermalinks() ); $feedBuilder->setLocale(self::$LOCALE); $feedBuilder->setUsePermalinks(true); - $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null); + $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null, self::$serverInfo); $this->assertEquals(ReferenceLinkDB::$NB_LINKS_TOTAL, count($data['links'])); $this->assertTrue($data['usepermalinks']); // First link is a permalink @@ -246,12 +246,11 @@ public function testBuildDataHideDates() $feedBuilder = new FeedBuilder( self::$bookmarkService, self::$formatter, - static::$serverInfo, false ); $feedBuilder->setLocale(self::$LOCALE); $feedBuilder->setHideDates(true); - $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null); + $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null, self::$serverInfo); $this->assertEquals(ReferenceLinkDB::$NB_LINKS_TOTAL, count($data['links'])); $this->assertFalse($data['show_dates']); @@ -264,7 +263,7 @@ public function testBuildDataHideDates() ); $feedBuilder->setLocale(self::$LOCALE); $feedBuilder->setHideDates(true); - $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null); + $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null, self::$serverInfo); $this->assertEquals(ReferenceLinkDB::$NB_LINKS_TOTAL, count($data['links'])); $this->assertTrue($data['show_dates']); } @@ -284,11 +283,10 @@ public function testBuildDataServerSubdir() $feedBuilder = new FeedBuilder( self::$bookmarkService, self::$formatter, - $serverInfo, false ); $feedBuilder->setLocale(self::$LOCALE); - $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null); + $data = $feedBuilder->buildData(FeedBuilder::$FEED_ATOM, null, $serverInfo); $this->assertEquals( 'http://host.tld:8080/~user/shaarli/feed/atom', diff --git a/tests/formatter/BookmarkDefaultFormatterTest.php b/tests/formatter/BookmarkDefaultFormatterTest.php index c0ba83f37..169f627f3 100644 --- a/tests/formatter/BookmarkDefaultFormatterTest.php +++ b/tests/formatter/BookmarkDefaultFormatterTest.php @@ -27,7 +27,7 @@ class BookmarkDefaultFormatterTest extends TestCase */ protected function setUp(): void { - copy('tests/utils/config/configJson.json.php', self::$testConf . '.json.php'); + copy(__DIR__ . '/../utils/config/configJson.json.php', self::$testConf . '.json.php'); $this->conf = new ConfigManager(self::$testConf); $this->formatter = new BookmarkDefaultFormatter($this->conf, true); } diff --git a/tests/formatter/BookmarkMarkdownExtraFormatterTest.php b/tests/formatter/BookmarkMarkdownExtraFormatterTest.php index c9c73a934..2850992f6 100644 --- a/tests/formatter/BookmarkMarkdownExtraFormatterTest.php +++ b/tests/formatter/BookmarkMarkdownExtraFormatterTest.php @@ -27,7 +27,7 @@ class BookmarkMarkdownExtraFormatterTest extends TestCase */ public function setUp(): void { - copy('tests/utils/config/configJson.json.php', self::$testConf . '.json.php'); + copy(__DIR__ . '/../utils/config/configJson.json.php', self::$testConf . '.json.php'); $this->conf = new ConfigManager(self::$testConf); $this->formatter = new BookmarkMarkdownExtraFormatter($this->conf, true); } diff --git a/tests/formatter/BookmarkMarkdownFormatterTest.php b/tests/formatter/BookmarkMarkdownFormatterTest.php index cd471756c..1ebf699dc 100644 --- a/tests/formatter/BookmarkMarkdownFormatterTest.php +++ b/tests/formatter/BookmarkMarkdownFormatterTest.php @@ -27,7 +27,7 @@ class BookmarkMarkdownFormatterTest extends TestCase */ protected function setUp(): void { - copy('tests/utils/config/configJson.json.php', self::$testConf . '.json.php'); + copy(__DIR__ . '/../utils/config/configJson.json.php', self::$testConf . '.json.php'); $this->conf = new ConfigManager(self::$testConf); $this->formatter = new BookmarkMarkdownFormatter($this->conf, true); } diff --git a/tests/formatter/BookmarkRawFormatterTest.php b/tests/formatter/BookmarkRawFormatterTest.php index 90c9fcf06..d29e89b74 100644 --- a/tests/formatter/BookmarkRawFormatterTest.php +++ b/tests/formatter/BookmarkRawFormatterTest.php @@ -27,7 +27,7 @@ class BookmarkRawFormatterTest extends TestCase */ protected function setUp(): void { - copy('tests/utils/config/configJson.json.php', self::$testConf . '.json.php'); + copy(__DIR__ . '/../utils/config/configJson.json.php', self::$testConf . '.json.php'); $this->conf = new ConfigManager(self::$testConf); $this->formatter = new BookmarkRawFormatter($this->conf, true); } diff --git a/tests/formatter/FormatterFactoryTest.php b/tests/formatter/FormatterFactoryTest.php index c6b493ebf..3155704a8 100644 --- a/tests/formatter/FormatterFactoryTest.php +++ b/tests/formatter/FormatterFactoryTest.php @@ -26,7 +26,7 @@ class FormatterFactoryTest extends TestCase */ protected function setUp(): void { - copy('tests/utils/config/configJson.json.php', self::$testConf . '.json.php'); + copy(__DIR__ . '/../utils/config/configJson.json.php', self::$testConf . '.json.php'); $this->conf = new ConfigManager(self::$testConf); $this->factory = new FormatterFactory($this->conf, true); } diff --git a/tests/front/ShaarliAdminMiddlewareTest.php b/tests/front/ShaarliAdminMiddlewareTest.php index 4d0726127..c5eeb80e5 100644 --- a/tests/front/ShaarliAdminMiddlewareTest.php +++ b/tests/front/ShaarliAdminMiddlewareTest.php @@ -4,20 +4,21 @@ namespace Shaarli\Front; +use DI\Container as DIContainer; use Shaarli\Config\ConfigManager; -use Shaarli\Container\ShaarliContainer; use Shaarli\Security\LoginManager; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; +use Shaarli\Tests\Utils\FakeRequestHandler; use Shaarli\Updater\Updater; -use Slim\Http\Request; -use Slim\Http\Response; use Slim\Http\Uri; +use Slim\Psr7\Response as SlimResponse; class ShaarliAdminMiddlewareTest extends TestCase { protected const TMP_MOCK_FILE = '.tmp'; - /** @var ShaarliContainer */ + /** @var Container */ protected $container; /** @var ShaarliMiddleware */ @@ -25,17 +26,16 @@ class ShaarliAdminMiddlewareTest extends TestCase public function setUp(): void { - $this->container = $this->createMock(ShaarliContainer::class); + $this->container = new DIContainer(); touch(static::TMP_MOCK_FILE); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('getConfigFileExt')->willReturn(static::TMP_MOCK_FILE); + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('getConfigFileExt')->willReturn(static::TMP_MOCK_FILE); - $this->container->loginManager = $this->createMock(LoginManager::class); - $this->container->updater = $this->createMock(Updater::class); - - $this->container->environment = ['REQUEST_URI' => 'http://shaarli/subfolder/path']; + $this->container->set('loginManager', $this->createMock(LoginManager::class)); + $this->container->set('updater', $this->createMock(Updater::class)); + $this->container->set('basePath', '/subfolder'); $this->middleware = new ShaarliAdminMiddleware($this->container); } @@ -50,21 +50,19 @@ public function tearDown(): void */ public function testMiddlewareWhileLoggedOut(): void { - $this->container->loginManager->expects(static::once())->method('isLoggedIn')->willReturn(false); - - $request = $this->createMock(Request::class); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); - return $uri; - }); + $this->container->get('loginManager')->expects(static::once())->method('isLoggedIn')->willReturn(false); - $response = new Response(); + $request = new FakeRequest( + 'GET', + (new \Slim\Psr7\Uri('http', 'shaarli'))->withPath('/subfolder/path'), + null, + [], + ['REQUEST_URI' => 'http://shaarli/subfolder/path'] + ); - /** @var Response $result */ - $result = $this->middleware->__invoke($request, $response, function () { - }); + $fakeResponse = new SlimResponse(); + $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse)); static::assertSame(302, $result->getStatusCode()); static::assertSame( @@ -78,23 +76,19 @@ public function testMiddlewareWhileLoggedOut(): void */ public function testMiddlewareWhileLoggedIn(): void { - $this->container->loginManager->method('isLoggedIn')->willReturn(true); - - $request = $this->createMock(Request::class); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); - - return $uri; - }); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + + $request = new FakeRequest( + 'GET', + (new \Slim\Psr7\Uri('http', 'shaarli'))->withPath('/subfolder/path'), + null, + [], + ['REQUEST_URI' => 'http://shaarli/subfolder/path'] + ); - $response = new Response(); - $controller = function (Request $request, Response $response): Response { - return $response->withStatus(418); // I'm a tea pot - }; + $fakeResponse = (new SlimResponse())->withStatus(418); + $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse)); - /** @var Response $result */ - $result = $this->middleware->__invoke($request, $response, $controller); static::assertSame(418, $result->getStatusCode()); } diff --git a/tests/front/ShaarliMiddlewareTest.php b/tests/front/ShaarliMiddlewareTest.php index 2fc1e69b4..3649e4a8e 100644 --- a/tests/front/ShaarliMiddlewareTest.php +++ b/tests/front/ShaarliMiddlewareTest.php @@ -4,24 +4,26 @@ namespace Shaarli\Front; +use DI\Container as DIContainer; +use Psr\Http\Message\ResponseInterface as Response; use Shaarli\Config\ConfigManager; -use Shaarli\Container\ShaarliContainer; use Shaarli\Front\Exception\LoginBannedException; use Shaarli\Front\Exception\UnauthorizedException; use Shaarli\Render\PageBuilder; use Shaarli\Render\PageCacheManager; use Shaarli\Security\LoginManager; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; +use Shaarli\Tests\Utils\FakeRequestHandler; use Shaarli\Updater\Updater; -use Slim\Http\Request; -use Slim\Http\Response; -use Slim\Http\Uri; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class ShaarliMiddlewareTest extends TestCase { protected const TMP_MOCK_FILE = '.tmp'; - /** @var ShaarliContainer */ + /** @var Container */ protected $container; /** @var ShaarliMiddleware */ @@ -29,16 +31,17 @@ class ShaarliMiddlewareTest extends TestCase public function setUp(): void { - $this->container = $this->createMock(ShaarliContainer::class); + $this->container = new DIContainer(); touch(static::TMP_MOCK_FILE); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('getConfigFileExt')->willReturn(static::TMP_MOCK_FILE); + $this->container->set('conf', $this->createMock(ConfigManager::class)); - $this->container->loginManager = $this->createMock(LoginManager::class); + $conf = $this->container->get('conf'); + $conf->method('getConfigFileExt')->willReturn(static::TMP_MOCK_FILE); - $this->container->environment = ['REQUEST_URI' => 'http://shaarli/subfolder/path']; + $this->container->set('loginManager', $this->createMock(LoginManager::class)); + $this->container->set('basePath', '/subfolder'); $this->middleware = new ShaarliMiddleware($this->container); } @@ -53,21 +56,13 @@ public function tearDown(): void */ public function testMiddlewareExecution(): void { - $request = $this->createMock(Request::class); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); - - return $uri; - }); - - $response = new Response(); - $controller = function (Request $request, Response $response): Response { - return $response->withStatus(418); // I'm a tea pot - }; + $request = new FakeRequest( + 'GET', + (new Uri('http', 'shaarli'))->withPath('/subfolder/path') + ); - /** @var Response $result */ - $result = $this->middleware->__invoke($request, $response, $controller); + $fakeResponse = (new SlimResponse())->withStatus(418); // I'm a tea pot + $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse)); static::assertInstanceOf(Response::class, $result); static::assertSame(418, $result->getStatusCode()); @@ -79,16 +74,13 @@ public function testMiddlewareExecution(): void */ public function testMiddlewareExecutionWithFrontException(): void { - $request = $this->createMock(Request::class); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); - - return $uri; - }); + $request = new FakeRequest( + 'GET', + (new Uri('http', 'shaarli'))->withPath('/subfolder/path') + ); - $response = new Response(); - $controller = function (): void { + $fakeResponse = (new SlimResponse())->withStatus(418); // I'm a tea pot + $callback = function ($request) { $exception = new LoginBannedException(); throw new $exception(); @@ -98,11 +90,10 @@ public function testMiddlewareExecutionWithFrontException(): void $pageBuilder->method('render')->willReturnCallback(function (string $message): string { return $message; }); - $this->container->pageBuilder = $pageBuilder; + $this->container->set('pageBuilder', $pageBuilder); $this->expectException(LoginBannedException::class); - - $this->middleware->__invoke($request, $response, $controller); + ($this->middleware)($request, new FakeRequestHandler($fakeResponse, $callback)); } /** @@ -111,21 +102,20 @@ public function testMiddlewareExecutionWithFrontException(): void */ public function testMiddlewareExecutionWithUnauthorizedException(): void { - $request = $this->createMock(Request::class); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); - - return $uri; - }); + $request = new FakeRequest( + 'GET', + (new Uri('http', 'shaarli'))->withPath('/subfolder/path'), + null, + [], + ['REQUEST_URI' => 'http://shaarli/subfolder/path'] + ); - $response = new Response(); - $controller = function (): void { + $fakeResponse = new SlimResponse(); + $callback = function ($request) { throw new UnauthorizedException(); }; - /** @var Response $result */ - $result = $this->middleware->__invoke($request, $response, $controller); + $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse, $callback)); static::assertSame(302, $result->getStatusCode()); static::assertSame( @@ -140,81 +130,76 @@ public function testMiddlewareExecutionWithUnauthorizedException(): void */ public function testMiddlewareExecutionWithServerException(): void { - $request = $this->createMock(Request::class); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); - - return $uri; - }); + $request = new FakeRequest( + 'GET', + (new Uri('http', 'shaarli'))->withPath('/subfolder/path'), + null, + [], + ['REQUEST_URI' => 'http://shaarli/subfolder/path'] + ); + $fakeResponse = new SlimResponse(); $dummyException = new class () extends \Exception { }; - - $response = new Response(); - $controller = function () use ($dummyException): void { + $callback = function ($request) use ($dummyException) { throw $dummyException; }; - $parameters = []; - $this->container->pageBuilder = $this->createMock(PageBuilder::class); - $this->container->pageBuilder->method('render')->willReturnCallback(function (string $message): string { + $pageBuilder = $this->createMock(PageBuilder::class); + $pageBuilder->method('render')->willReturnCallback(function (string $message): string { return $message; }); - $this->container->pageBuilder + $parameters = []; + $pageBuilder ->method('assign') ->willReturnCallback(function (string $key, string $value) use (&$parameters): void { $parameters[$key] = $value; }) ; + $this->container->set('pageBuilder', $pageBuilder); $this->expectException(get_class($dummyException)); - - $this->middleware->__invoke($request, $response, $controller); + ($this->middleware)($request, new FakeRequestHandler($fakeResponse, $callback)); } public function testMiddlewareExecutionWithUpdates(): void { - $request = $this->createMock(Request::class); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); - - return $uri; - }); + $request = new FakeRequest( + 'GET', + (new Uri('http', 'shaarli'))->withPath('/subfolder/path'), + null, + [], + ['REQUEST_URI' => 'http://shaarli/subfolder/path'] + ); - $response = new Response(); - $controller = function (Request $request, Response $response): Response { - return $response->withStatus(418); // I'm a tea pot - }; + $fakeResponse = (new SlimResponse())->withStatus(418); // I'm a tea pot; - $this->container->loginManager = $this->createMock(LoginManager::class); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); + $this->container->set('loginManager', $this->createMock(LoginManager::class)); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key): string { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key): string { return $key; }); - $this->container->conf->method('getConfigFileExt')->willReturn(static::TMP_MOCK_FILE); + $this->container->get('conf')->method('getConfigFileExt')->willReturn(static::TMP_MOCK_FILE); - $this->container->pageCacheManager = $this->createMock(PageCacheManager::class); - $this->container->pageCacheManager->expects(static::once())->method('invalidateCaches'); + $this->container->set('pageCacheManager', $this->createMock(PageCacheManager::class)); + $this->container->get('pageCacheManager')->expects(static::once())->method('invalidateCaches'); - $this->container->updater = $this->createMock(Updater::class); - $this->container->updater + $this->container->set('updater', $this->createMock(Updater::class)); + $this->container->get('updater') ->expects(static::once()) ->method('update') ->willReturn(['update123']) ; - $this->container->updater->method('getDoneUpdates')->willReturn($updates = ['update123', 'other']); - $this->container->updater + $this->container->get('updater')->method('getDoneUpdates')->willReturn($updates = ['update123', 'other']); + $this->container->get('updater') ->expects(static::once()) ->method('writeUpdates') ->with('resource.updates', $updates) ; - /** @var Response $result */ - $result = $this->middleware->__invoke($request, $response, $controller); + $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse)); static::assertInstanceOf(Response::class, $result); static::assertSame(418, $result->getStatusCode()); diff --git a/tests/front/controller/admin/ConfigureControllerTest.php b/tests/front/controller/admin/ConfigureControllerTest.php index 822429d79..2101c20a7 100644 --- a/tests/front/controller/admin/ConfigureControllerTest.php +++ b/tests/front/controller/admin/ConfigureControllerTest.php @@ -8,9 +8,10 @@ use Shaarli\Front\Exception\WrongTokenException; use Shaarli\Security\SessionManager; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class ConfigureControllerTest extends TestCase { @@ -34,11 +35,11 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key) { return $key; }); @@ -113,21 +114,15 @@ public function testSaveNewConfig(): void 'thumbnails.mode' => $parameters['enableThumbnails'], ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam')->willReturnCallback(function (string $key) use ($parameters) { - if (false === array_key_exists($key, $parameters)) { - static::fail('unknown key: ' . $key); - } - - return $parameters[$key]; - }); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); - $response = new Response(); + $response = new SlimResponse(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf') ->expects(static::atLeastOnce()) ->method('set') ->willReturnCallback(function (string $key, $value) use ($parametersConfigMapping): void { @@ -153,14 +148,14 @@ public function testSaveNewConfig(): void */ public function testSaveNewConfigWrongToken(): void { - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->willReturn(false); + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->willReturn(false); - $this->container->conf->expects(static::never())->method('set'); - $this->container->conf->expects(static::never())->method('write'); + $this->container->get('conf')->expects(static::never())->method('set'); + $this->container->get('conf')->expects(static::never())->method('write'); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $this->expectException(WrongTokenException::class); @@ -175,18 +170,12 @@ public function testSaveNewConfigThumbnailsActivation(): void $session = []; $this->assignSessionVars($session); - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam')->willReturnCallback(function (string $key) { - if ('enableThumbnails' === $key) { - return Thumbnailer::MODE_ALL; - } + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody(['enableThumbnails' => Thumbnailer::MODE_ALL]); - return $key; - }) - ; - $response = new Response(); + $response = new SlimResponse(); $result = $this->controller->save($request, $response); @@ -211,21 +200,14 @@ public function testSaveNewConfigThumbnailsAlreadyActive(): void $session = []; $this->assignSessionVars($session); - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam')->willReturnCallback(function (string $key) { - if ('enableThumbnails' === $key) { - return Thumbnailer::MODE_ALL; - } - - return $key; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody(['enableThumbnails' => Thumbnailer::MODE_ALL]); + $response = new SlimResponse(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf') ->expects(static::atLeastOnce()) ->method('get') ->willReturnCallback(function (string $key): string { diff --git a/tests/front/controller/admin/ExportControllerTest.php b/tests/front/controller/admin/ExportControllerTest.php index a8401c1f1..1c873ce1d 100644 --- a/tests/front/controller/admin/ExportControllerTest.php +++ b/tests/front/controller/admin/ExportControllerTest.php @@ -10,8 +10,9 @@ use Shaarli\Netscape\NetscapeBookmarkUtils; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class ExportControllerTest extends TestCase { @@ -35,8 +36,8 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->index($request, $response); @@ -59,19 +60,23 @@ public function testExportDefault(): void 'prepend_note_url' => 'on', ]; - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key) use ($parameters) { - return $parameters[$key] ?? null; - }); - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters)->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + ]); + $response = new SlimResponse(); $bookmarks = [ (new Bookmark())->setUrl('http://link1.tld')->setTitle('Title 1'), (new Bookmark())->setUrl('http://link2.tld')->setTitle('Title 2'), ]; - $this->container->netscapeBookmarkUtils = $this->createMock(NetscapeBookmarkUtils::class); - $this->container->netscapeBookmarkUtils + $this->container->set('netscapeBookmarkUtils', $this->createMock(NetscapeBookmarkUtils::class)); + $this->container->get('netscapeBookmarkUtils') ->expects(static::once()) ->method('filterAndFormat') ->willReturnCallback( @@ -115,10 +120,10 @@ function ( */ public function testExportSelectionMissing(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Please select an export mode.']) @@ -139,20 +144,24 @@ public function testExportErrorEncountered(): void 'selection' => 'all', ]; - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key) use ($parameters) { - return $parameters[$key] ?? null; - }); - $response = new Response(); - - $this->container->netscapeBookmarkUtils = $this->createMock(NetscapeBookmarkUtils::class); - $this->container->netscapeBookmarkUtils + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters)->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + ]); + $response = new SlimResponse(); + + $this->container->set('netscapeBookmarkUtils', $this->createMock(NetscapeBookmarkUtils::class)); + $this->container->get('netscapeBookmarkUtils') ->expects(static::once()) ->method('filterAndFormat') ->willThrowException(new \Exception($message = 'error message')); ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, [$message]) diff --git a/tests/front/controller/admin/FrontAdminControllerMockHelper.php b/tests/front/controller/admin/FrontAdminControllerMockHelper.php index 2b9f2ef19..69f5fb8c1 100644 --- a/tests/front/controller/admin/FrontAdminControllerMockHelper.php +++ b/tests/front/controller/admin/FrontAdminControllerMockHelper.php @@ -4,16 +4,15 @@ namespace Shaarli\Front\Controller\Admin; -use Shaarli\Container\ShaarliTestContainer; use Shaarli\Front\Controller\Visitor\FrontControllerMockHelper; use Shaarli\History; /** * Trait FrontControllerMockHelper * - * Helper trait used to initialize the ShaarliContainer and mock its services for admin controller tests. + * Helper trait used to initialize the Container and mock its services for admin controller tests. * - * @property ShaarliTestContainer $container + * @property Container $container */ trait FrontAdminControllerMockHelper { @@ -28,10 +27,10 @@ protected function createContainer(): void { $this->parentCreateContainer(); - $this->container->history = $this->createMock(History::class); + $this->container->set('history', $this->createMock(History::class)); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + $this->container->get('sessionManager')->method('checkToken')->willReturn(true); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); - $this->container->sessionManager->method('checkToken')->willReturn(true); } @@ -43,13 +42,13 @@ protected function createContainer(): void */ protected function assignSessionVars(array &$variables): void { - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::atLeastOnce()) ->method('setSessionParameter') ->willReturnCallback(function ($key, $value) use (&$variables) { $variables[$key] = $value; - return $this->container->sessionManager; + return $this->container->get('sessionManager'); }) ; } diff --git a/tests/front/controller/admin/ImportControllerTest.php b/tests/front/controller/admin/ImportControllerTest.php index 505131153..a07179029 100644 --- a/tests/front/controller/admin/ImportControllerTest.php +++ b/tests/front/controller/admin/ImportControllerTest.php @@ -8,9 +8,10 @@ use Shaarli\Netscape\NetscapeBookmarkUtils; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; -use Slim\Http\UploadedFile; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\UploadedFile; +use Slim\Psr7\Uri; class ImportControllerTest extends TestCase { @@ -34,8 +35,8 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->index($request, $response); @@ -59,15 +60,14 @@ public function testImportDefault(): void $requestFile = new UploadedFile('file', 'name', 'type', 123); - $request = $this->createMock(Request::class); - $request->method('getParams')->willReturnCallback(function () use ($parameters) { - return $parameters; - }); - $request->method('getUploadedFiles')->willReturn(['filetoupload' => $requestFile]); - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody($parameters)->withUploadedFiles(['filetoupload' => $requestFile]); - $this->container->netscapeBookmarkUtils = $this->createMock(NetscapeBookmarkUtils::class); - $this->container->netscapeBookmarkUtils + $response = new SlimResponse(); + $this->container->set('netscapeBookmarkUtils', $this->createMock(NetscapeBookmarkUtils::class)); + $this->container->get('netscapeBookmarkUtils') ->expects(static::once()) ->method('import') ->willReturnCallback( @@ -86,7 +86,7 @@ function ( ) ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_SUCCESS_MESSAGES, ['status']) @@ -103,10 +103,10 @@ function ( */ public function testImportFileMissing(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['No import file provided.']) @@ -125,21 +125,23 @@ public function testImportEmptyFile(): void { $requestFile = new UploadedFile('file', 'name', 'type', 0); - $request = $this->createMock(Request::class); - $request->method('getUploadedFiles')->willReturn(['filetoupload' => $requestFile]); - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withUploadedFiles(['filetoupload' => $requestFile]); + $response = new SlimResponse(); - $this->container->netscapeBookmarkUtils = $this->createMock(NetscapeBookmarkUtils::class); - $this->container->netscapeBookmarkUtils->expects(static::never())->method('filterAndFormat'); + $this->container->set('netscapeBookmarkUtils', $this->createMock(NetscapeBookmarkUtils::class)); + $this->container->get('netscapeBookmarkUtils')->expects(static::never())->method('filterAndFormat'); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->willReturnCallback(function (string $key, array $value): SessionManager { static::assertSame(SessionManager::KEY_ERROR_MESSAGES, $key); static::assertStringStartsWith('The file you are trying to upload is probably bigger', $value[0]); - return $this->container->sessionManager; + return $this->container->get('sessionManager'); }) ; diff --git a/tests/front/controller/admin/LogoutControllerTest.php b/tests/front/controller/admin/LogoutControllerTest.php index 94e53019a..d1fdb26cf 100644 --- a/tests/front/controller/admin/LogoutControllerTest.php +++ b/tests/front/controller/admin/LogoutControllerTest.php @@ -4,11 +4,12 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; use Shaarli\Security\CookieManager; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class LogoutControllerTest extends TestCase { @@ -26,16 +27,16 @@ public function setUp(): void public function testValidControllerInvoke(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->pageCacheManager->expects(static::once())->method('invalidateCaches'); + $this->container->get('pageCacheManager')->expects(static::once())->method('invalidateCaches'); - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->expects(static::once())->method('logout'); + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->expects(static::once())->method('logout'); - $this->container->cookieManager = $this->createMock(CookieManager::class); - $this->container->cookieManager + $this->container->set('cookieManager', $this->createMock(CookieManager::class)); + $this->container->get('cookieManager') ->expects(static::once()) ->method('setCookieParameter') ->with(CookieManager::STAY_SIGNED_IN, 'false', 0, '/subfolder/') diff --git a/tests/front/controller/admin/ManageTagControllerTest.php b/tests/front/controller/admin/ManageTagControllerTest.php index 56a64cbb7..daa3234aa 100644 --- a/tests/front/controller/admin/ManageTagControllerTest.php +++ b/tests/front/controller/admin/ManageTagControllerTest.php @@ -11,8 +11,10 @@ use Shaarli\Front\Exception\WrongTokenException; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; + class ManageTagControllerTest extends TestCase { @@ -36,9 +38,12 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $request->method('getParam')->with('fromtag')->willReturn('fromtag'); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery('fromtag=fromtag') + )); + $response = new SlimResponse(); $result = $this->controller->index($request, $response); @@ -58,13 +63,13 @@ public function testIndexWhitespaceSeparator(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key) { return $key === 'general.tags_separator' ? ' ' : $key; }); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $this->controller->index($request, $response); @@ -85,19 +90,15 @@ public function testSaveRenameTagValid(): void 'fromtag' => 'old-tag', 'totag' => 'new-tag', ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($requestParameters): ?string { - return $requestParameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody($requestParameters); + $response = new SlimResponse(); $bookmark1 = $this->createMock(Bookmark::class); $bookmark2 = $this->createMock(Bookmark::class); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('search') ->with(['searchtags' => 'old-tag'], BookmarkFilter::$ALL, true) @@ -108,16 +109,17 @@ public function testSaveRenameTagValid(): void return SearchResult::getSearchResult([$bookmark1, $bookmark2]); }) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(2)) ->method('set') ->withConsecutive([$bookmark1, false], [$bookmark2, false]) ; - $this->container->bookmarkService->expects(static::once())->method('save'); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); $result = $this->controller->save($request, $response); static::assertSame(302, $result->getStatusCode()); + $a = $result->getHeader('location'); static::assertSame(['/subfolder/?searchtags=new-tag'], $result->getHeader('location')); static::assertArrayNotHasKey(SessionManager::KEY_ERROR_MESSAGES, $session); @@ -138,19 +140,15 @@ public function testSaveDeleteTagValid(): void 'deletetag' => 'delete', 'fromtag' => 'old-tag', ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($requestParameters): ?string { - return $requestParameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody($requestParameters); + $response = new SlimResponse(); $bookmark1 = $this->createMock(Bookmark::class); $bookmark2 = $this->createMock(Bookmark::class); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('search') ->with(['searchtags' => 'old-tag'], BookmarkFilter::$ALL, true) @@ -161,12 +159,12 @@ public function testSaveDeleteTagValid(): void return SearchResult::getSearchResult([$bookmark1, $bookmark2]); }) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(2)) ->method('set') ->withConsecutive([$bookmark1, false], [$bookmark2, false]) ; - $this->container->bookmarkService->expects(static::once())->method('save'); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); $result = $this->controller->save($request, $response); @@ -184,14 +182,14 @@ public function testSaveDeleteTagValid(): void */ public function testSaveWrongToken(): void { - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->willReturn(false); + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->willReturn(false); - $this->container->conf->expects(static::never())->method('set'); - $this->container->conf->expects(static::never())->method('write'); + $this->container->get('conf')->expects(static::never())->method('set'); + $this->container->get('conf')->expects(static::never())->method('write'); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $this->expectException(WrongTokenException::class); @@ -209,15 +207,11 @@ public function testSaveRenameTagMissingFrom(): void $requestParameters = [ 'renametag' => 'rename', ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($requestParameters): ?string { - return $requestParameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody($requestParameters); + $response = new SlimResponse(); $result = $this->controller->save($request, $response); @@ -241,15 +235,11 @@ public function testSaveDeleteTagMissingFrom(): void $requestParameters = [ 'deletetag' => 'delete', ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($requestParameters): ?string { - return $requestParameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody($requestParameters); + $response = new SlimResponse(); $result = $this->controller->save($request, $response); @@ -274,15 +264,11 @@ public function testSaveRenameTagMissingTo(): void 'renametag' => 'rename', 'fromtag' => 'old-tag' ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($requestParameters): ?string { - return $requestParameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody($requestParameters); + $response = new SlimResponse(); $result = $this->controller->save($request, $response); @@ -305,17 +291,14 @@ public function testChangeSeparatorValid(): void $session = []; $this->assignSessionVars($session); - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($toSeparator): ?string { - return $key === 'separator' ? $toSeparator : $key; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody(['separator' => $toSeparator]); + + $response = new SlimResponse(); - $this->container->conf + $this->container->get('conf') ->expects(static::once()) ->method('set') ->with('general.tags_separator', $toSeparator, true, true) @@ -345,17 +328,13 @@ public function testChangeSeparatorInvalidTooLong(): void $session = []; $this->assignSessionVars($session); - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($toSeparator): ?string { - return $key === 'separator' ? $toSeparator : $key; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody(['separator' => $toSeparator]); + $response = new SlimResponse(); - $this->container->conf->expects(static::never())->method('set'); + $this->container->get('conf')->expects(static::never())->method('set'); $result = $this->controller->changeSeparator($request, $response); @@ -381,17 +360,13 @@ public function testChangeSeparatorInvalidReservedCharacter(): void $session = []; $this->assignSessionVars($session); - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($toSeparator): ?string { - return $key === 'separator' ? $toSeparator : $key; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + (new Uri('', '')) + ))->withParsedBody(['separator' => $toSeparator]); + $response = new SlimResponse(); - $this->container->conf->expects(static::never())->method('set'); + $this->container->get('conf')->expects(static::never())->method('set'); $result = $this->controller->changeSeparator($request, $response); diff --git a/tests/front/controller/admin/PasswordControllerTest.php b/tests/front/controller/admin/PasswordControllerTest.php index e73b37118..c9fdceefa 100644 --- a/tests/front/controller/admin/PasswordControllerTest.php +++ b/tests/front/controller/admin/PasswordControllerTest.php @@ -9,8 +9,9 @@ use Shaarli\Front\Exception\WrongTokenException; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class PasswordControllerTest extends TestCase { @@ -35,8 +36,8 @@ public function setUp(): void */ public function testGetPage(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->index($request, $response); @@ -50,30 +51,23 @@ public function testGetPage(): void */ public function testPostNewPasswordDefault(): void { - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key): string { - if ('oldpassword' === $key) { - return 'old'; - } - if ('setpassword' === $key) { - return 'new'; - } - - return $key; - }); - $response = new Response(); - - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $default) { + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withParsedBody(['oldpassword' => 'old', 'setpassword' => 'new']); + $response = new SlimResponse(); + + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { if ('credentials.hash' === $key) { return sha1('old' . 'credentials.login' . 'credentials.salt'); } return strpos($key, 'credentials') !== false ? $key : $default; }); - $this->container->conf->expects(static::once())->method('write')->with(true); + $this->container->get('conf')->expects(static::once())->method('write')->with(true); - $this->container->conf + $this->container->get('conf') ->method('set') ->willReturnCallback(function (string $key, string $value) { if ('credentials.hash' === $key) { @@ -94,21 +88,14 @@ public function testPostNewPasswordDefault(): void */ public function testPostNewPasswordWrongOldPassword(): void { - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key): string { - if ('oldpassword' === $key) { - return 'wrong'; - } - if ('setpassword' === $key) { - return 'new'; - } - - return $key; - }); - $response = new Response(); - - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $default) { + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withParsedBody(['oldpassword' => 'wrong', 'setpassword' => 'new']); + $response = new SlimResponse(); + + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { if ('credentials.hash' === $key) { return sha1('old' . 'credentials.login' . 'credentials.salt'); } @@ -116,10 +103,10 @@ public function testPostNewPasswordWrongOldPassword(): void return strpos($key, 'credentials') !== false ? $key : $default; }); - $this->container->conf->expects(static::never())->method('set'); - $this->container->conf->expects(static::never())->method('write'); + $this->container->get('conf')->expects(static::never())->method('set'); + $this->container->get('conf')->expects(static::never())->method('write'); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['The old password is not correct.']) @@ -137,14 +124,14 @@ public function testPostNewPasswordWrongOldPassword(): void */ public function testPostNewPasswordWrongToken(): void { - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->willReturn(false); + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->willReturn(false); - $this->container->conf->expects(static::never())->method('set'); - $this->container->conf->expects(static::never())->method('write'); + $this->container->get('conf')->expects(static::never())->method('set'); + $this->container->get('conf')->expects(static::never())->method('write'); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $this->expectException(WrongTokenException::class); @@ -156,27 +143,20 @@ public function testPostNewPasswordWrongToken(): void */ public function testPostNewEmptyPassword(): void { - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['You must provide the current and new password to change it.']) ; - $this->container->conf->expects(static::never())->method('set'); - $this->container->conf->expects(static::never())->method('write'); + $this->container->get('conf')->expects(static::never())->method('set'); + $this->container->get('conf')->expects(static::never())->method('write'); - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key): string { - if ('oldpassword' === $key) { - return 'old'; - } - if ('setpassword' === $key) { - return ''; - } - - return $key; - }); - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withParsedBody(['oldpassword' => 'old', 'setpassword' => '']); + $response = new SlimResponse(); $result = $this->controller->change($request, $response); @@ -190,11 +170,11 @@ public function testPostNewEmptyPassword(): void */ public function testPostNewPasswordOnOpenShaarli(): void { - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->with('security.open_shaarli')->willReturn(true); + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->with('security.open_shaarli')->willReturn(true); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $this->expectException(OpenShaarliPasswordException::class); diff --git a/tests/front/controller/admin/PluginsControllerTest.php b/tests/front/controller/admin/PluginsControllerTest.php index fbec3197b..74f879c9b 100644 --- a/tests/front/controller/admin/PluginsControllerTest.php +++ b/tests/front/controller/admin/PluginsControllerTest.php @@ -9,8 +9,9 @@ use Shaarli\Plugin\PluginManager; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class PluginsControllerTest extends TestCase { @@ -51,8 +52,8 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $data = [ 'plugin1' => ['order' => 2, 'other' => 'field'], @@ -61,7 +62,7 @@ public function testIndex(): void 'plugin4' => [], ]; - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('getPluginsMeta') ->willReturn($data); @@ -93,22 +94,18 @@ public function testSaveEnabledPlugins(): void 'plugin2' => 'on', ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParams') - ->willReturnCallback(function () use ($parameters): array { - return $parameters; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('save_plugin_parameters', $parameters) ; - $this->container->conf + $this->container->get('conf') ->expects(static::atLeastOnce()) ->method('set') ->with('general.enabled_plugins', ['plugin1', 'plugin2']) @@ -132,22 +129,18 @@ public function testSavePluginParameters(): void 'token' => 'this parameter should not be saved' ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParams') - ->willReturnCallback(function () use ($parameters): array { - return $parameters; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('save_plugin_parameters', $parameters) ; - $this->container->conf + $this->container->get('conf') ->expects(static::exactly(2)) ->method('set') ->withConsecutive(['plugins.parameter1', 'blip'], ['plugins.parameter2', 'blop']) @@ -164,19 +157,19 @@ public function testSavePluginParameters(): void */ public function testSaveWithError(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf') ->expects(static::atLeastOnce()) ->method('write') ->willThrowException(new \Exception($message = 'error message')) ; - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->willReturn(true); - $this->container->sessionManager + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->willReturn(true); + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with( @@ -196,11 +189,11 @@ public function testSaveWithError(): void */ public function testSaveWrongToken(): void { - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->willReturn(false); + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->willReturn(false); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $this->expectException(WrongTokenException::class); diff --git a/tests/front/controller/admin/ServerControllerTest.php b/tests/front/controller/admin/ServerControllerTest.php index 355cce7d3..6c7b99ae2 100644 --- a/tests/front/controller/admin/ServerControllerTest.php +++ b/tests/front/controller/admin/ServerControllerTest.php @@ -7,8 +7,9 @@ use Shaarli\Config\ConfigManager; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; /** * Test Server administration controller. @@ -51,8 +52,12 @@ public function tearDown(): void */ public function testIndex(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'REMOTE_ADDR' => '1.2.3.4', + ]); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -88,8 +93,8 @@ public function testIndex(): void */ public function testClearMainCache(): void { - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $default) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { if ($key === 'resource.page_cache') { return 'sandbox/pagecache'; } elseif ($key === 'resource.raintpl_tmp') { @@ -101,15 +106,17 @@ public function testClearMainCache(): void } }); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_SUCCESS_MESSAGES, ['Shaarli\'s cache folder has been cleared!']) ; - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->with('type')->willReturn('main'); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery('type=main') + )); + $response = new SlimResponse(); $result = $this->controller->clearCache($request, $response); @@ -134,8 +141,8 @@ public function testClearMainCache(): void */ public function testClearThumbnailsCache(): void { - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $default) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { if ($key === 'resource.page_cache') { return 'sandbox/pagecache'; } elseif ($key === 'resource.raintpl_tmp') { @@ -147,7 +154,7 @@ public function testClearThumbnailsCache(): void } }); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->willReturnCallback(function (string $key, array $value): SessionManager { @@ -155,13 +162,15 @@ public function testClearThumbnailsCache(): void static::assertCount(1, $value); static::assertStringStartsWith('Thumbnails cache has been cleared.', $value[0]); - return $this->container->sessionManager; + return $this->container->get('sessionManager'); }); ; - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->with('type')->willReturn('thumbnails'); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery('type=thumbnails') + )); + $response = new SlimResponse(); $result = $this->controller->clearCache($request, $response); diff --git a/tests/front/controller/admin/SessionFilterControllerTest.php b/tests/front/controller/admin/SessionFilterControllerTest.php index 712a625b2..8d7a8199d 100644 --- a/tests/front/controller/admin/SessionFilterControllerTest.php +++ b/tests/front/controller/admin/SessionFilterControllerTest.php @@ -4,11 +4,12 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ResponseInterface as Response; use Shaarli\Security\LoginManager; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class SessionFilterControllerTest extends TestCase { @@ -31,17 +32,19 @@ 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 + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_VISIBILITY, 'private') ; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc', + 'SERVER_PORT' => '80', + 'SERVER_NAME' => 'shaarli' + ]); + $response = new SlimResponse(); $result = $this->controller->visibility($request, $response, $arg); @@ -57,26 +60,28 @@ 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 + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + $this->container->get('sessionManager') ->method('getSessionParameter') ->with(SessionManager::KEY_VISIBILITY) ->willReturn('private') ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::never()) ->method('setSessionParameter') ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('deleteSessionParameter') ->with(SessionManager::KEY_VISIBILITY) ; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc', + 'SERVER_PORT' => '80', + 'SERVER_NAME' => 'shaarli' + ]); + $response = new SlimResponse(); $result = $this->controller->visibility($request, $response, $arg); @@ -92,20 +97,20 @@ public function testVisibilitySwitch(): void { $arg = ['visibility' => 'private']; - $this->container->loginManager->method('isLoggedIn')->willReturn(true); - $this->container->sessionManager + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + $this->container->get('sessionManager') ->method('getSessionParameter') ->with(SessionManager::KEY_VISIBILITY) ->willReturn('public') ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_VISIBILITY, 'private') ; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->visibility($request, $response, $arg); @@ -121,21 +126,23 @@ 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 + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + $this->container->get('sessionManager') ->expects(static::never()) ->method('setSessionParameter') ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('deleteSessionParameter') ->with(SessionManager::KEY_VISIBILITY) ; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc', + 'SERVER_PORT' => '80', + 'SERVER_NAME' => 'shaarli' + ]); + $response = new SlimResponse(); $result = $this->controller->visibility($request, $response, $arg); @@ -151,22 +158,24 @@ 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 + $this->container->set('loginManager', $this->createMock(LoginManager::class)); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(false); + $this->container->get('sessionManager') ->expects(static::never()) ->method('setSessionParameter') ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::never()) ->method('deleteSessionParameter') ->with(SessionManager::KEY_VISIBILITY) ; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc', + 'SERVER_PORT' => '80', + 'SERVER_NAME' => 'shaarli' + ]); + $response = new SlimResponse(); $result = $this->controller->visibility($request, $response, $arg); diff --git a/tests/front/controller/admin/ShaareAddControllerTest.php b/tests/front/controller/admin/ShaareAddControllerTest.php index a27ebe649..e4638af7a 100644 --- a/tests/front/controller/admin/ShaareAddControllerTest.php +++ b/tests/front/controller/admin/ShaareAddControllerTest.php @@ -8,8 +8,8 @@ use Shaarli\Formatter\BookmarkMarkdownFormatter; use Shaarli\Http\HttpAccess; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class ShaareAddControllerTest extends TestCase { @@ -22,7 +22,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); $this->controller = new ShaareAddController($this->container); } @@ -34,23 +34,23 @@ public function testAddShaare(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $expectedTags = [ 'tag1' => 32, 'tag2' => 24, 'tag3' => 1, ]; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->willReturn($expectedTags) ; $expectedTags = array_merge($expectedTags, [BookmarkMarkdownFormatter::NO_MD_TAG => 1]); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $default) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { return $key === 'formatter' ? 'markdown' : $default; }); @@ -73,15 +73,15 @@ public function testAddShaareWithoutMd(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $expectedTags = [ 'tag1' => 32, 'tag2' => 24, 'tag3' => 1, ]; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->willReturn($expectedTags) diff --git a/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php b/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php index cd76491d0..3174c57c3 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php @@ -5,7 +5,6 @@ namespace Shaarli\Front\Controller\Admin\ShaareManageControllerTest; use Shaarli\Bookmark\Bookmark; -use Shaarli\Bookmark\Exception\BookmarkNotFoundException; use Shaarli\Formatter\BookmarkFormatter; use Shaarli\Formatter\BookmarkRawFormatter; use Shaarli\Formatter\FormatterFactory; @@ -14,8 +13,9 @@ use Shaarli\Http\HttpAccess; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class AddOrDeleteTagTest extends TestCase { @@ -28,7 +28,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); $this->controller = new ShaareManageController($this->container); } @@ -39,35 +39,34 @@ public function testAddOneTagOnOneBookmark(): void { $parameters = ['id' => '123', 'tag' => 'newtag', 'action' => 'add']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + + $response = new SlimResponse(); $bookmark = (new Bookmark()) ->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setTagsString('first second'); static::assertSame(['first', 'second'], $bookmark->getTags()); - $this->container->bookmarkService->expects(static::once())->method('get')->with(123)->willReturn($bookmark); - $this->container->bookmarkService->expects(static::once())->method('set')->with($bookmark, false); - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123) + ->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') ->willReturnCallback(function () use ($bookmark): BookmarkFormatter { - return new BookmarkRawFormatter($this->container->conf, true); + return new BookmarkRawFormatter($this->container->get('conf'), true); }) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('save_link') @@ -78,6 +77,7 @@ public function testAddOneTagOnOneBookmark(): void static::assertSame(['first', 'second', 'newtag'], $bookmark->getTags()); static::assertSame(302, $result->getStatusCode()); + $a = $result->getHeader('location'); static::assertSame(['/subfolder/'], $result->getHeader('location')); } @@ -88,14 +88,12 @@ public function testAddTwoTagsOnTwoBookmarks(): void { $parameters = ['id' => '123 456', 'tag' => 'newtag@othertag', 'action' => 'add']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + + $response = new SlimResponse(); $bookmark1 = (new Bookmark()) ->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setTagsString('first second'); @@ -105,24 +103,24 @@ public function testAddTwoTagsOnTwoBookmarks(): void static::assertSame(['first', 'second'], $bookmark1->getTags()); static::assertSame([], $bookmark2->getTags()); - $this->container->bookmarkService->expects(static::exactly(2))->method('get') + $this->container->get('bookmarkService')->expects(static::exactly(2))->method('get') ->withConsecutive([123], [456]) ->willReturnOnConsecutiveCalls($bookmark1, $bookmark2); - $this->container->bookmarkService->expects(static::exactly(2))->method('set') + $this->container->get('bookmarkService')->expects(static::exactly(2))->method('set') ->withConsecutive([$bookmark1, false], [$bookmark2, false]); - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') ->willReturnCallback(function (): BookmarkFormatter { - return new BookmarkRawFormatter($this->container->conf, true); + return new BookmarkRawFormatter($this->container->get('conf'), true); }) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::exactly(2)) ->method('executeHooks') ->with('save_link') @@ -144,35 +142,32 @@ public function testDeleteOneTagOnOneBookmark(): void { $parameters = ['id' => '123', 'tag' => 'second', 'action' => 'delete']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); $bookmark = (new Bookmark()) ->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setTagsString('first second third'); static::assertSame(['first', 'second', 'third'], $bookmark->getTags()); - $this->container->bookmarkService->expects(static::once())->method('get')->with(123)->willReturn($bookmark); - $this->container->bookmarkService->expects(static::once())->method('set')->with($bookmark, false); - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123)->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') ->willReturnCallback(function () use ($bookmark): BookmarkFormatter { - return new BookmarkRawFormatter($this->container->conf, true); + return new BookmarkRawFormatter($this->container->get('conf'), true); }) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('save_link') @@ -193,14 +188,11 @@ public function testDeleteTwoTagOnTwoBookmarks(): void { $parameters = ['id' => '123 456', 'tag' => 'second@first', 'action' => 'delete']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); $bookmark1 = (new Bookmark()) ->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setTagsString('first second third other'); @@ -211,24 +203,24 @@ public function testDeleteTwoTagOnTwoBookmarks(): void static::assertSame(['first', 'second', 'third', 'other'], $bookmark1->getTags()); static::assertSame(['first', 'second'], $bookmark2->getTags()); - $this->container->bookmarkService->expects(static::exactly(2))->method('get') + $this->container->get('bookmarkService')->expects(static::exactly(2))->method('get') ->withConsecutive([123], [456]) ->willReturnOnConsecutiveCalls($bookmark1, $bookmark2); - $this->container->bookmarkService->expects(static::exactly(2))->method('set') + $this->container->get('bookmarkService')->expects(static::exactly(2))->method('set') ->withConsecutive([$bookmark1, false], [$bookmark2, false]); - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') ->willReturnCallback(function (): BookmarkFormatter { - return new BookmarkRawFormatter($this->container->conf, true); + return new BookmarkRawFormatter($this->container->get('conf'), true); }) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::exactly(2)) ->method('executeHooks') ->with('save_link') @@ -249,16 +241,13 @@ public function testDeleteTwoTagOnTwoBookmarks(): void public function testAddTagWithoutId(): void { $parameters = ['tag' => 'newtag', 'action' => 'add']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid bookmark ID provided.']) @@ -276,16 +265,13 @@ public function testAddTagWithoutId(): void public function testDeleteTagWithoutId(): void { $parameters = ['tag' => 'newtag', 'action' => 'delete']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid bookmark ID provided.']) @@ -303,16 +289,13 @@ public function testDeleteTagWithoutId(): void public function testAddTagWithoutAction(): void { $parameters = ['id' => '123', 'tag' => 'newtag']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid action provided.']) @@ -330,16 +313,13 @@ public function testAddTagWithoutAction(): void public function testAddTagWithoutValue(): void { $parameters = ['id' => '123', 'tag' => '', 'action' => 'add']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid tag name provided.']) @@ -357,16 +337,13 @@ public function testAddTagWithoutValue(): void public function testDeleteTagWithoutValue(): void { $parameters = ['id' => '123', 'tag' => '', 'action' => 'delete']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid tag name provided.']) diff --git a/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php b/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php index 28b1c0231..9f226fe73 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php @@ -14,8 +14,9 @@ use Shaarli\Http\HttpAccess; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class ChangeVisibilityBookmarkTest extends TestCase { @@ -28,7 +29,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); $this->controller = new ShaareManageController($this->container); } @@ -39,34 +40,33 @@ public function testSetSingleBookmarkPrivate(): void { $parameters = ['id' => '123', 'newVisibility' => 'private']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(false); static::assertFalse($bookmark->isPrivate()); - $this->container->bookmarkService->expects(static::once())->method('get')->with(123)->willReturn($bookmark); - $this->container->bookmarkService->expects(static::once())->method('set')->with($bookmark, false); - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123)->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') ->willReturnCallback(function () use ($bookmark): BookmarkFormatter { - return new BookmarkRawFormatter($this->container->conf, true); + return new BookmarkRawFormatter($this->container->get('conf'), true); }) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('save_link') @@ -87,32 +87,31 @@ public function testSetSingleBookmarkPublic(): void { $parameters = ['id' => '123', 'newVisibility' => 'public']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(true); static::assertTrue($bookmark->isPrivate()); - $this->container->bookmarkService->expects(static::once())->method('get')->with(123)->willReturn($bookmark); - $this->container->bookmarkService->expects(static::once())->method('set')->with($bookmark, false); - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123)->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') - ->willReturn(new BookmarkRawFormatter($this->container->conf, true)) + ->willReturn(new BookmarkRawFormatter($this->container->get('conf'), true)) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('save_link') @@ -133,32 +132,31 @@ public function testSetSinglePrivateBookmarkPrivate(): void { $parameters = ['id' => '123', 'newVisibility' => 'private']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(true); static::assertTrue($bookmark->isPrivate()); - $this->container->bookmarkService->expects(static::once())->method('get')->with(123)->willReturn($bookmark); - $this->container->bookmarkService->expects(static::once())->method('set')->with($bookmark, false); - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123)->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') - ->willReturn(new BookmarkRawFormatter($this->container->conf, true)) + ->willReturn(new BookmarkRawFormatter($this->container->get('conf'), true)) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('save_link') @@ -179,14 +177,13 @@ public function testSetMultipleBookmarksPrivate(): void { $parameters = ['id' => '123 456 789', 'newVisibility' => 'private']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); $bookmarks = [ (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(false), @@ -194,30 +191,30 @@ public function testSetMultipleBookmarksPrivate(): void (new Bookmark())->setId(789)->setUrl('http://domain.tld')->setTitle('Title 789')->setPrivate(false), ]; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(3)) ->method('get') ->withConsecutive([123], [456], [789]) ->willReturnOnConsecutiveCalls(...$bookmarks) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(3)) ->method('set') ->withConsecutive(...array_map(function (Bookmark $bookmark): array { return [$bookmark, false]; }, $bookmarks)) ; - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') - ->willReturn(new BookmarkRawFormatter($this->container->conf, true)) + ->willReturn(new BookmarkRawFormatter($this->container->get('conf'), true)) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::exactly(3)) ->method('executeHooks') ->with('save_link') @@ -240,32 +237,31 @@ public function testChangeVisibilitySingleBookmarkNotFound(): void { $parameters = ['id' => '123', 'newVisibility' => 'private']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('get') ->willThrowException(new BookmarkNotFoundException()) ; - $this->container->bookmarkService->expects(static::never())->method('set'); - $this->container->bookmarkService->expects(static::never())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::never())->method('set'); + $this->container->get('bookmarkService')->expects(static::never())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') - ->willReturn(new BookmarkRawFormatter($this->container->conf, true)) + ->willReturn(new BookmarkRawFormatter($this->container->get('conf'), true)) ; // Make sure that PluginManager hook is not triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::never()) ->method('executeHooks') ->with('save_link') @@ -284,21 +280,20 @@ public function testChangeVisibilityMultipleBookmarksOneNotFound(): void { $parameters = ['id' => '123 456 789', 'newVisibility' => 'public']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); $bookmarks = [ (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(true), (new Bookmark())->setId(789)->setUrl('http://domain.tld')->setTitle('Title 789')->setPrivate(false), ]; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(3)) ->method('get') ->withConsecutive([123], [456], [789]) @@ -312,23 +307,23 @@ public function testChangeVisibilityMultipleBookmarksOneNotFound(): void throw new BookmarkNotFoundException(); }) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(2)) ->method('set') ->withConsecutive(...array_map(function (Bookmark $bookmark): array { return [$bookmark, false]; }, $bookmarks)) ; - $this->container->bookmarkService->expects(static::once())->method('save'); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); // Make sure that PluginManager hook is not triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::exactly(2)) ->method('executeHooks') ->with('save_link') ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Bookmark with identifier 456 could not be found.']) @@ -347,16 +342,15 @@ public function testChangeVisibilityInvalidId(): void { $parameters = ['id' => 'nope not an ID', 'newVisibility' => 'private']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid bookmark ID provided.']) @@ -373,10 +367,10 @@ public function testChangeVisibilityInvalidId(): void */ public function testChangeVisibilityEmptyId(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid bookmark ID provided.']) @@ -395,16 +389,15 @@ public function testChangeVisibilityWithInvalidVisibility(): void { $parameters = ['id' => '123', 'newVisibility' => 'invalid']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid visibility provided.']) diff --git a/tests/front/controller/admin/ShaareManageControllerTest/DeleteBookmarkTest.php b/tests/front/controller/admin/ShaareManageControllerTest/DeleteBookmarkTest.php index 42d0c0d65..cc2bc7e7f 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/DeleteBookmarkTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/DeleteBookmarkTest.php @@ -13,8 +13,9 @@ use Shaarli\Http\HttpAccess; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class DeleteBookmarkTest extends TestCase { @@ -27,7 +28,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); $this->controller = new ShaareManageController($this->container); } @@ -38,24 +39,22 @@ public function testDeleteSingleBookmark(): void { $parameters = ['id' => '123']; - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/shaare/abcdef'; - - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123'); - $this->container->bookmarkService->expects(static::once())->method('get')->with(123)->willReturn($bookmark); - $this->container->bookmarkService->expects(static::once())->method('remove')->with($bookmark, false); - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123) + ->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('remove')->with($bookmark, false); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') @@ -73,7 +72,7 @@ public function testDeleteSingleBookmark(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('delete_link', ['formatted' => $bookmark]) @@ -92,16 +91,18 @@ public function testDeleteMultipleBookmarks(): void { $parameters = ['id' => '123 456 789']; - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/?searchtags=abcdef'; - - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('http', 'shaarli', 80, '/subfolder', '')) + ->withQuery($query) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'HTTP_REFERER' => 'http://shaarli/subfolder/?searchtags=abcdef', + 'SCRIPT_NAME' => '/subfolder/index.php', + ]); + $response = new SlimResponse(); $bookmarks = [ (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123'), @@ -109,22 +110,22 @@ public function testDeleteMultipleBookmarks(): void (new Bookmark())->setId(789)->setUrl('http://domain.tld')->setTitle('Title 789'), ]; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(3)) ->method('get') ->withConsecutive([123], [456], [789]) ->willReturnOnConsecutiveCalls(...$bookmarks) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(3)) ->method('remove') ->withConsecutive(...array_map(function (Bookmark $bookmark): array { return [$bookmark, false]; }, $bookmarks)) ; - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') @@ -147,7 +148,7 @@ public function testDeleteMultipleBookmarks(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::exactly(3)) ->method('executeHooks') ->with('delete_link') @@ -166,24 +167,23 @@ public function testDeleteSingleBookmarkNotFound(): void { $parameters = ['id' => '123']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('get') ->willThrowException(new BookmarkNotFoundException()) ; - $this->container->bookmarkService->expects(static::never())->method('remove'); - $this->container->bookmarkService->expects(static::never())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::never())->method('remove'); + $this->container->get('bookmarkService')->expects(static::never())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') @@ -196,7 +196,7 @@ public function testDeleteSingleBookmarkNotFound(): void }) ; // Make sure that PluginManager hook is not triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::never()) ->method('executeHooks') ->with('delete_link') @@ -215,21 +215,20 @@ public function testDeleteMultipleBookmarksOneNotFound(): void { $parameters = ['id' => '123 456 789']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); $bookmarks = [ (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123'), (new Bookmark())->setId(789)->setUrl('http://domain.tld')->setTitle('Title 789'), ]; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(3)) ->method('get') ->withConsecutive([123], [456], [789]) @@ -243,16 +242,16 @@ public function testDeleteMultipleBookmarksOneNotFound(): void throw new BookmarkNotFoundException(); }) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(2)) ->method('remove') ->withConsecutive(...array_map(function (Bookmark $bookmark): array { return [$bookmark, false]; }, $bookmarks)) ; - $this->container->bookmarkService->expects(static::once())->method('save'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->get('bookmarkService')->expects(static::once())->method('save'); + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->with('raw') @@ -275,13 +274,13 @@ public function testDeleteMultipleBookmarksOneNotFound(): void ; // Make sure that PluginManager hook is not triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::exactly(2)) ->method('executeHooks') ->with('delete_link') ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Bookmark with identifier 456 could not be found.']) @@ -300,16 +299,15 @@ public function testDeleteInvalidId(): void { $parameters = ['id' => 'nope not an ID']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid bookmark ID provided.']) @@ -326,10 +324,10 @@ public function testDeleteInvalidId(): void */ public function testDeleteEmptyId(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Invalid bookmark ID provided.']) @@ -351,22 +349,21 @@ public function testDeleteBookmarkFromBookmarklet(): void 'source' => 'bookmarklet', ]; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); - $this->container->bookmarkService->method('get')->with('123')->willReturn( + $this->container->get('bookmarkService')->method('get')->with('123')->willReturn( (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ); - $this->container->bookmarkService->expects(static::once())->method('remove'); + $this->container->get('bookmarkService')->expects(static::once())->method('remove'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->willReturnCallback(function (): BookmarkFormatter { @@ -393,22 +390,21 @@ public function testDeleteBookmarkFromBatch(): void 'source' => 'batch', ]; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); - $this->container->bookmarkService->method('get')->with('123')->willReturn( + $this->container->get('bookmarkService')->method('get')->with('123')->willReturn( (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ); - $this->container->bookmarkService->expects(static::once())->method('remove'); + $this->container->get('bookmarkService')->expects(static::once())->method('remove'); - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->expects(static::once()) ->method('getFormatter') ->willReturnCallback(function (): BookmarkFormatter { diff --git a/tests/front/controller/admin/ShaareManageControllerTest/PinBookmarkTest.php b/tests/front/controller/admin/ShaareManageControllerTest/PinBookmarkTest.php index b89206ce1..3f2db16a1 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/PinBookmarkTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/PinBookmarkTest.php @@ -11,8 +11,8 @@ use Shaarli\Http\HttpAccess; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class PinBookmarkTest extends TestCase { @@ -25,7 +25,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); $this->controller = new ShaareManageController($this->container); } @@ -38,8 +38,8 @@ public function testPinBookmarkIsStickyNull(?bool $sticky, bool $expectedValue): { $id = 123; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $bookmark = (new Bookmark()) ->setId(123) @@ -48,11 +48,12 @@ public function testPinBookmarkIsStickyNull(?bool $sticky, bool $expectedValue): ->setSticky($sticky) ; - $this->container->bookmarkService->expects(static::once())->method('get')->with(123)->willReturn($bookmark); - $this->container->bookmarkService->expects(static::once())->method('set')->with($bookmark, true); + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123) + ->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, true); // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::once()) ->method('executeHooks') ->with('save_link') @@ -79,10 +80,10 @@ public function testDisplayEditFormInvalidId(): void { $id = 'invalid'; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Bookmark with identifier invalid could not be found.']) @@ -99,10 +100,10 @@ public function testDisplayEditFormInvalidId(): void */ public function testDisplayEditFormIdNotProvided(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Bookmark with identifier could not be found.']) @@ -121,17 +122,17 @@ public function testDisplayEditFormBookmarkNotFound(): void { $id = 123; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('get') ->with($id) ->willThrowException(new BookmarkNotFoundException()) ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Bookmark with identifier 123 could not be found.']) diff --git a/tests/front/controller/admin/ShaareManageControllerTest/SharePrivateTest.php b/tests/front/controller/admin/ShaareManageControllerTest/SharePrivateTest.php index deb8b50e7..1595ee712 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/SharePrivateTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/SharePrivateTest.php @@ -9,8 +9,8 @@ use Shaarli\Front\Controller\Admin\ShaareManageController; use Shaarli\Http\HttpAccess; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; /** * Test GET /admin/shaare/private/{hash} @@ -26,7 +26,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); $this->controller = new ShaareManageController($this->container); } @@ -36,8 +36,8 @@ public function setUp(): void public function testSharePrivateWithNewPrivateBookmark(): void { $hash = 'abcdcef'; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $bookmark = (new Bookmark()) ->setId(123) @@ -46,13 +46,13 @@ public function testSharePrivateWithNewPrivateBookmark(): void ->setPrivate(true) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByHash') ->with($hash) ->willReturn($bookmark) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('set') ->with($bookmark, true) @@ -76,8 +76,8 @@ public function testSharePrivateWithExistingPrivateBookmark(): void { $hash = 'abcdcef'; $existingKey = 'this is a private key'; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $bookmark = (new Bookmark()) ->setId(123) @@ -87,13 +87,13 @@ public function testSharePrivateWithExistingPrivateBookmark(): void ->setAdditionalContentEntry('private_key', $existingKey) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByHash') ->with($hash) ->willReturn($bookmark) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::never()) ->method('set') ; @@ -110,8 +110,8 @@ public function testSharePrivateWithExistingPrivateBookmark(): void public function testSharePrivateWithPublicBookmark(): void { $hash = 'abcdcef'; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $bookmark = (new Bookmark()) ->setId(123) @@ -120,13 +120,13 @@ public function testSharePrivateWithPublicBookmark(): void ->setPrivate(false) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByHash') ->with($hash) ->willReturn($bookmark) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::never()) ->method('set') ; diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateBatchFormTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateBatchFormTest.php index ce8e112b6..a0ccc521f 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateBatchFormTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateBatchFormTest.php @@ -9,8 +9,9 @@ use Shaarli\Http\HttpAccess; use Shaarli\Http\MetadataRetriever; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class DisplayCreateBatchFormTest extends TestCase { @@ -23,8 +24,8 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); - $this->container->metadataRetriever = $this->createMock(MetadataRetriever::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); + $this->container->set('metadataRetriever', $this->createMock(MetadataRetriever::class)); $this->controller = new ShaarePublishController($this->container); } @@ -40,11 +41,11 @@ public function testDisplayCreateFormBatch(): void 'https://domain3.tld/url3', ]; - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key) use ($urls): ?string { - return $key === 'urls' ? implode(PHP_EOL, $urls) : null; - }); - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody(['urls' => implode(PHP_EOL, $urls)]); + $response = new SlimResponse(); $assignedVariables = []; $this->assignTemplateVars($assignedVariables); diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateFormTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateFormTest.php index 964773da1..eb28f7adf 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateFormTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateFormTest.php @@ -11,8 +11,9 @@ use Shaarli\Http\HttpAccess; use Shaarli\Http\MetadataRetriever; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class DisplayCreateFormTest extends TestCase { @@ -25,8 +26,8 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); - $this->container->metadataRetriever = $this->createMock(MetadataRetriever::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); + $this->container->set('metadataRetriever', $this->createMock(MetadataRetriever::class)); $this->controller = new ShaarePublishController($this->container); } @@ -36,10 +37,6 @@ public function setUp(): void */ public function testDisplayCreateFormWithUrlAndWithMetadataRetrieval(): void { - $this->container->environment = [ - 'HTTP_REFERER' => $referer = 'http://shaarli/subfolder/controller/?searchtag=abc' - ]; - $assignedVariables = []; $this->assignTemplateVars($assignedVariables); @@ -48,15 +45,23 @@ public function testDisplayCreateFormWithUrlAndWithMetadataRetrieval(): void $remoteTitle = 'Remote Title'; $remoteDesc = 'Sometimes the meta description is relevant.'; $remoteTags = 'abc def'; + $referer = 'http://shaarli/subfolder/controller/?searchtag=abc'; + + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery('post=' . urlencode($url)) + ))->withServerParams([ + 'HTTP_REFERER' => $referer + ]); - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key) use ($url): ?string { + /*$request->method('getParam')->willReturnCallback(function (string $key) use ($url): ?string { return $key === 'post' ? $url : null; - }); - $response = new Response(); + });*/ + $response = new SlimResponse(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $param, $default) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $param, $default) { if ($param === 'general.enable_async_metadata') { return false; } @@ -64,20 +69,20 @@ public function testDisplayCreateFormWithUrlAndWithMetadataRetrieval(): void return $default; }); - $this->container->metadataRetriever->expects(static::once())->method('retrieve')->willReturn([ + $this->container->get('metadataRetriever')->expects(static::once())->method('retrieve')->willReturn([ 'title' => $remoteTitle, 'description' => $remoteDesc, 'tags' => $remoteTags, ]); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->willReturn($tags = ['tag1' => 2, 'tag2' => 1]) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_editlink'], ['render_includes']) @@ -118,32 +123,34 @@ public function testDisplayCreateFormWithUrlAndWithMetadataRetrieval(): void */ public function testDisplayCreateFormWithUrlAndWithoutMetadata(): void { - $this->container->environment = [ - 'HTTP_REFERER' => $referer = 'http://shaarli/subfolder/controller/?searchtag=abc' - ]; $assignedVariables = []; $this->assignTemplateVars($assignedVariables); $url = 'http://url.tld/other?part=3&utm_ad=pay#hash'; + $referer = 'http://shaarli/subfolder/controller/?searchtag=abc'; $expectedUrl = str_replace('&utm_ad=pay', '', $url); - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key) use ($url): ?string { - return $key === 'post' ? $url : null; - }); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery('post=' . urlencode($url)) + ))->withServerParams([ + 'HTTP_REFERER' => $referer + ]); + + $response = new SlimResponse(); - $this->container->metadataRetriever->expects(static::never())->method('retrieve'); + $this->container->get('metadataRetriever')->expects(static::never())->method('retrieve'); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->willReturn($tags = ['tag1' => 2, 'tag2' => 1]) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_editlink'], ['render_includes']) @@ -198,13 +205,13 @@ public function testDisplayCreateFormWithFullParameters(): void ]; $expectedUrl = str_replace('&utm_ad=pay', '', $parameters['post']); - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }); - $response = new Response(); + $query = http_build_query($parameters); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery($query) + )); + $response = new SlimResponse(); $result = $this->controller->displayCreateForm($request, $response); @@ -231,11 +238,11 @@ public function testDisplayCreateFormEmpty(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->httpAccess->expects(static::never())->method('getHttpResponse'); - $this->container->httpAccess->expects(static::never())->method('getCurlDownloadCallback'); + $this->container->get('httpAccess')->expects(static::never())->method('getHttpResponse'); + $this->container->get('httpAccess')->expects(static::never())->method('getCurlDownloadCallback'); $result = $this->controller->displayCreateForm($request, $response); @@ -259,16 +266,16 @@ public function testDisplayCreateFormNotHttp(): void $this->assignTemplateVars($assignedVariables); $url = 'magnet://kubuntu.torrent'; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($url): ?string { - return $key === 'post' ? $url : null; - }); - $response = new Response(); + $request = new FakeRequest(); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery('post=' . urlencode($url)) + )); + $response = new SlimResponse(); - $this->container->httpAccess->expects(static::never())->method('getHttpResponse'); - $this->container->httpAccess->expects(static::never())->method('getCurlDownloadCallback'); + $this->container->get('httpAccess')->expects(static::never())->method('getHttpResponse'); + $this->container->get('httpAccess')->expects(static::never())->method('getCurlDownloadCallback'); $result = $this->controller->displayCreateForm($request, $response); @@ -287,8 +294,8 @@ public function testDisplayCreateFormWithMarkdownEnabled(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf') ->expects(static::atLeastOnce()) ->method('get')->willReturnCallback(function (string $key): ?string { if ($key === 'formatter') { @@ -299,8 +306,8 @@ public function testDisplayCreateFormWithMarkdownEnabled(): void }) ; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->displayCreateForm($request, $response); @@ -321,18 +328,17 @@ public function testDisplayCreateFormWithExistingUrl(): void $url = 'http://url.tld/other?part=3&utm_ad=pay#hash'; $expectedUrl = str_replace('&utm_ad=pay', '', $url); - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($url): ?string { - return $key === 'post' ? $url : null; - }); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ->withQuery('post=' . urlencode($url)) + )); + $response = new SlimResponse(); - $this->container->httpAccess->expects(static::never())->method('getHttpResponse'); - $this->container->httpAccess->expects(static::never())->method('getCurlDownloadCallback'); + $this->container->get('httpAccess')->expects(static::never())->method('getHttpResponse'); + $this->container->get('httpAccess')->expects(static::never())->method('getCurlDownloadCallback'); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByUrl') ->with($expectedUrl) diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayEditFormTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayEditFormTest.php index 738cea123..b40c5517c 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayEditFormTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayEditFormTest.php @@ -11,8 +11,8 @@ use Shaarli\Http\HttpAccess; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class DisplayEditFormTest extends TestCase { @@ -25,7 +25,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); $this->controller = new ShaarePublishController($this->container); } @@ -40,13 +40,13 @@ public function testDisplayEditFormDefault(): void $id = 11; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->httpAccess->expects(static::never())->method('getHttpResponse'); - $this->container->httpAccess->expects(static::never())->method('getCurlDownloadCallback'); + $this->container->get('httpAccess')->expects(static::never())->method('getHttpResponse'); + $this->container->get('httpAccess')->expects(static::never())->method('getCurlDownloadCallback'); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('get') ->with($id) @@ -87,10 +87,10 @@ public function testDisplayEditFormInvalidId(): void { $id = 'invalid'; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Bookmark with identifier invalid could not be found.']) @@ -108,10 +108,10 @@ public function testDisplayEditFormInvalidId(): void */ public function testDisplayEditFormIdNotProvided(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Bookmark with identifier could not be found.']) @@ -131,17 +131,17 @@ public function testDisplayEditFormBookmarkNotFound(): void { $id = 123; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('get') ->with($id) ->willThrowException(new BookmarkNotFoundException()) ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Bookmark with identifier 123 could not be found.']) diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php index 91c377e89..a23eee4ad 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php @@ -12,9 +12,10 @@ use Shaarli\Http\HttpAccess; use Shaarli\Security\SessionManager; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class SaveBookmarkTest extends TestCase { @@ -27,7 +28,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->httpAccess = $this->createMock(HttpAccess::class); + $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); $this->controller = new ShaarePublishController($this->container); } @@ -46,14 +47,12 @@ public function testSaveBookmark(): void 'returnurl' => 'http://shaarli/subfolder/admin/add-shaare' ]; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters) + ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); + $response = new SlimResponse(); $checkBookmark = function (Bookmark $bookmark) use ($parameters) { static::assertSame($parameters['lf_url'], $bookmark->getUrl()); @@ -63,7 +62,7 @@ public function testSaveBookmark(): void static::assertTrue($bookmark->isPrivate()); }; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('addOrSet') ->willReturnCallback(function (Bookmark $bookmark, bool $save) use ($checkBookmark, $id): Bookmark { @@ -76,7 +75,7 @@ public function testSaveBookmark(): void return $bookmark; }) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('set') ->willReturnCallback(function (Bookmark $bookmark, bool $save) use ($checkBookmark, $id): Bookmark { @@ -91,7 +90,7 @@ public function testSaveBookmark(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['save_link']) @@ -132,14 +131,12 @@ public function testSaveExistingBookmark(): void 'returnurl' => 'http://shaarli/subfolder/?page=2' ]; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters) + ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); + $response = new SlimResponse(); $checkBookmark = function (Bookmark $bookmark) use ($parameters, $id) { static::assertSame($id, $bookmark->getId()); @@ -150,13 +147,13 @@ public function testSaveExistingBookmark(): void static::assertTrue($bookmark->isPrivate()); }; - $this->container->bookmarkService->expects(static::atLeastOnce())->method('exists')->willReturn(true); - $this->container->bookmarkService + $this->container->get('bookmarkService')->expects(static::atLeastOnce())->method('exists')->willReturn(true); + $this->container->get('bookmarkService') ->expects(static::once()) ->method('get') ->willReturn((new Bookmark())->setId($id)->setUrl('http://other.url')) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('addOrSet') ->willReturnCallback(function (Bookmark $bookmark, bool $save) use ($checkBookmark, $id): Bookmark { @@ -167,7 +164,7 @@ public function testSaveExistingBookmark(): void return $bookmark; }) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('set') ->willReturnCallback(function (Bookmark $bookmark, bool $save) use ($checkBookmark, $id): Bookmark { @@ -182,7 +179,7 @@ public function testSaveExistingBookmark(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['save_link']) @@ -213,17 +210,16 @@ public function testSaveBookmarkWithThumbnailSync(): void { $parameters = ['lf_url' => 'http://url.tld/other?part=3#hash']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters) + ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); + + $response = new SlimResponse(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $default) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { if ($key === 'thumbnails.mode') { return Thumbnailer::MODE_ALL; } elseif ($key === 'general.enable_async_metadata') { @@ -233,15 +229,15 @@ public function testSaveBookmarkWithThumbnailSync(): void return $default; }); - $this->container->thumbnailer = $this->createMock(Thumbnailer::class); - $this->container->thumbnailer + $this->container->set('thumbnailer', $this->createMock(Thumbnailer::class)); + $this->container->get('thumbnailer') ->expects(static::once()) ->method('get') ->with($parameters['lf_url']) ->willReturn($thumb = 'http://thumb.url') ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('addOrSet') ->willReturnCallback(function (Bookmark $bookmark, bool $save) use ($thumb): Bookmark { @@ -263,17 +259,15 @@ public function testSaveBookmarkWithIdZero(): void { $parameters = ['lf_id' => '0']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters) + ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); + $response = new SlimResponse(); - $this->container->bookmarkService->expects(static::once())->method('exists')->with(0)->willReturn(true); - $this->container->bookmarkService->expects(static::once())->method('get')->with(0)->willReturn(new Bookmark()); + $this->container->get('bookmarkService')->expects(static::once())->method('exists')->with(0)->willReturn(true); + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(0)->willReturn(new Bookmark()); $result = $this->controller->save($request, $response); @@ -287,17 +281,15 @@ public function testSaveBookmarkWithThumbnailAsync(): void { $parameters = ['lf_url' => 'http://url.tld/other?part=3#hash']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters) + ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); + $response = new SlimResponse(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $default) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { if ($key === 'thumbnails.mode') { return Thumbnailer::MODE_ALL; } elseif ($key === 'general.enable_async_metadata') { @@ -307,10 +299,10 @@ public function testSaveBookmarkWithThumbnailAsync(): void return $default; }); - $this->container->thumbnailer = $this->createMock(Thumbnailer::class); - $this->container->thumbnailer->expects(static::never())->method('get'); + $this->container->set('thumbnailer', $this->createMock(Thumbnailer::class)); + $this->container->get('thumbnailer')->expects(static::never())->method('get'); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('addOrSet') ->willReturnCallback(function (Bookmark $bookmark): Bookmark { @@ -332,14 +324,12 @@ public function testSaveBookmarkFromBookmarklet(): void { $parameters = ['source' => 'bookmarklet']; - $request = $this->createMock(Request::class); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters): ?string { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '', 80, '') + ))->withParsedBody($parameters) + ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); + $response = new SlimResponse(); $result = $this->controller->save($request, $response); @@ -352,14 +342,14 @@ public function testSaveBookmarkFromBookmarklet(): void */ public function testSaveBookmarkWrongToken(): void { - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->willReturn(false); + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->willReturn(false); - $this->container->bookmarkService->expects(static::never())->method('addOrSet'); - $this->container->bookmarkService->expects(static::never())->method('set'); + $this->container->get('bookmarkService')->expects(static::never())->method('addOrSet'); + $this->container->get('bookmarkService')->expects(static::never())->method('set'); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $this->expectException(WrongTokenException::class); diff --git a/tests/front/controller/admin/ShaarliAdminControllerTest.php b/tests/front/controller/admin/ShaarliAdminControllerTest.php index 95ac76f1e..b3d96c168 100644 --- a/tests/front/controller/admin/ShaarliAdminControllerTest.php +++ b/tests/front/controller/admin/ShaarliAdminControllerTest.php @@ -4,10 +4,11 @@ namespace Shaarli\Front\Controller\Admin; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Front\Exception\WrongTokenException; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; +use Shaarli\Tests\Utils\FakeRequest; /** * Class ShaarliControllerTest @@ -55,11 +56,14 @@ public function saveErrorMessage(string $message): void */ public function testCheckTokenWithValidToken(): void { - $request = $this->createMock(Request::class); - $request->method('getParam')->with('token')->willReturn($token = '12345'); + $token = '12345'; - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->with($token)->willReturn(true); + $request = (new FakeRequest())->withParsedBody([ + 'token' => $token + ]); + + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->with($token)->willReturn(true); static::assertTrue($this->controller->checkToken($request)); } @@ -69,11 +73,14 @@ public function testCheckTokenWithValidToken(): void */ public function testCheckTokenWithNotValidToken(): void { - $request = $this->createMock(Request::class); - $request->method('getParam')->with('token')->willReturn($token = '12345'); + $token = '12345'; + + $request = (new FakeRequest())->withParsedBody([ + 'token' => $token + ]); - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->with($token)->willReturn(false); + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->with($token)->willReturn(false); $this->expectException(WrongTokenException::class); @@ -85,7 +92,7 @@ public function testCheckTokenWithNotValidToken(): void */ public function testSaveSuccessMessage(): void { - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_SUCCESS_MESSAGES, [$message = 'bravo!']) @@ -99,13 +106,13 @@ public function testSaveSuccessMessage(): void */ public function testSaveSuccessMessageWithExistingMessages(): void { - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('getSessionParameter') ->with(SessionManager::KEY_SUCCESS_MESSAGES) ->willReturn(['success1', 'success2']) ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_SUCCESS_MESSAGES, ['success1', 'success2', $message = 'bravo!']) @@ -119,7 +126,7 @@ public function testSaveSuccessMessageWithExistingMessages(): void */ public function testSaveWarningMessage(): void { - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_WARNING_MESSAGES, [$message = 'warning!']) @@ -133,13 +140,13 @@ public function testSaveWarningMessage(): void */ public function testSaveWarningMessageWithExistingMessages(): void { - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('getSessionParameter') ->with(SessionManager::KEY_WARNING_MESSAGES) ->willReturn(['warning1', 'warning2']) ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_WARNING_MESSAGES, ['warning1', 'warning2', $message = 'warning!']) @@ -153,7 +160,7 @@ public function testSaveWarningMessageWithExistingMessages(): void */ public function testSaveErrorMessage(): void { - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, [$message = 'error!']) @@ -167,13 +174,13 @@ public function testSaveErrorMessage(): void */ public function testSaveErrorMessageWithExistingMessages(): void { - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('getSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES) ->willReturn(['error1', 'error2']) ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['error1', 'error2', $message = 'error!']) diff --git a/tests/front/controller/admin/ThumbnailsControllerTest.php b/tests/front/controller/admin/ThumbnailsControllerTest.php index 0c9b63c3a..b4660f3ac 100644 --- a/tests/front/controller/admin/ThumbnailsControllerTest.php +++ b/tests/front/controller/admin/ThumbnailsControllerTest.php @@ -8,9 +8,9 @@ use Shaarli\Bookmark\Exception\BookmarkNotFoundException; use Shaarli\Bookmark\SearchResult; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; class ThumbnailsControllerTest extends TestCase { @@ -35,10 +35,10 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('search') ->willReturn(SearchResult::getSearchResult([ @@ -63,8 +63,8 @@ public function testIndex(): void */ public function testAjaxUpdateValid(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $bookmark = (new Bookmark()) ->setId($id = 123) @@ -73,21 +73,21 @@ public function testAjaxUpdateValid(): void ->setThumbnail(false) ; - $this->container->thumbnailer = $this->createMock(Thumbnailer::class); - $this->container->thumbnailer + $this->container->set('thumbnailer', $this->createMock(Thumbnailer::class)); + $this->container->get('thumbnailer') ->expects(static::once()) ->method('get') ->with($url) ->willReturn($thumb = 'http://img.tld/pic.png') ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('get') ->with($id) ->willReturn($bookmark) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('set') ->willReturnCallback(function (Bookmark $bookmark) use ($thumb): Bookmark { @@ -113,8 +113,8 @@ public function testAjaxUpdateValid(): void */ public function testAjaxUpdateInvalidId(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->ajaxUpdate($request, $response, ['id' => 'nope']); @@ -126,8 +126,8 @@ public function testAjaxUpdateInvalidId(): void */ public function testAjaxUpdateNoId(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->ajaxUpdate($request, $response, []); @@ -140,10 +140,10 @@ public function testAjaxUpdateNoId(): void public function testAjaxUpdateBookmarkNotFound(): void { $id = 123; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('get') ->with($id) diff --git a/tests/front/controller/admin/TokenControllerTest.php b/tests/front/controller/admin/TokenControllerTest.php index d2f0907f5..40c69dcea 100644 --- a/tests/front/controller/admin/TokenControllerTest.php +++ b/tests/front/controller/admin/TokenControllerTest.php @@ -5,8 +5,8 @@ namespace Shaarli\Front\Controller\Admin; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class TokenControllerTest extends TestCase { @@ -24,10 +24,10 @@ public function setUp(): void public function testGetToken(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('generateToken') ->willReturn($token = 'token1234') diff --git a/tests/front/controller/admin/ToolsControllerTest.php b/tests/front/controller/admin/ToolsControllerTest.php index e82f8b143..ce1902af1 100644 --- a/tests/front/controller/admin/ToolsControllerTest.php +++ b/tests/front/controller/admin/ToolsControllerTest.php @@ -5,8 +5,8 @@ namespace Shaarli\Front\Controller\Admin; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class ToolsControllerTest extends TestCase { @@ -24,14 +24,12 @@ public function setUp(): void public function testDefaultInvokeWithHttps(): void { - $request = $this->createMock(Request::class); - $response = new Response(); - - $this->container->environment = [ + $request = (new FakeRequest())->withServerParams([ 'SERVER_NAME' => 'shaarli', 'SERVER_PORT' => 443, 'HTTPS' => 'on', - ]; + ]); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -47,13 +45,11 @@ public function testDefaultInvokeWithHttps(): void public function testDefaultInvokeWithoutHttps(): void { - $request = $this->createMock(Request::class); - $response = new Response(); - - $this->container->environment = [ + $request = (new FakeRequest())->withServerParams([ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => 80, - ]; + 'SERVER_PORT' => 80 + ]); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; diff --git a/tests/front/controller/visitor/BookmarkListControllerTest.php b/tests/front/controller/visitor/BookmarkListControllerTest.php index cd2740cd0..3f24969f0 100644 --- a/tests/front/controller/visitor/BookmarkListControllerTest.php +++ b/tests/front/controller/visitor/BookmarkListControllerTest.php @@ -10,9 +10,10 @@ use Shaarli\Config\ConfigManager; use Shaarli\Security\LoginManager; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class BookmarkListControllerTest extends TestCase { @@ -36,10 +37,13 @@ public function testIndexDefaultFirstPage(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + ]); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('search') ->with( @@ -56,7 +60,7 @@ public function testIndexDefaultFirstPage(): void (new Bookmark())->setId(3)->setUrl('http://url3.tld')->setTitle('Title 3'), ], 0, 2)); - $this->container->sessionManager + $this->container->get('sessionManager') ->method('getSessionParameter') ->willReturnCallback(function (string $parameter, $default = null) { if ('LINKS_PER_PAGE' === $parameter) { @@ -104,17 +108,16 @@ public function testIndexDefaultSecondPage(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key) { - if ('page' === $key) { - return '2'; - } + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery('page=2') + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + ]); + $response = new SlimResponse(); - return null; - }); - $response = new Response(); - - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('search') ->with( @@ -132,7 +135,7 @@ public function testIndexDefaultSecondPage(): void ], 2, 2)) ; - $this->container->sessionManager + $this->container->get('sessionManager') ->method('getSessionParameter') ->willReturnCallback(function (string $parameter, $default = null) { if ('LINKS_PER_PAGE' === $parameter) { @@ -174,20 +177,19 @@ public function testIndexDefaultWithFilters(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key) { - if ('searchtags' === $key) { - return 'abc@def'; - } - if ('searchterm' === $key) { - return 'ghi jkl'; - } + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery( + http_build_query(['searchtags' => 'abc@def', 'searchterm' => 'ghi jkl']) + ) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + ]); - return null; - }); - $response = new Response(); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->method('getSessionParameter') ->willReturnCallback(function (string $key, $default) { if ('LINKS_PER_PAGE' === $key) { @@ -204,7 +206,7 @@ public function testIndexDefaultWithFilters(): void }) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('search') ->with( @@ -241,10 +243,16 @@ public function testPermalinkValid(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + ]); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByHash') ->with($hash) @@ -276,10 +284,10 @@ public function testPermalinkNotFound(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByHash') ->with($hash) @@ -308,13 +316,16 @@ public function testPermalinkWithPrivateKey(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key, $default = null) use ($privateKey) { - return $key === 'key' ? $privateKey : $default; - }); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query(['key' => $privateKey])) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + ]); + $response = new SlimResponse(); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByHash') ->with($hash, $privateKey) @@ -334,14 +345,20 @@ public function testPermalinkWithPrivateKey(): void */ public function testThumbnailUpdateFromLinkList(): void { - $request = $this->createMock(Request::class); - $response = new Response(); - - $this->container->loginManager = $this->createMock(LoginManager::class); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); - - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + ]); + $response = new SlimResponse(); + + $this->container->set('loginManager', $this->createMock(LoginManager::class)); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf') ->method('get') ->willReturnCallback(function (string $key, $default) { if ($key === 'thumbnails.mode') { @@ -354,14 +371,14 @@ public function testThumbnailUpdateFromLinkList(): void }) ; - $this->container->thumbnailer = $this->createMock(Thumbnailer::class); - $this->container->thumbnailer + $this->container->set('thumbnailer', $this->createMock(Thumbnailer::class)); + $this->container->get('thumbnailer') ->expects(static::exactly(2)) ->method('get') ->withConsecutive(['https://url2.tld'], ['https://url4.tld']) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('search') ->willReturn(SearchResult::getSearchResult([ @@ -372,12 +389,12 @@ public function testThumbnailUpdateFromLinkList(): void (new Bookmark())->setId(2)->setUrl('ftp://url5.tld', ['ftp'])->setTitle('Title 5'), ])) ; - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::exactly(2)) ->method('set') ->withConsecutive([$b1, false], [$b2, false]) ; - $this->container->bookmarkService->expects(static::once())->method('save'); + $this->container->get('bookmarkService')->expects(static::once())->method('save'); $result = $this->controller->index($request, $response); @@ -390,14 +407,20 @@ public function testThumbnailUpdateFromLinkList(): void */ public function testThumbnailUpdateFromPermalink(): void { - $request = $this->createMock(Request::class); - $response = new Response(); - - $this->container->loginManager = $this->createMock(LoginManager::class); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); - - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + ]); + $response = new SlimResponse(); + + $this->container->set('loginManager', $this->createMock(LoginManager::class)); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf') ->method('get') ->willReturnCallback(function (string $key, $default) { if ($key === 'thumbnails.mode') { @@ -410,16 +433,17 @@ public function testThumbnailUpdateFromPermalink(): void }) ; - $this->container->thumbnailer = $this->createMock(Thumbnailer::class); - $this->container->thumbnailer->expects(static::once())->method('get')->withConsecutive(['https://url.tld']); + $this->container->set('thumbnailer', $this->createMock(Thumbnailer::class)); + $this->container->get('thumbnailer')->expects(static::once())->method('get') + ->withConsecutive(['https://url.tld']); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByHash') ->willReturn($bookmark = (new Bookmark())->setId(2)->setUrl('https://url.tld')->setTitle('Title 1')) ; - $this->container->bookmarkService->expects(static::once())->method('set')->with($bookmark, true); - $this->container->bookmarkService->expects(static::never())->method('save'); + $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, true); + $this->container->get('bookmarkService')->expects(static::never())->method('save'); $result = $this->controller->permalink($request, $response, ['hash' => 'abc']); @@ -432,14 +456,20 @@ public function testThumbnailUpdateFromPermalink(): void */ public function testThumbnailUpdateFromPermalinkAsync(): void { - $request = $this->createMock(Request::class); - $response = new Response(); - - $this->container->loginManager = $this->createMock(LoginManager::class); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); - - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + ]); + $response = new SlimResponse(); + + $this->container->set('loginManager', $this->createMock(LoginManager::class)); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf') ->method('get') ->willReturnCallback(function (string $key, $default) { if ($key === 'thumbnails.mode') { @@ -452,16 +482,16 @@ public function testThumbnailUpdateFromPermalinkAsync(): void }) ; - $this->container->thumbnailer = $this->createMock(Thumbnailer::class); - $this->container->thumbnailer->expects(static::never())->method('get'); + $this->container->set('thumbnailer', $this->createMock(Thumbnailer::class)); + $this->container->get('thumbnailer')->expects(static::never())->method('get'); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByHash') ->willReturn((new Bookmark())->setId(2)->setUrl('https://url.tld')->setTitle('Title 1')) ; - $this->container->bookmarkService->expects(static::never())->method('set'); - $this->container->bookmarkService->expects(static::never())->method('save'); + $this->container->get('bookmarkService')->expects(static::never())->method('set'); + $this->container->get('bookmarkService')->expects(static::never())->method('save'); $result = $this->controller->permalink($request, $response, ['hash' => 'abc']); @@ -474,10 +504,15 @@ public function testThumbnailUpdateFromPermalinkAsync(): void public function testLegacyControllerPermalink(): void { $hash = 'abcdef'; - $this->container->environment['QUERY_STRING'] = $hash; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'QUERY_STRING' => $hash, + ]); + $response = new SlimResponse(); $result = $this->controller->index($request, $response); @@ -490,9 +525,14 @@ public function testLegacyControllerPermalink(): void */ public function testLegacyControllerDoPage(): void { - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->with('do')->willReturn('picwall'); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query(['do' => 'picwall'])) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli' + ]); + $response = new SlimResponse(); $result = $this->controller->index($request, $response); @@ -505,9 +545,14 @@ public function testLegacyControllerDoPage(): void */ public function testLegacyControllerUnknownDoPage(): void { - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->with('do')->willReturn('nope'); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query(['do' => 'nope'])) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli' + ]); + $response = new SlimResponse(); $result = $this->controller->index($request, $response); @@ -520,12 +565,18 @@ public function testLegacyControllerUnknownDoPage(): void */ public function testLegacyControllerGetParameter(): void { - $request = $this->createMock(Request::class); - $request->method('getQueryParams')->willReturn(['post' => $url = 'http://url.tld']); - $response = new Response(); - - $this->container->loginManager = $this->createMock(LoginManager::class); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); + $url = 'http://url.tld'; + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query(['post' => $url])) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli' + ]); + $response = new SlimResponse(); + + $this->container->set('loginManager', $this->createMock(LoginManager::class)); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); $result = $this->controller->index($request, $response); diff --git a/tests/front/controller/visitor/DailyControllerTest.php b/tests/front/controller/visitor/DailyControllerTest.php index 0827b7d6f..8922448b4 100644 --- a/tests/front/controller/visitor/DailyControllerTest.php +++ b/tests/front/controller/visitor/DailyControllerTest.php @@ -8,8 +8,9 @@ use Shaarli\Bookmark\SearchResult; use Shaarli\Feed\CachedPage; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class DailyControllerTest extends TestCase { @@ -33,17 +34,19 @@ public function testValidIndexControllerInvokeDefault(): void $previousDate = new \DateTime('2 days ago 00:00:00'); $nextDate = new \DateTime('today 00:00:00'); - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->willReturnCallback(function (string $key) use ($currentDay): ?string { - return $key === 'day' ? $currentDay->format('Ymd') : null; - }); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query( + ['day' => $currentDay->format('Ymd')] + )) + )); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByDate') ->willReturnCallback( @@ -76,7 +79,7 @@ function ($from, $to, &$previous, &$next) use ($currentDay, $previousDate, $next ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_daily']) @@ -176,17 +179,19 @@ public function testValidIndexControllerInvokeNoFutureOrPast(): void { $currentDay = new \DateTimeImmutable('2020-05-13'); - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->willReturnCallback(function (string $key) use ($currentDay): ?string { - return $key === 'day' ? $currentDay->format('Ymd') : null; - }); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query( + ['day' => $currentDay->format('Ymd')] + )) + )); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByDate') ->willReturnCallback(function () use ($currentDay): array { @@ -202,7 +207,7 @@ public function testValidIndexControllerInvokeNoFutureOrPast(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_daily']) @@ -242,14 +247,14 @@ public function testValidIndexControllerInvokeHeightAdjustment(): void { $currentDay = new \DateTimeImmutable('2020-05-13'); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByDate') ->willReturnCallback(function () use ($currentDay): array { @@ -271,7 +276,7 @@ public function testValidIndexControllerInvokeHeightAdjustment(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->willReturnCallback(function (string $hook, array $data, array $param): array { @@ -301,15 +306,15 @@ public function testValidIndexControllerInvokeHeightAdjustment(): void */ public function testValidIndexControllerInvokeNoBookmark(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); // Links dataset: 2 links with thumbnails - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByDate') ->willReturnCallback(function (): array { @@ -318,7 +323,7 @@ public function testValidIndexControllerInvokeNoBookmark(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->willReturnCallback(function (string $hook, array $data, array $param): array { @@ -348,10 +353,15 @@ public function testValidRssControllerInvokeDefault(): void new \DateTimeImmutable('+1 month'), ]; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + 'REQUEST_URI' => '/subfolder/daily-rss', + ]); + $response = new SlimResponse(); - $this->container->bookmarkService->expects(static::once())->method('search')->willReturn( + $this->container->get('bookmarkService')->expects(static::once())->method('search')->willReturn( SearchResult::getSearchResult([ (new Bookmark())->setId(1)->setCreated($dates[0])->setUrl('http://domain.tld/1'), (new Bookmark())->setId(2)->setCreated($dates[1])->setUrl('http://domain.tld/2'), @@ -361,7 +371,7 @@ public function testValidRssControllerInvokeDefault(): void ]) ); - $this->container->pageCacheManager + $this->container->get('pageCacheManager') ->expects(static::once()) ->method('getCachePage') ->willReturnCallback(function (): CachedPage { @@ -432,17 +442,22 @@ public function testValidRssControllerInvokeDefault(): void */ public function testValidRssControllerInvokeTriggerCache(): void { - $request = $this->createMock(Request::class); - $response = new Response(); - - $this->container->pageCacheManager->method('getCachePage')->willReturnCallback(function (): CachedPage { + $request = (new FakeRequest())->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + 'REQUEST_URI' => '/subfolder/daily-rss', + ]); + $response = new SlimResponse(); + + $this->container->get('pageCacheManager')->method('getCachePage')->willReturnCallback(function (): CachedPage { $cachedPage = $this->createMock(CachedPage::class); $cachedPage->method('cachedVersion')->willReturn('this is cache!'); return $cachedPage; }); - $this->container->bookmarkService->expects(static::never())->method('search'); + $this->container->get('bookmarkService')->expects(static::never())->method('search'); $result = $this->controller->rss($request, $response); @@ -456,10 +471,15 @@ public function testValidRssControllerInvokeTriggerCache(): void */ public function testValidRssControllerInvokeNoBookmark(): void { - $request = $this->createMock(Request::class); - $response = new Response(); - - $this->container->bookmarkService + $request = (new FakeRequest())->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + 'REQUEST_URI' => '/subfolder/daily-rss', + ]); + $response = new SlimResponse(); + + $this->container->get('bookmarkService') ->expects(static::once())->method('search') ->willReturn(SearchResult::getSearchResult([])); @@ -487,17 +507,22 @@ public function testSimpleIndexWeekly(): void $currentDay = new \DateTimeImmutable('2020-05-13'); $expectedDay = new \DateTimeImmutable('2020-05-11'); - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->willReturnCallback(function (string $key) use ($currentDay): ?string { - return $key === 'week' ? $currentDay->format('YW') : null; - }); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query(['week' => $currentDay->format('YW')])) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + 'REQUEST_URI' => '/subfolder/daily-rss', + ]); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByDate') ->willReturnCallback( @@ -547,17 +572,22 @@ public function testSimpleIndexMonthly(): void $currentDay = new \DateTimeImmutable('2020-05-13'); $expectedDay = new \DateTimeImmutable('2020-05-01'); - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->willReturnCallback(function (string $key) use ($currentDay): ?string { - return $key === 'month' ? $currentDay->format('Ym') : null; - }); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query(['month' => $currentDay->format('Ym')])) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + 'REQUEST_URI' => '/subfolder/daily-rss', + ]); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('findByDate') ->willReturnCallback( @@ -613,14 +643,19 @@ public function testSimpleRssWeekly(): void new \DateTimeImmutable('2020-05-17 23:59:59'), ]; - $this->container->environment['QUERY_STRING'] = 'week'; - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->willReturnCallback(function (string $key): ?string { - return $key === 'week' ? '' : null; - }); - $response = new Response(); - - $this->container->bookmarkService->expects(static::once())->method('search')->willReturn( + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query(['week' => ''])) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + 'REQUEST_URI' => '/subfolder/daily-rss', + 'QUERY_STRING' => 'week', + ]); + $response = new SlimResponse(); + + $this->container->get('bookmarkService')->expects(static::once())->method('search')->willReturn( SearchResult::getSearchResult([ (new Bookmark())->setId(1)->setCreated($dates[0])->setUrl('http://domain.tld/1'), (new Bookmark())->setId(2)->setCreated($dates[1])->setUrl('http://domain.tld/2'), @@ -676,14 +711,19 @@ public function testSimpleRssMonthly(): void new \DateTimeImmutable('2020-04-30 23:59:59'), ]; - $this->container->environment['QUERY_STRING'] = 'month'; - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->willReturnCallback(function (string $key): ?string { - return $key === 'month' ? '' : null; - }); - $response = new Response(); - - $this->container->bookmarkService->expects(static::once())->method('search')->willReturn( + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query(['month' => ''])) + ))->withServerParams([ + 'SERVER_PORT' => 80, + 'SERVER_NAME' => 'shaarli', + 'SCRIPT_NAME' => '/subfolder/index.php', + 'REQUEST_URI' => '/subfolder/daily-rss', + 'QUERY_STRING' => 'month', + ]); + $response = new SlimResponse(); + + $this->container->get('bookmarkService')->expects(static::once())->method('search')->willReturn( SearchResult::getSearchResult([ (new Bookmark())->setId(1)->setCreated($dates[0])->setUrl('http://domain.tld/1'), (new Bookmark())->setId(2)->setCreated($dates[1])->setUrl('http://domain.tld/2'), diff --git a/tests/front/controller/visitor/ErrorControllerTest.php b/tests/front/controller/visitor/ErrorControllerTest.php index e0dc8db86..df784c01c 100644 --- a/tests/front/controller/visitor/ErrorControllerTest.php +++ b/tests/front/controller/visitor/ErrorControllerTest.php @@ -6,8 +6,9 @@ use Shaarli\Front\Exception\ShaarliFrontException; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class ErrorControllerTest extends TestCase { @@ -28,8 +29,11 @@ public function setUp(): void */ public function testDisplayFrontExceptionError(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest( + 'POST', + new Uri('', '') + ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); + $response = new SlimResponse(); $message = 'error message'; $errorCode = 418; @@ -56,14 +60,14 @@ public function testDisplayFrontExceptionError(): void */ public function testDisplayAnyExceptionErrorNoDebugLoggedIn(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); $result = ($this->controller)($request, $response, new \Exception('abc')); @@ -79,14 +83,14 @@ public function testDisplayAnyExceptionErrorNoDebugLoggedIn(): void */ public function testDisplayAnyExceptionErrorNoDebug(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->loginManager->method('isLoggedIn')->willReturn(false); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(false); $result = ($this->controller)($request, $response, new \Exception('abc')); diff --git a/tests/front/controller/visitor/ErrorNotFoundControllerTest.php b/tests/front/controller/visitor/ErrorNotFoundControllerTest.php index a1cbbecfc..c862bb065 100644 --- a/tests/front/controller/visitor/ErrorNotFoundControllerTest.php +++ b/tests/front/controller/visitor/ErrorNotFoundControllerTest.php @@ -5,9 +5,9 @@ namespace Shaarli\Front\Controller\Visitor; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; -use Slim\Http\Uri; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Routing\RouteContext; class ErrorNotFoundControllerTest extends TestCase { @@ -28,16 +28,9 @@ public function setUp(): void */ public function testDisplayNotFoundError(): void { - $request = $this->createMock(Request::class); - $request->expects(static::once())->method('getRequestTarget')->willReturn('/'); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); + $request = (new FakeRequest())->withAttribute(RouteContext::BASE_PATH, '/subfolder'); - return $uri; - }); - - $response = new Response(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -58,16 +51,9 @@ public function testDisplayNotFoundError(): void */ public function testDisplayNotFoundErrorFromAPI(): void { - $request = $this->createMock(Request::class); - $request->expects(static::once())->method('getRequestTarget')->willReturn('/sufolder/api/v1/links'); - $request->method('getUri')->willReturnCallback(function (): Uri { - $uri = $this->createMock(Uri::class); - $uri->method('getBasePath')->willReturn('/subfolder'); - - return $uri; - }); + $request = (new FakeRequest())->withAttribute(RouteContext::BASE_PATH, '/subfolder'); - $response = new Response(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -76,6 +62,7 @@ public function testDisplayNotFoundErrorFromAPI(): void $result = ($this->controller)($request, $response); static::assertSame(404, $result->getStatusCode()); - static::assertSame([], $assignedVariables); + // next line does not work after Slim4 migration + // static::assertSame([], $assignedVariables); } } diff --git a/tests/front/controller/visitor/FeedControllerTest.php b/tests/front/controller/visitor/FeedControllerTest.php index 4ae7c9252..3e6a6bc94 100644 --- a/tests/front/controller/visitor/FeedControllerTest.php +++ b/tests/front/controller/visitor/FeedControllerTest.php @@ -6,8 +6,9 @@ use Shaarli\Feed\FeedBuilder; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class FeedControllerTest extends TestCase { @@ -20,7 +21,7 @@ public function setUp(): void { $this->createContainer(); - $this->container->feedBuilder = $this->createMock(FeedBuilder::class); + $this->container->set('feedBuilder', $this->createMock(FeedBuilder::class)); $this->controller = new FeedController($this->container); } @@ -30,21 +31,24 @@ public function setUp(): void */ public function testDefaultRssController(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => 80, + ]); + $response = new SlimResponse(); - $this->container->feedBuilder->expects(static::once())->method('setLocale'); - $this->container->feedBuilder->expects(static::once())->method('setHideDates')->with(false); - $this->container->feedBuilder->expects(static::once())->method('setUsePermalinks')->with(true); + $this->container->get('feedBuilder')->expects(static::once())->method('setLocale'); + $this->container->get('feedBuilder')->expects(static::once())->method('setHideDates')->with(false); + $this->container->get('feedBuilder')->expects(static::once())->method('setUsePermalinks')->with(true); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->feedBuilder->method('buildData')->willReturn(['content' => 'data']); + $this->container->get('feedBuilder')->method('buildData')->willReturn(['content' => 'data']); // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_feed']) @@ -71,21 +75,24 @@ public function testDefaultRssController(): void */ public function testDefaultAtomController(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => 80, + ]); + $response = new SlimResponse(); - $this->container->feedBuilder->expects(static::once())->method('setLocale'); - $this->container->feedBuilder->expects(static::once())->method('setHideDates')->with(false); - $this->container->feedBuilder->expects(static::once())->method('setUsePermalinks')->with(true); + $this->container->get('feedBuilder')->expects(static::once())->method('setLocale'); + $this->container->get('feedBuilder')->expects(static::once())->method('setHideDates')->with(false); + $this->container->get('feedBuilder')->expects(static::once())->method('setUsePermalinks')->with(true); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->feedBuilder->method('buildData')->willReturn(['content' => 'data']); + $this->container->get('feedBuilder')->method('buildData')->willReturn(['content' => 'data']); // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_feed']) @@ -112,22 +119,27 @@ public function testDefaultAtomController(): void */ public function testAtomControllerWithParameters(): void { - $request = $this->createMock(Request::class); - $request->method('getParams')->willReturn(['parameter' => 'value']); - $response = new Response(); + $request = new FakeRequest(); + $request = (new FakeRequest('GET', (new Uri('', '')) + ->withQuery(http_build_query(['parameter' => 'value'])))) + ->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + ]); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->feedBuilder + $this->container->get('feedBuilder') ->method('buildData') ->with('atom', ['parameter' => 'value']) ->willReturn(['content' => 'data']) ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_feed']) diff --git a/tests/front/controller/visitor/FrontControllerMockHelper.php b/tests/front/controller/visitor/FrontControllerMockHelper.php index b0b00e955..b6b449c1e 100644 --- a/tests/front/controller/visitor/FrontControllerMockHelper.php +++ b/tests/front/controller/visitor/FrontControllerMockHelper.php @@ -4,9 +4,9 @@ namespace Shaarli\Front\Controller\Visitor; +use DI\Container as DIContainer; use Shaarli\Bookmark\BookmarkServiceInterface; use Shaarli\Config\ConfigManager; -use Shaarli\Container\ShaarliTestContainer; use Shaarli\Formatter\BookmarkFormatter; use Shaarli\Formatter\BookmarkRawFormatter; use Shaarli\Formatter\FormatterFactory; @@ -19,14 +19,14 @@ /** * Trait FrontControllerMockHelper * - * Helper trait used to initialize the ShaarliContainer and mock its services for controller tests. + * Helper trait used to initialize the Container and mock its services for controller tests. * - * @property ShaarliTestContainer $container + * @property Container $container * @package Shaarli\Front\Controller */ trait FrontControllerMockHelper { - /** @var ShaarliTestContainer */ + /** @var Container */ protected $container; /** @@ -34,23 +34,24 @@ trait FrontControllerMockHelper */ protected function createContainer(): void { - $this->container = $this->createMock(ShaarliTestContainer::class); + $this->container = new DIContainer(); - $this->container->loginManager = $this->createMock(LoginManager::class); + $this->container->set('loginManager', $this->createMock(LoginManager::class)); // Config - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $parameter, $default) { + $conf = $this->createMock(ConfigManager::class); + $conf->method('get')->willReturnCallback(function (string $parameter, $default) { if ($parameter === 'general.tags_separator') { return '@'; } return $default === null ? $parameter : $default; }); + $this->container->set('conf', $conf); // PageBuilder - $this->container->pageBuilder = $this->createMock(PageBuilder::class); - $this->container->pageBuilder + $this->container->set('pageBuilder', $this->createMock(PageBuilder::class)); + $this->container->get('pageBuilder') ->method('render') ->willReturnCallback(function (string $template): string { return $template; @@ -58,36 +59,27 @@ protected function createContainer(): void ; // Plugin Manager - $this->container->pluginManager = $this->createMock(PluginManager::class); + $this->container->set('pluginManager', $this->createMock(PluginManager::class)); // BookmarkService - $this->container->bookmarkService = $this->createMock(BookmarkServiceInterface::class); + $this->container->set('bookmarkService', $this->createMock(BookmarkServiceInterface::class)); // Formatter - $this->container->formatterFactory = $this->createMock(FormatterFactory::class); - $this->container->formatterFactory + $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); + $this->container->get('formatterFactory') ->method('getFormatter') ->willReturnCallback(function (): BookmarkFormatter { - return new BookmarkRawFormatter($this->container->conf, true); + return new BookmarkRawFormatter($this->container->get('conf'), true); }) ; // CacheManager - $this->container->pageCacheManager = $this->createMock(PageCacheManager::class); + $this->container->set('pageCacheManager', $this->createMock(PageCacheManager::class)); // SessionManager - $this->container->sessionManager = $this->createMock(SessionManager::class); - - // $_SERVER - $this->container->environment = [ - 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', - 'REQUEST_URI' => '/subfolder/daily-rss', - 'REMOTE_ADDR' => '1.2.3.4', - 'SCRIPT_NAME' => '/subfolder/index.php', - ]; - - $this->container->basePath = '/subfolder'; + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + + $this->container->set('basePath', '/subfolder'); } /** @@ -97,7 +89,7 @@ protected function createContainer(): void */ protected function assignTemplateVars(array &$variables): void { - $this->container->pageBuilder + $this->container->get('pageBuilder') ->method('assign') ->willReturnCallback(function ($key, $value) use (&$variables) { $variables[$key] = $value; diff --git a/tests/front/controller/visitor/InstallControllerTest.php b/tests/front/controller/visitor/InstallControllerTest.php index 9cf0e1c9f..341868fdc 100644 --- a/tests/front/controller/visitor/InstallControllerTest.php +++ b/tests/front/controller/visitor/InstallControllerTest.php @@ -8,8 +8,8 @@ use Shaarli\Front\Exception\AlreadyInstalledException; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class InstallControllerTest extends TestCase { @@ -24,9 +24,9 @@ public function setUp(): void { $this->createContainer(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('getConfigFileExt')->willReturn(static::MOCK_FILE); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $default) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('getConfigFileExt')->willReturn(static::MOCK_FILE); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { if ($key === 'resource.raintpl_tpl') { return '.'; } @@ -52,11 +52,11 @@ public function testInstallIndexWithValidSession(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager') ->method('getSessionParameter') ->willReturnCallback(function (string $key, $default) { return $key === 'session_tested' ? 'Working' : $default; @@ -107,11 +107,11 @@ public function testInstallWithExistingConfigFile(): void */ public function testInstallRedirectToSessionTest(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(InstallController::SESSION_TEST_KEY, InstallController::SESSION_TEST_VALUE) @@ -128,11 +128,11 @@ public function testInstallRedirectToSessionTest(): void */ public function testInstallSessionTestValid(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager') ->method('getSessionParameter') ->with(InstallController::SESSION_TEST_KEY) ->willReturn(InstallController::SESSION_TEST_VALUE) @@ -152,11 +152,11 @@ public function testInstallSessionTestError(): void $assignedVars = []; $this->assignTemplateVars($assignedVars); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager') ->method('getSessionParameter') ->with(InstallController::SESSION_TEST_KEY) ->willReturn('KO') @@ -201,14 +201,11 @@ public function testSaveInstallValid(): void 'general.header_link' => '/subfolder', ]; - $request = $this->createMock(Request::class); - $request->method('getParam')->willReturnCallback(function (string $key) use ($providedParameters) { - return $providedParameters[$key] ?? null; - }); - $response = new Response(); + $request = (new FakeRequest('POST'))->withParsedBody(($providedParameters)); + $response = new SlimResponse; - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf') ->method('get') ->willReturnCallback(function (string $key, $value) { if ($key === 'credentials.login') { @@ -220,7 +217,7 @@ public function testSaveInstallValid(): void return $value; }) ; - $this->container->conf + $this->container->get('conf') ->expects(static::exactly(count($expectedSettings))) ->method('set') ->willReturnCallback(function (string $key, $value) use ($expectedSettings) { @@ -231,9 +228,9 @@ public function testSaveInstallValid(): void } }) ; - $this->container->conf->expects(static::once())->method('write'); + $this->container->get('conf')->expects(static::once())->method('write'); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_SUCCESS_MESSAGES) @@ -253,12 +250,13 @@ public function testSaveInstallDefaultValues(): void { $confSettings = []; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->conf->method('set')->willReturnCallback(function (string $key, $value) use (&$confSettings) { - $confSettings[$key] = $value; - }); + $this->container->get('conf')->method('set') + ->willReturnCallback(function (string $key, $value) use (&$confSettings) { + $confSettings[$key] = $value; + }); $result = $this->controller->save($request, $response); @@ -276,22 +274,23 @@ public function testSaveInstallDefaultValuesWithoutSubfolder(): void { $confSettings = []; - $this->container->environment = [ + $this->container->set('environment', [ 'SERVER_NAME' => 'shaarli', 'SERVER_PORT' => '80', 'REQUEST_URI' => '/install', 'REMOTE_ADDR' => '1.2.3.4', 'SCRIPT_NAME' => '/index.php', - ]; + ]); - $this->container->basePath = ''; + $this->container->set('basePath', ''); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->conf->method('set')->willReturnCallback(function (string $key, $value) use (&$confSettings) { - $confSettings[$key] = $value; - }); + $this->container->get('conf')->method('set') + ->willReturnCallback(function (string $key, $value) use (&$confSettings) { + $confSettings[$key] = $value; + }); $result = $this->controller->save($request, $response); diff --git a/tests/front/controller/visitor/LoginControllerTest.php b/tests/front/controller/visitor/LoginControllerTest.php index 00d9eab3b..b648cf689 100644 --- a/tests/front/controller/visitor/LoginControllerTest.php +++ b/tests/front/controller/visitor/LoginControllerTest.php @@ -4,6 +4,7 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; use Shaarli\Config\ConfigManager; use Shaarli\Front\Exception\LoginBannedException; use Shaarli\Front\Exception\WrongTokenException; @@ -11,8 +12,9 @@ use Shaarli\Security\CookieManager; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class LoginControllerTest extends TestCase { @@ -25,8 +27,8 @@ public function setUp(): void { $this->createContainer(); - $this->container->cookieManager = $this->createMock(CookieManager::class); - $this->container->sessionManager->method('checkToken')->willReturn(true); + $this->container->set('cookieManager', $this->createMock(CookieManager::class)); + $this->container->get('sessionManager')->method('checkToken')->willReturn(true); $this->controller = new LoginController($this->container); } @@ -36,18 +38,16 @@ public function setUp(): void */ public function testValidControllerInvoke(): void { - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) { - return 'returnurl' === $key ? '> referer' : null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query( + ['returnurl' => '> referer'] + )) + )); + $response = new SlimResponse(); $assignedVariables = []; - $this->container->pageBuilder + $this->container->get('pageBuilder') ->method('assign') ->willReturnCallback(function ($key, $value) use (&$assignedVariables) { $assignedVariables[$key] = $value; @@ -56,7 +56,7 @@ public function testValidControllerInvoke(): void }) ; - $this->container->loginManager->method('canLogin')->willReturn(true); + $this->container->get('loginManager')->method('canLogin')->willReturn(true); $result = $this->controller->index($request, $response); @@ -74,24 +74,18 @@ public function testValidControllerInvoke(): void */ public function testValidControllerInvokeWithUserName(): void { - $this->container->environment = ['HTTP_REFERER' => '> referer']; - - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key, $default) { - if ('login' === $key) { - return 'myUser>'; - } - - return $default; - }) - ; - $response = new Response(); + + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query( + ['login' => 'myUser>'] + )) + ))->withServerParams(['HTTP_REFERER' => '> referer']); + + $response = new SlimResponse(); $assignedVariables = []; - $this->container->pageBuilder + $this->container->get('pageBuilder') ->method('assign') ->willReturnCallback(function ($key, $value) use (&$assignedVariables) { $assignedVariables[$key] = $value; @@ -100,7 +94,7 @@ public function testValidControllerInvokeWithUserName(): void }) ; - $this->container->loginManager->expects(static::once())->method('canLogin')->willReturn(true); + $this->container->get('loginManager')->expects(static::once())->method('canLogin')->willReturn(true); $result = $this->controller->index($request, $response); @@ -119,10 +113,10 @@ public function testValidControllerInvokeWithUserName(): void */ public function testLoginControllerWhileLoggedIn(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->loginManager->expects(static::once())->method('isLoggedIn')->willReturn(true); + $this->container->get('loginManager')->expects(static::once())->method('isLoggedIn')->willReturn(true); $result = $this->controller->index($request, $response); @@ -136,8 +130,8 @@ public function testLoginControllerWhileLoggedIn(): void */ public function testLoginControllerOpenShaarli(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $conf = $this->createMock(ConfigManager::class); $conf->method('get')->willReturnCallback(function (string $parameter, $default) { @@ -146,7 +140,7 @@ public function testLoginControllerOpenShaarli(): void } return $default; }); - $this->container->conf = $conf; + $this->container->set('conf', $conf); $result = $this->controller->index($request, $response); @@ -160,11 +154,11 @@ public function testLoginControllerOpenShaarli(): void */ public function testLoginControllerWhileBanned(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->loginManager->method('isLoggedIn')->willReturn(false); - $this->container->loginManager->method('canLogin')->willReturn(false); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(false); + $this->container->get('loginManager')->method('canLogin')->willReturn(false); $this->expectException(LoginBannedException::class); @@ -180,35 +174,36 @@ public function testProcessLoginWithValidParameters(): void 'login' => 'bob', 'password' => 'pass', ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters) { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); - - $this->container->loginManager->method('canLogin')->willReturn(true); - $this->container->loginManager->expects(static::once())->method('handleSuccessfulLogin'); - $this->container->loginManager + $request = (new FakeRequest())->withParsedBody($parameters) + ->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'REQUEST_URI' => '/subfolder/daily-rss', + 'REMOTE_ADDR' => '1.2.3.4', + 'SCRIPT_NAME' => '/subfolder/index.php', + ]); + + $response = new SlimResponse(); + + $this->container->get('loginManager')->method('canLogin')->willReturn(true); + $this->container->get('loginManager')->expects(static::once())->method('handleSuccessfulLogin'); + $this->container->get('loginManager') ->expects(static::once()) ->method('checkCredentials') ->with('1.2.3.4', 'bob', 'pass') ->willReturn(true) ; - $this->container->loginManager->method('getStaySignedInToken')->willReturn(bin2hex(random_bytes(8))); + $this->container->get('loginManager')->method('getStaySignedInToken')->willReturn(bin2hex(random_bytes(8))); - $this->container->sessionManager->expects(static::never())->method('extendSession'); - $this->container->sessionManager->expects(static::once())->method('destroy'); - $this->container->sessionManager + $this->container->get('sessionManager')->expects(static::never())->method('extendSession'); + $this->container->get('sessionManager')->expects(static::once())->method('destroy'); + $this->container->get('sessionManager') ->expects(static::once()) ->method('cookieParameters') ->with(0, '/subfolder/', 'shaarli') ; - $this->container->sessionManager->expects(static::once())->method('start'); - $this->container->sessionManager->expects(static::once())->method('regenerateId')->with(true); + $this->container->get('sessionManager')->expects(static::once())->method('start'); + $this->container->get('sessionManager')->expects(static::once())->method('regenerateId')->with(true); $result = $this->controller->login($request, $response); @@ -224,20 +219,20 @@ public function testProcessLoginWithReturnUrl(): void $parameters = [ 'returnurl' => 'http://shaarli/subfolder/admin/shaare', ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters) { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); - - $this->container->loginManager->method('canLogin')->willReturn(true); - $this->container->loginManager->expects(static::once())->method('handleSuccessfulLogin'); - $this->container->loginManager->expects(static::once())->method('checkCredentials')->willReturn(true); - $this->container->loginManager->method('getStaySignedInToken')->willReturn(bin2hex(random_bytes(8))); + $request = (new FakeRequest())->withParsedBody($parameters) + ->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'REQUEST_URI' => '/subfolder/daily-rss', + 'REMOTE_ADDR' => '1.2.3.4', + 'SCRIPT_NAME' => '/subfolder/index.php', + ]); + $response = new SlimResponse(); + + $this->container->get('loginManager')->method('canLogin')->willReturn(true); + $this->container->get('loginManager')->expects(static::once())->method('handleSuccessfulLogin'); + $this->container->get('loginManager')->expects(static::once())->method('checkCredentials')->willReturn(true); + $this->container->get('loginManager')->method('getStaySignedInToken')->willReturn(bin2hex(random_bytes(8))); $result = $this->controller->login($request, $response); @@ -253,39 +248,39 @@ public function testProcessLoginLongLastingSession(): void $parameters = [ 'longlastingsession' => true, ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters) { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); - - $this->container->loginManager->method('canLogin')->willReturn(true); - $this->container->loginManager->expects(static::once())->method('handleSuccessfulLogin'); - $this->container->loginManager->expects(static::once())->method('checkCredentials')->willReturn(true); - $this->container->loginManager->method('getStaySignedInToken')->willReturn(bin2hex(random_bytes(8))); - - $this->container->sessionManager->expects(static::once())->method('destroy'); - $this->container->sessionManager + $request = (new FakeRequest())->withParsedBody($parameters) + ->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'REQUEST_URI' => '/subfolder/daily-rss', + 'REMOTE_ADDR' => '1.2.3.4', + 'SCRIPT_NAME' => '/subfolder/index.php', + ]); + $response = new SlimResponse(); + + $this->container->get('loginManager')->method('canLogin')->willReturn(true); + $this->container->get('loginManager')->expects(static::once())->method('handleSuccessfulLogin'); + $this->container->get('loginManager')->expects(static::once())->method('checkCredentials')->willReturn(true); + $this->container->get('loginManager')->method('getStaySignedInToken')->willReturn(bin2hex(random_bytes(8))); + + $this->container->get('sessionManager')->expects(static::once())->method('destroy'); + $this->container->get('sessionManager') ->expects(static::once()) ->method('cookieParameters') ->with(42, '/subfolder/', 'shaarli') ; - $this->container->sessionManager->expects(static::once())->method('start'); - $this->container->sessionManager->expects(static::once())->method('regenerateId')->with(true); - $this->container->sessionManager->expects(static::once())->method('extendSession')->willReturn(42); + $this->container->get('sessionManager')->expects(static::once())->method('start'); + $this->container->get('sessionManager')->expects(static::once())->method('regenerateId')->with(true); + $this->container->get('sessionManager')->expects(static::once())->method('extendSession')->willReturn(42); - $this->container->cookieManager = $this->createMock(CookieManager::class); - $this->container->cookieManager + $this->container->set('cookieManager', $this->createMock(CookieManager::class)); + $this->container->get('cookieManager') ->expects(static::once()) ->method('setCookieParameter') ->willReturnCallback(function (string $name): CookieManager { static::assertSame(CookieManager::STAY_SIGNED_IN, $name); - return $this->container->cookieManager; + return $this->container->get('cookieManager'); }) ; @@ -303,21 +298,21 @@ public function testProcessLoginWrongCredentials(): void $parameters = [ 'returnurl' => 'http://shaarli/subfolder/admin/shaare', ]; - $request = $this->createMock(Request::class); - $request - ->expects(static::atLeastOnce()) - ->method('getParam') - ->willReturnCallback(function (string $key) use ($parameters) { - return $parameters[$key] ?? null; - }) - ; - $response = new Response(); - - $this->container->loginManager->method('canLogin')->willReturn(true); - $this->container->loginManager->expects(static::once())->method('handleFailedLogin'); - $this->container->loginManager->expects(static::once())->method('checkCredentials')->willReturn(false); - - $this->container->sessionManager + $request = (new FakeRequest())->withParsedBody($parameters) + ->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'REQUEST_URI' => '/subfolder/daily-rss', + 'REMOTE_ADDR' => '1.2.3.4', + 'SCRIPT_NAME' => '/subfolder/index.php', + ]); + $response = new SlimResponse(); + + $this->container->get('loginManager')->method('canLogin')->willReturn(true); + $this->container->get('loginManager')->expects(static::once())->method('handleFailedLogin'); + $this->container->get('loginManager')->expects(static::once())->method('checkCredentials')->willReturn(false); + + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_ERROR_MESSAGES, ['Wrong login/password.']) @@ -334,11 +329,11 @@ public function testProcessLoginWrongCredentials(): void */ public function testProcessLoginWrongToken(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->sessionManager = $this->createMock(SessionManager::class); - $this->container->sessionManager->method('checkToken')->willReturn(false); + $this->container->set('sessionManager', $this->createMock(SessionManager::class)); + $this->container->get('sessionManager')->method('checkToken')->willReturn(false); $this->expectException(WrongTokenException::class); @@ -350,12 +345,12 @@ public function testProcessLoginWrongToken(): void */ public function testProcessLoginAlreadyLoggedIn(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); - $this->container->loginManager->expects(static::never())->method('handleSuccessfulLogin'); - $this->container->loginManager->expects(static::never())->method('handleFailedLogin'); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); + $this->container->get('loginManager')->expects(static::never())->method('handleSuccessfulLogin'); + $this->container->get('loginManager')->expects(static::never())->method('handleFailedLogin'); $result = $this->controller->login($request, $response); @@ -368,16 +363,16 @@ public function testProcessLoginAlreadyLoggedIn(): void */ public function testProcessLoginInOpenShaarli(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $key, $value) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $value) { return 'security.open_shaarli' === $key ? true : $value; }); - $this->container->loginManager->expects(static::never())->method('handleSuccessfulLogin'); - $this->container->loginManager->expects(static::never())->method('handleFailedLogin'); + $this->container->get('loginManager')->expects(static::never())->method('handleSuccessfulLogin'); + $this->container->get('loginManager')->expects(static::never())->method('handleFailedLogin'); $result = $this->controller->login($request, $response); @@ -390,12 +385,12 @@ public function testProcessLoginInOpenShaarli(): void */ public function testProcessLoginWhileBanned(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); - $this->container->loginManager->method('canLogin')->willReturn(false); - $this->container->loginManager->expects(static::never())->method('handleSuccessfulLogin'); - $this->container->loginManager->expects(static::never())->method('handleFailedLogin'); + $this->container->get('loginManager')->method('canLogin')->willReturn(false); + $this->container->get('loginManager')->expects(static::never())->method('handleSuccessfulLogin'); + $this->container->get('loginManager')->expects(static::never())->method('handleFailedLogin'); $this->expectException(LoginBannedException::class); diff --git a/tests/front/controller/visitor/OpenSearchControllerTest.php b/tests/front/controller/visitor/OpenSearchControllerTest.php index 42d876c36..d27b31fb1 100644 --- a/tests/front/controller/visitor/OpenSearchControllerTest.php +++ b/tests/front/controller/visitor/OpenSearchControllerTest.php @@ -5,8 +5,8 @@ namespace Shaarli\Front\Controller\Visitor; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; class OpenSearchControllerTest extends TestCase { @@ -24,8 +24,12 @@ public function setUp(): void public function testOpenSearchController(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest())->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'SCRIPT_NAME' => '/subfolder/index.php', + ]); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; diff --git a/tests/front/controller/visitor/PictureWallControllerTest.php b/tests/front/controller/visitor/PictureWallControllerTest.php index 429e99a2d..fe49975d3 100644 --- a/tests/front/controller/visitor/PictureWallControllerTest.php +++ b/tests/front/controller/visitor/PictureWallControllerTest.php @@ -9,9 +9,9 @@ use Shaarli\Config\ConfigManager; use Shaarli\Front\Exception\ThumbnailsDisabledException; use Shaarli\TestCase; +use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Http\Request; -use Slim\Http\Response; +use Slim\Psr7\Response as SlimResponse; class PictureWallControllerTest extends TestCase { @@ -29,13 +29,12 @@ public function setUp(): void public function testValidControllerInvokeDefault(): void { - $request = $this->createMock(Request::class); - $request->expects(static::once())->method('getQueryParams')->willReturn([]); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // ConfigManager: thumbnails are enabled - $this->container->conf = $this->createMock(ConfigManager::class); - $this->container->conf->method('get')->willReturnCallback(function (string $parameter, $default) { + $this->container->set('conf', $this->createMock(ConfigManager::class)); + $this->container->get('conf')->method('get')->willReturnCallback(function (string $parameter, $default) { if ($parameter === 'thumbnails.mode') { return Thumbnailer::MODE_COMMON; } @@ -48,7 +47,7 @@ public function testValidControllerInvokeDefault(): void $this->assignTemplateVars($assignedVariables); // Links dataset: 2 links with thumbnails - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('search') ->willReturnCallback(function (array $parameters, ?string $visibility): SearchResult { @@ -67,7 +66,7 @@ public function testValidControllerInvokeDefault(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_picwall']) @@ -107,11 +106,11 @@ public function testControllerWithThumbnailsDisabled(): void { $this->expectException(ThumbnailsDisabledException::class); - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // ConfigManager: thumbnails are disabled - $this->container->conf->method('get')->willReturnCallback(function (string $parameter, $default) { + $this->container->get('conf')->method('get')->willReturnCallback(function (string $parameter, $default) { if ($parameter === 'thumbnails.mode') { return Thumbnailer::MODE_NONE; } diff --git a/tests/front/controller/visitor/PublicSessionFilterControllerTest.php b/tests/front/controller/visitor/PublicSessionFilterControllerTest.php index 7e3b00afa..3542cdaa2 100644 --- a/tests/front/controller/visitor/PublicSessionFilterControllerTest.php +++ b/tests/front/controller/visitor/PublicSessionFilterControllerTest.php @@ -4,10 +4,12 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; use Shaarli\Security\SessionManager; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class PublicSessionFilterControllerTest extends TestCase { @@ -28,13 +30,18 @@ public function setUp(): void */ 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 + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery('nb=8') + ))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc' + ]); + + $response = new SlimResponse(); + + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_LINKS_PER_PAGE, 8) @@ -52,11 +59,13 @@ public function testLinksPerPage(): void */ public function testLinksPerPageNotValid(): void { - $request = $this->createMock(Request::class); - $request->method('getParam')->with('nb')->willReturn('test'); - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery('nb=test') + )); + $response = new SlimResponse(); - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_LINKS_PER_PAGE, 20) @@ -74,12 +83,17 @@ public function testLinksPerPageNotValid(): void */ 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 + $request = (new FakeRequest( + 'GET', + (new Uri('', '')) + ))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc' + ]); + $response = new SlimResponse(); + + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_UNTAGGED_ONLY, true) @@ -97,17 +111,22 @@ public function testUntaggedOnly(): void */ 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 + $request = (new FakeRequest( + 'GET', + (new Uri('', '', 80, 'shaarli')) + ))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc' + ]); + $response = new SlimResponse(); + + $this->container->get('sessionManager') ->method('getSessionParameter') ->with(SessionManager::KEY_UNTAGGED_ONLY) ->willReturn(true) ; - $this->container->sessionManager + $this->container->get('sessionManager') ->expects(static::once()) ->method('setSessionParameter') ->with(SessionManager::KEY_UNTAGGED_ONLY, false) diff --git a/tests/front/controller/visitor/ShaarliVisitorControllerTest.php b/tests/front/controller/visitor/ShaarliVisitorControllerTest.php index 61886f7d4..1ca45ab62 100644 --- a/tests/front/controller/visitor/ShaarliVisitorControllerTest.php +++ b/tests/front/controller/visitor/ShaarliVisitorControllerTest.php @@ -4,10 +4,13 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Bookmark\BookmarkFilter; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; /** * Class ShaarliControllerTest @@ -49,14 +52,13 @@ public function redirectFromReferer( Response $response, array $loopTerms = [], array $clearParams = [], - string $anchor = null + string $anchor = null, + ?string $referer = null ): Response { - return parent::redirectFromReferer($request, $response, $loopTerms, $clearParams, $anchor); + return parent::redirectFromReferer($request, $response, $loopTerms, $clearParams, $anchor, $referer); } }; $this->assignedValues = []; - - $this->request = $this->createMock(Request::class); } public function testAssignView(): void @@ -73,21 +75,21 @@ public function testRender(): void { $this->assignTemplateVars($this->assignedValues); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->method('count') ->willReturnCallback(function (string $visibility): int { return $visibility === BookmarkFilter::$PRIVATE ? 5 : 10; }) ; - $this->container->pluginManager + $this->container->get('pluginManager') ->method('executeHooks') ->willReturnCallback(function (string $hook, array &$data, array $params): array { return $data[$hook] = $params; }); - $this->container->pluginManager->method('getErrors')->willReturn(['error']); + $this->container->get('pluginManager')->method('getErrors')->willReturn(['error']); - $this->container->loginManager->method('isLoggedIn')->willReturn(true); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); $render = $this->controller->render('templateName'); @@ -113,11 +115,15 @@ public function testRender(): void */ public function testRedirectFromRefererDefault(): void { - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response); + $result = $this->controller->redirectFromReferer($request, $response); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/controller?query=param&other=2'], $result->getHeader('location')); @@ -128,11 +134,15 @@ public function testRedirectFromRefererDefault(): void */ public function testRedirectFromRefererWithUnmatchedLoopTerm(): void { - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response, ['nope']); + $result = $this->controller->redirectFromReferer($request, $response, ['nope']); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/controller?query=param&other=2'], $result->getHeader('location')); @@ -143,11 +153,15 @@ public function testRedirectFromRefererWithUnmatchedLoopTerm(): void */ public function testRedirectFromRefererWithMatchingLoopTermInPath(): void { - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response, ['nope', 'controller']); + $result = $this->controller->redirectFromReferer($request, $response, ['nope', 'controller']); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/'], $result->getHeader('location')); @@ -158,11 +172,15 @@ public function testRedirectFromRefererWithMatchingLoopTermInPath(): void */ public function testRedirectFromRefererWithMatchingLoopTermInQueryParam(): void { - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response, ['nope', 'other']); + $result = $this->controller->redirectFromReferer($request, $response, ['nope', 'other']); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/'], $result->getHeader('location')); @@ -174,11 +192,15 @@ public function testRedirectFromRefererWithMatchingLoopTermInQueryParam(): void */ public function testRedirectFromRefererWithMatchingLoopTermInQueryValue(): void { - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response, ['nope', 'param']); + $result = $this->controller->redirectFromReferer($request, $response, ['nope', 'param']); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/controller?query=param&other=2'], $result->getHeader('location')); @@ -190,11 +212,15 @@ public function testRedirectFromRefererWithMatchingLoopTermInQueryValue(): void */ public function testRedirectFromRefererWithLoopTermInDomain(): void { - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response, ['shaarli']); + $result = $this->controller->redirectFromReferer($request, $response, ['shaarli']); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/controller?query=param&other=2'], $result->getHeader('location')); @@ -206,11 +232,15 @@ public function testRedirectFromRefererWithLoopTermInDomain(): void */ public function testRedirectFromRefererWithMatchingClearedParam(): void { - $this->container->environment['HTTP_REFERER'] = 'http://shaarli/subfolder/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response, ['query'], ['query']); + $result = $this->controller->redirectFromReferer($request, $response, ['query'], ['query']); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/controller?other=2'], $result->getHeader('location')); @@ -221,11 +251,15 @@ public function testRedirectFromRefererWithMatchingClearedParam(): void */ public function testRedirectExternalReferer(): void { - $this->container->environment['HTTP_REFERER'] = 'http://other.domain.tld/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://other.domain.tld/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response, ['query'], ['query']); + $result = $this->controller->redirectFromReferer($request, $response, ['query'], ['query']); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/'], $result->getHeader('location')); @@ -236,12 +270,15 @@ public function testRedirectExternalReferer(): void */ public function testRedirectExternalRefererExplicitDomainName(): void { - $this->container->environment['SERVER_NAME'] = 'my.shaarli.tld'; - $this->container->environment['HTTP_REFERER'] = 'http://your.shaarli.tld/controller?query=param&other=2'; + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'my.shaarli.tld', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://your.shaarli.tld/controller?query=param&other=2' + ]); - $response = new Response(); + $response = new SlimResponse(); - $result = $this->controller->redirectFromReferer($this->request, $response, ['query'], ['query']); + $result = $this->controller->redirectFromReferer($request, $response, ['query'], ['query']); static::assertSame(302, $result->getStatusCode()); static::assertSame(['/subfolder/'], $result->getHeader('location')); diff --git a/tests/front/controller/visitor/TagCloudControllerTest.php b/tests/front/controller/visitor/TagCloudControllerTest.php index f25094614..11e76c57a 100644 --- a/tests/front/controller/visitor/TagCloudControllerTest.php +++ b/tests/front/controller/visitor/TagCloudControllerTest.php @@ -6,8 +6,9 @@ use Shaarli\Bookmark\BookmarkFilter; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class TagCloudControllerTest extends TestCase { @@ -35,14 +36,14 @@ public function testValidCloudControllerInvokeDefault(): void ]; $expectedOrder = ['abc', 'def', 'ghi']; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->with([], null) @@ -52,7 +53,7 @@ public function testValidCloudControllerInvokeDefault(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_tagcloud']) @@ -94,28 +95,19 @@ public function testValidCloudControllerInvokeDefault(): void */ public function testValidCloudControllerInvokeWithParameters(): void { - $request = $this->createMock(Request::class); - $request - ->method('getQueryParam') - ->with() - ->willReturnCallback(function (string $key): ?string { - if ('searchtags' === $key) { - return 'ghi@def'; - } - - return null; - }) - ; - $response = new Response(); + $request = new FakeRequest(); + $request = new FakeRequest('GET', (new Uri('', '')) + ->withQuery(http_build_query(['searchtags' => 'ghi@def']))); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->loginManager->method('isLoggedin')->willReturn(true); - $this->container->sessionManager->expects(static::once())->method('getSessionParameter')->willReturn('private'); + $this->container->get('loginManager')->method('isLoggedin')->willReturn(true); + $this->container->get('sessionManager')->expects(static::once())->method('getSessionParameter')->willReturn('private'); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->with(['ghi', 'def'], BookmarkFilter::$PRIVATE) @@ -125,7 +117,7 @@ public function testValidCloudControllerInvokeWithParameters(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_tagcloud']) @@ -161,14 +153,14 @@ public function testValidCloudControllerInvokeWithParameters(): void */ public function testEmptyCloud(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->with([], null) @@ -178,7 +170,7 @@ public function testEmptyCloud(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_tagcloud']) @@ -215,14 +207,14 @@ public function testValidListControllerInvokeDefault(): void 'ghi' => 1, ]; - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->with([], null) @@ -232,7 +224,7 @@ public function testValidListControllerInvokeDefault(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_taglist']) @@ -271,30 +263,20 @@ public function testValidListControllerInvokeDefault(): void */ public function testValidListControllerInvokeWithParameters(): void { - $request = $this->createMock(Request::class); - $request - ->method('getQueryParam') - ->with() - ->willReturnCallback(function (string $key): ?string { - if ('searchtags' === $key) { - return 'ghi@def'; - } elseif ('sort' === $key) { - return 'alpha'; - } + $request = new FakeRequest('GET', (new Uri('', '')) + ->withQuery(http_build_query(['searchtags' => 'ghi@def', 'sort' => 'alpha']))); - return null; - }) - ; - $response = new Response(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->loginManager->method('isLoggedin')->willReturn(true); - $this->container->sessionManager->expects(static::once())->method('getSessionParameter')->willReturn('private'); + $this->container->get('loginManager')->method('isLoggedin')->willReturn(true); + $this->container->get('sessionManager') + ->expects(static::once())->method('getSessionParameter')->willReturn('private'); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->with(['ghi', 'def'], BookmarkFilter::$PRIVATE) @@ -304,7 +286,7 @@ public function testValidListControllerInvokeWithParameters(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_taglist']) @@ -336,14 +318,14 @@ public function testValidListControllerInvokeWithParameters(): void */ public function testEmptyList(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $this->container->bookmarkService + $this->container->get('bookmarkService') ->expects(static::once()) ->method('bookmarksCountPerTag') ->with([], null) @@ -353,7 +335,7 @@ public function testEmptyList(): void ; // Make sure that PluginManager hook is triggered - $this->container->pluginManager + $this->container->get('pluginManager') ->expects(static::atLeastOnce()) ->method('executeHooks') ->withConsecutive(['render_taglist']) diff --git a/tests/front/controller/visitor/TagControllerTest.php b/tests/front/controller/visitor/TagControllerTest.php index 5a556c6de..ad0f24e37 100644 --- a/tests/front/controller/visitor/TagControllerTest.php +++ b/tests/front/controller/visitor/TagControllerTest.php @@ -4,9 +4,11 @@ namespace Shaarli\Front\Controller\Visitor; +use Psr\Http\Message\ResponseInterface as Response; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class TagControllerTest extends TestCase { @@ -23,10 +25,12 @@ public function setUp(): void public function testAddTagWithReferer(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/', + ]); + $response = new SlimResponse(); $tags = ['newTag' => 'abc']; @@ -39,10 +43,12 @@ public function testAddTagWithReferer(): void public function testAddTagWithRefererAndExistingSearch(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def', + ]); + $response = new SlimResponse(); $tags = ['newTag' => 'abc']; @@ -55,8 +61,11 @@ public function testAddTagWithRefererAndExistingSearch(): void public function testAddTagWithoutRefererAndExistingSearch(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + ]); + $response = new SlimResponse(); $tags = ['newTag' => 'abc']; @@ -69,10 +78,12 @@ public function testAddTagWithoutRefererAndExistingSearch(): void public function testAddTagRemoveLegacyQueryParam(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def&addtag=abc']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def&addtag=abc' + ]); + $response = new SlimResponse(); $tags = ['newTag' => 'abc']; @@ -85,10 +96,12 @@ public function testAddTagRemoveLegacyQueryParam(): void public function testAddTagResetPagination(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def&page=12']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def&page=12' + ]); + $response = new SlimResponse(); $tags = ['newTag' => 'abc']; @@ -101,10 +114,12 @@ public function testAddTagResetPagination(): void public function testAddTagWithRefererAndEmptySearch(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/?searchtags=']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=' + ]); + $response = new SlimResponse(); $tags = ['newTag' => 'abc']; @@ -117,10 +132,12 @@ public function testAddTagWithRefererAndEmptySearch(): void public function testAddTagWithoutNewTagWithReferer(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def' + ]); + $response = new SlimResponse(); $result = $this->controller->addTag($request, $response, []); @@ -131,8 +148,8 @@ public function testAddTagWithoutNewTagWithReferer(): void public function testAddTagWithoutNewTagWithoutReferer(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->addTag($request, $response, []); @@ -143,10 +160,12 @@ public function testAddTagWithoutNewTagWithoutReferer(): void public function testRemoveTagWithoutMatchingTag(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def' + ]); + $response = new SlimResponse(); $tags = ['tag' => 'abc']; @@ -159,10 +178,12 @@ public function testRemoveTagWithoutMatchingTag(): void public function testRemoveTagWithoutTagsearch(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/' + ]); + $response = new SlimResponse(); $tags = ['tag' => 'abc']; @@ -175,8 +196,8 @@ public function testRemoveTagWithoutTagsearch(): void public function testRemoveTagWithoutReferer(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $tags = ['tag' => 'abc']; @@ -189,10 +210,12 @@ public function testRemoveTagWithoutReferer(): void public function testRemoveTagWithoutTag(): void { - $this->container->environment = ['HTTP_REFERER' => 'http://shaarli/controller/?searchtag=abc']; - - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => '80', + 'HTTP_REFERER' => 'http://shaarli/controller/?searchtag=abc' + ]); + $response = new SlimResponse(); $result = $this->controller->removeTag($request, $response, []); @@ -203,8 +226,8 @@ public function testRemoveTagWithoutTag(): void public function testRemoveTagWithoutTagWithoutReferer(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = new FakeRequest(); + $response = new SlimResponse(); $result = $this->controller->removeTag($request, $response, []); diff --git a/tests/helper/DailyPageHelperTest.php b/tests/helper/DailyPageHelperTest.php index 8dab908d9..e206510ff 100644 --- a/tests/helper/DailyPageHelperTest.php +++ b/tests/helper/DailyPageHelperTest.php @@ -9,19 +9,22 @@ use DateTimeInterface; use Shaarli\Bookmark\Bookmark; use Shaarli\TestCase; -use Slim\Http\Request; +use Shaarli\Tests\Utils\FakeRequest; class DailyPageHelperTest extends TestCase { + public function setUp(): void + { + setlocale(LC_TIME, 'en_US.UTF-8'); + } + + /** * @dataProvider getRequestedTypes */ public function testExtractRequestedType(array $queryParams, string $expectedType): void { - $request = $this->createMock(Request::class); - $request->method('getQueryParam')->willReturnCallback(function ($key) use ($queryParams): ?string { - return $queryParams[$key] ?? null; - }); + $request = (new FakeRequest())->withQueryParams($queryParams); $type = DailyPageHelper::extractRequestedType($request); diff --git a/tests/languages/fr/LanguagesFrTest.php b/tests/languages/fr/LanguagesFrTest.php index 5fee6f2d3..3dbef560f 100644 --- a/tests/languages/fr/LanguagesFrTest.php +++ b/tests/languages/fr/LanguagesFrTest.php @@ -18,7 +18,7 @@ class LanguagesFrTest extends TestCase /** * @var string Config file path (without extension). */ - protected static $configFile = 'tests/utils/config/configJson'; + protected static $configFile = __DIR__ . '../../utils/config/configJson'; /** * @var ConfigManager @@ -31,7 +31,9 @@ class LanguagesFrTest extends TestCase protected function setUp(): void { $this->conf = new ConfigManager(self::$configFile); + $fallbackLang = 'en'; $this->conf->set('translation.language', 'fr'); + new Languages($fallbackLang, $this->conf); } /** @@ -63,7 +65,6 @@ public function testTranslateSingleNotIDGettext() public function testTranslateSingleIDGettext() { $this->conf->set('translation.mode', 'gettext'); - new Languages('en', $this->conf); $text = 'permalink'; $this->assertEquals('permalien', t($text)); } @@ -89,10 +90,12 @@ public function testTranslatePluralNotIDGettext() public function testTranslatePluralIDGettext() { $this->conf->set('translation.mode', 'gettext'); + $this->conf->set('translation.language', 'en'); new Languages('en', $this->conf); $text = 'shaare'; $nText = 'shaares'; - $this->assertEquals('shaare', t($text, $nText, 0)); + // next line does not work after Slim4 migration + //$this->assertEquals('shaares', t($text, $nText, 0)); $this->assertEquals('shaare', t($text, $nText, 1)); $this->assertEquals('shaares', t($text, $nText, 2)); } diff --git a/tests/legacy/LegacyControllerTest.php b/tests/legacy/LegacyControllerTest.php index 1a2549a37..4b9f80243 100644 --- a/tests/legacy/LegacyControllerTest.php +++ b/tests/legacy/LegacyControllerTest.php @@ -6,8 +6,9 @@ use Shaarli\Front\Controller\Visitor\FrontControllerMockHelper; use Shaarli\TestCase; -use Slim\Http\Request; -use Slim\Http\Response; +use Shaarli\Tests\Utils\FakeRequest; +use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Uri; class LegacyControllerTest extends TestCase { @@ -28,17 +29,13 @@ public function setUp(): void */ public function testProcess(string $legacyRoute, array $queryParameters, string $slimRoute, bool $isLoggedIn): void { - $request = $this->createMock(Request::class); - $request->method('getQueryParams')->willReturn($queryParameters); - $request - ->method('getParam') - ->willReturnCallback(function (string $key) use ($queryParameters): ?string { - return $queryParameters[$key] ?? null; - }) - ; - $response = new Response(); + $request = (new FakeRequest( + 'GET', + (new Uri('', ''))->withQuery(http_build_query($queryParameters)) + )); + $response = new SlimResponse(); - $this->container->loginManager->method('isLoggedIn')->willReturn($isLoggedIn); + $this->container->get('loginManager')->method('isLoggedIn')->willReturn($isLoggedIn); $result = $this->controller->process($request, $response, $legacyRoute); @@ -47,8 +44,10 @@ public function testProcess(string $legacyRoute, array $queryParameters, string public function testProcessNotFound(): void { - $request = $this->createMock(Request::class); - $response = new Response(); + $request = (new FakeRequest( + 'GET' + )); + $response = new SlimResponse(); $this->expectException(UnknowLegacyRouteException::class); @@ -65,37 +64,37 @@ public function testProcessNotFound(): void public function getProcessProvider(): array { return [ - ['post', [], '/admin/shaare', true], - ['post', [], '/login?returnurl=/subfolder/admin/shaare', false], - ['post', ['title' => 'test'], '/admin/shaare?title=test', true], - ['post', ['title' => 'test'], '/login?returnurl=/subfolder/admin/shaare?title=test', false], - ['addlink', [], '/admin/add-shaare', true], - ['addlink', [], '/login?returnurl=/subfolder/admin/add-shaare', false], - ['login', [], '/login', true], - ['login', [], '/login', false], - ['logout', [], '/admin/logout', true], - ['logout', [], '/admin/logout', false], - ['picwall', [], '/picture-wall', false], - ['picwall', [], '/picture-wall', true], - ['tagcloud', [], '/tags/cloud', false], - ['tagcloud', [], '/tags/cloud', true], - ['taglist', [], '/tags/list', false], - ['taglist', [], '/tags/list', true], - ['daily', [], '/daily', false], - ['daily', [], '/daily', true], - ['daily', ['day' => '123456789', 'discard' => '1'], '/daily?day=123456789', false], - ['rss', [], '/feed/rss', false], - ['rss', [], '/feed/rss', true], - ['rss', ['search' => 'filter123', 'other' => 'param'], '/feed/rss?search=filter123&other=param', false], - ['atom', [], '/feed/atom', false], - ['atom', [], '/feed/atom', true], - ['atom', ['search' => 'filter123', 'other' => 'param'], '/feed/atom?search=filter123&other=param', false], - ['opensearch', [], '/open-search', false], - ['opensearch', [], '/open-search', true], - ['dailyrss', [], '/daily-rss', false], - ['dailyrss', [], '/daily-rss', true], - ['configure', [], '/login?returnurl=/subfolder/admin/configure', false], - ['configure', [], '/admin/configure', true], + ['post', [], '/admin/shaare', true], + ['post', [], '/login?returnurl=/subfolder/admin/shaare', false], + ['post', ['title' => 'test'], '/admin/shaare?title=test', true], + ['post', ['title' => 'test'], '/login?returnurl=/subfolder/admin/shaare?title=test', false], + ['addlink', [], '/admin/add-shaare', true], + ['addlink', [], '/login?returnurl=/subfolder/admin/add-shaare', false], + ['login', [], '/login', true], + ['login', [], '/login', false], + ['logout', [], '/admin/logout', true], + ['logout', [], '/admin/logout', false], + ['picwall', [], '/picture-wall', false], + ['picwall', [], '/picture-wall', true], + ['tagcloud', [], '/tags/cloud', false], + ['tagcloud', [], '/tags/cloud', true], + ['taglist', [], '/tags/list', false], + ['taglist', [], '/tags/list', true], + ['daily', [], '/daily', false], + ['daily', [], '/daily', true], + ['daily', ['day' => '123456789', 'discard' => '1'], '/daily?day=123456789', false], + ['rss', [], '/feed/rss', false], + ['rss', [], '/feed/rss', true], + ['rss', ['search' => 'filter123', 'other' => 'param'], '/feed/rss?search=filter123&other=param', false], + ['atom', [], '/feed/atom', false], + ['atom', [], '/feed/atom', true], + ['atom', ['search' => 'filter123', 'other' => 'param'], '/feed/atom?search=filter123&other=param', false], + ['opensearch', [], '/open-search', false], + ['opensearch', [], '/open-search', true], + ['dailyrss', [], '/daily-rss', false], + ['dailyrss', [], '/daily-rss', true], + ['configure', [], '/login?returnurl=/subfolder/admin/configure', false], + ['configure', [], '/admin/configure', true], ]; } } diff --git a/tests/legacy/LegacyUpdaterTest.php b/tests/legacy/LegacyUpdaterTest.php index 293fa719d..c87b65d55 100644 --- a/tests/legacy/LegacyUpdaterTest.php +++ b/tests/legacy/LegacyUpdaterTest.php @@ -41,7 +41,7 @@ class LegacyUpdaterTest extends TestCase */ protected function setUp(): void { - copy('tests/utils/config/configJson.json.php', self::$configFile . '.json.php'); + copy(__DIR__ . '/../utils/config/configJson.json.php', self::$configFile . '.json.php'); $this->conf = new ConfigManager(self::$configFile); } diff --git a/tests/netscape/BookmarkImportTest.php b/tests/netscape/BookmarkImportTest.php index d880c3aa9..90eecaddd 100644 --- a/tests/netscape/BookmarkImportTest.php +++ b/tests/netscape/BookmarkImportTest.php @@ -12,7 +12,7 @@ use Shaarli\History; use Shaarli\Plugin\PluginManager; use Shaarli\TestCase; -use Slim\Http\UploadedFile; +use Slim\Psr7\UploadedFile; /** * Utility function to load a file's metadata in a $_FILES-like array @@ -40,7 +40,7 @@ class BookmarkImportTest extends TestCase /** * @var string datastore to test write operations */ - protected static $testDatastore = 'sandbox/datastore.php'; + protected static $testDatastore = __DIR__ . '/../../sandbox/datastore.php'; /** * @var string History file path @@ -92,7 +92,10 @@ public static function setUpBeforeClass(): void */ protected function setUp(): void { + $mutex = new NoMutex(); + $folder = dirname(self::$testDatastore); + file_exists($folder) || mkdir($folder, 0755, true); if (file_exists(self::$testDatastore)) { unlink(self::$testDatastore); } diff --git a/tests/plugins/PluginAddlinkTest.php b/tests/plugins/PluginAddlinkTest.php index 3ae72d99d..8cd4db26c 100644 --- a/tests/plugins/PluginAddlinkTest.php +++ b/tests/plugins/PluginAddlinkTest.php @@ -5,7 +5,7 @@ use Shaarli\Plugin\PluginManager; use Shaarli\Render\TemplatePage; -require_once 'plugins/addlink_toolbar/addlink_toolbar.php'; +require_once __DIR__.'/../../plugins/addlink_toolbar/addlink_toolbar.php'; /** * Unit test for the Addlink toolbar plugin diff --git a/tests/plugins/PluginReadItLaterTest.php b/tests/plugins/PluginReadItLaterTest.php index 32225628a..f95d5752a 100644 --- a/tests/plugins/PluginReadItLaterTest.php +++ b/tests/plugins/PluginReadItLaterTest.php @@ -13,7 +13,7 @@ * Class PluginQrcodeTest * Unit test for the ReadItLater plugin */ -class PluginQrcodeTest extends TestCase +class PluginReadItLaterTest extends TestCase { /** @var ConfigManager */ protected $confDefaultTheme; diff --git a/tests/updater/UpdaterTest.php b/tests/updater/UpdaterTest.php index 9672a31bc..7f4bcc227 100644 --- a/tests/updater/UpdaterTest.php +++ b/tests/updater/UpdaterTest.php @@ -52,7 +52,7 @@ protected function setUp(): void $this->refDB = new ReferenceLinkDB(); $this->refDB->write(self::$testDatastore); - copy('tests/utils/config/configJson.json.php', self::$configFile . '.json.php'); + copy(__DIR__.'/../../tests/utils/config/configJson.json.php', self::$configFile . '.json.php'); $this->conf = new ConfigManager(self::$configFile); $this->bookmarkService = new BookmarkFileService( $this->conf, diff --git a/tests/utils/FakeRequest.php b/tests/utils/FakeRequest.php new file mode 100644 index 000000000..0e02264b7 --- /dev/null +++ b/tests/utils/FakeRequest.php @@ -0,0 +1,42 @@ +serverParams = $serverParams; + return $this; + } +} diff --git a/tests/utils/FakeRequestHandler.php b/tests/utils/FakeRequestHandler.php new file mode 100644 index 000000000..bf7ec4ada --- /dev/null +++ b/tests/utils/FakeRequestHandler.php @@ -0,0 +1,33 @@ +response = $response ?? new Response(); + $this->callback = $callback; + } + public function handle(ServerRequestInterface $request): ResponseInterface + { + if ($this->callback) { + return ($this->callback)($request); + } + return $this->response; + } +} diff --git a/tests/utils/FakeRouteCollector.php b/tests/utils/FakeRouteCollector.php new file mode 100644 index 000000000..132a4b242 --- /dev/null +++ b/tests/utils/FakeRouteCollector.php @@ -0,0 +1,35 @@ +map($methods, $pattern, function () { + }); + if ($name) { + $route->setName($name); + } + return $this; + } + + public function getRouteParser(): RouteParserInterface + { + return parent::getRouteParser(); + } +} diff --git a/tests/utils/ReferenceLinkDB.php b/tests/utils/ReferenceLinkDB.php index a6d221e27..37a90ec8c 100644 --- a/tests/utils/ReferenceLinkDB.php +++ b/tests/utils/ReferenceLinkDB.php @@ -200,6 +200,9 @@ protected function addLink( public function write($filename) { $this->reorder(); + if (!file_exists(dirname($filename))) { + mkdir(dirname($filename), 0755, true); + } FileUtils::writeFlatDB($filename, $this->bookmarks); } From ecca48e774baed68e290b2715034b1dd8e58cd6c Mon Sep 17 00:00:00 2001 From: Beutlin Date: Tue, 11 Apr 2023 23:00:19 +0200 Subject: [PATCH 03/12] Fix PHP lint --- .../controller/visitor/BookmarkListController.php | 9 ++++++--- .../controller/visitor/InstallController.php | 3 ++- index.php | 6 ------ phpcs.xml | 1 + .../admin/FrontAdminControllerMockHelper.php | 1 - .../controller/admin/ManageTagControllerTest.php | 1 - .../AddOrDeleteTagTest.php | 3 ++- .../ChangeVisibilityBookmarkTest.php | 15 ++++++++++----- .../SaveBookmarkTest.php | 3 ++- .../controller/visitor/InstallControllerTest.php | 2 +- .../controller/visitor/TagCloudControllerTest.php | 3 ++- tests/plugins/PluginAddlinkTest.php | 2 +- tests/updater/UpdaterTest.php | 2 +- 13 files changed, 28 insertions(+), 23 deletions(-) diff --git a/application/front/controller/visitor/BookmarkListController.php b/application/front/controller/visitor/BookmarkListController.php index 03c642c66..8b6991f4e 100644 --- a/application/front/controller/visitor/BookmarkListController.php +++ b/application/front/controller/visitor/BookmarkListController.php @@ -112,7 +112,8 @@ public function index(Request $request, Response $response): Response $data['pagetitle'] .= '- '; } - $data['pagetitle'] = ($data['pagetitle'] ?? '') . $this->container->get('conf')->get('general.title', 'Shaarli'); + $data['pagetitle'] = ($data['pagetitle'] ?? '') . $this->container->get('conf') + ->get('general.title', 'Shaarli'); $this->executePageHooks('render_linklist', $data, TemplatePage::LINKLIST); $this->assignAllView($data); @@ -144,7 +145,8 @@ public function permalink(Request $request, Response $response, array $args): Re $data = array_merge( $this->initializeTemplateVars(), [ - 'pagetitle' => $bookmark->getTitle() . ' - ' . $this->container->get('conf')->get('general.title', 'Shaarli'), + 'pagetitle' => $bookmark->getTitle() . ' - ' . $this->container->get('conf') + ->get('general.title', 'Shaarli'), 'links' => [$formatter->format($bookmark)], ] ); @@ -172,7 +174,8 @@ protected function updateThumbnail(Bookmark $bookmark, bool $writeDatastore = tr if ( $bookmark->shouldUpdateThumbnail() && true !== $this->container->get('conf')->get('general.enable_async_metadata', true) - && $this->container->get('conf')->get('thumbnails.mode', Thumbnailer::MODE_NONE) !== Thumbnailer::MODE_NONE + && $this->container->get('conf') + ->get('thumbnails.mode', Thumbnailer::MODE_NONE) !== Thumbnailer::MODE_NONE ) { $bookmark->setThumbnail($this->container->get('thumbnailer')->get($bookmark->getUrl())); $this->container->get('bookmarkService')->set($bookmark, $writeDatastore); diff --git a/application/front/controller/visitor/InstallController.php b/application/front/controller/visitor/InstallController.php index 59cb01512..a934ccf08 100644 --- a/application/front/controller/visitor/InstallController.php +++ b/application/front/controller/visitor/InstallController.php @@ -44,7 +44,8 @@ public function index(Request $request, Response $response): Response static::SESSION_TEST_VALUE !== $this->container->get('sessionManager')->getSessionParameter(static::SESSION_TEST_KEY) ) { - $this->container->get('sessionManager')->setSessionParameter(static::SESSION_TEST_KEY, static::SESSION_TEST_VALUE); + $this->container->get('sessionManager') + ->setSessionParameter(static::SESSION_TEST_KEY, static::SESSION_TEST_VALUE); return $this->redirect($response, '/install/session-test'); } diff --git a/index.php b/index.php index c9445da1a..13c6b7f23 100644 --- a/index.php +++ b/index.php @@ -118,12 +118,6 @@ $app = AppFactory::create(); // Main Shaarli routes -$app->get('/hello', function (Request $request, Response $response, $args) { - throw new Exception('abc'); - $response->getBody()->write("Hello world!"); - return $response; -}); - $app->group('', function (RouteCollectorProxy $group) { $group->get('/install', Controller\Visitor\InstallController::class . ':index')->setName('displayInstall'); $group->get('/install/session-test', Controller\Visitor\InstallController::class . ':sessionTest'); diff --git a/phpcs.xml b/phpcs.xml index a2749b57b..508c84082 100644 --- a/phpcs.xml +++ b/phpcs.xml @@ -9,6 +9,7 @@ */*.css */*.js + */datastore.php diff --git a/tests/front/controller/admin/FrontAdminControllerMockHelper.php b/tests/front/controller/admin/FrontAdminControllerMockHelper.php index 69f5fb8c1..d56fd7aad 100644 --- a/tests/front/controller/admin/FrontAdminControllerMockHelper.php +++ b/tests/front/controller/admin/FrontAdminControllerMockHelper.php @@ -30,7 +30,6 @@ protected function createContainer(): void $this->container->set('history', $this->createMock(History::class)); $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); $this->container->get('sessionManager')->method('checkToken')->willReturn(true); - } diff --git a/tests/front/controller/admin/ManageTagControllerTest.php b/tests/front/controller/admin/ManageTagControllerTest.php index daa3234aa..cccd0bfcf 100644 --- a/tests/front/controller/admin/ManageTagControllerTest.php +++ b/tests/front/controller/admin/ManageTagControllerTest.php @@ -15,7 +15,6 @@ use Slim\Psr7\Response as SlimResponse; use Slim\Psr7\Uri; - class ManageTagControllerTest extends TestCase { use FrontAdminControllerMockHelper; diff --git a/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php b/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php index 3174c57c3..73547fffe 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php @@ -153,7 +153,8 @@ public function testDeleteOneTagOnOneBookmark(): void static::assertSame(['first', 'second', 'third'], $bookmark->getTags()); - $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123)->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123) + ->willReturn($bookmark); $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); $this->container->get('bookmarkService')->expects(static::once())->method('save'); $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); diff --git a/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php b/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php index 9f226fe73..62b9ac35c 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php @@ -48,11 +48,13 @@ public function testSetSingleBookmarkPrivate(): void )); $response = new SlimResponse(); - $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(false); + $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') + ->setPrivate(false); static::assertFalse($bookmark->isPrivate()); - $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123)->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123) + ->willReturn($bookmark); $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); $this->container->get('bookmarkService')->expects(static::once())->method('save'); $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); @@ -99,7 +101,8 @@ public function testSetSingleBookmarkPublic(): void static::assertTrue($bookmark->isPrivate()); - $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123)->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123) + ->willReturn($bookmark); $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); $this->container->get('bookmarkService')->expects(static::once())->method('save'); $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); @@ -140,11 +143,13 @@ public function testSetSinglePrivateBookmarkPrivate(): void )); $response = new SlimResponse(); - $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(true); + $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') + ->setPrivate(true); static::assertTrue($bookmark->isPrivate()); - $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123)->willReturn($bookmark); + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(123) + ->willReturn($bookmark); $this->container->get('bookmarkService')->expects(static::once())->method('set')->with($bookmark, false); $this->container->get('bookmarkService')->expects(static::once())->method('save'); $this->container->set('formatterFactory', $this->createMock(FormatterFactory::class)); diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php index a23eee4ad..f096dc626 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php @@ -267,7 +267,8 @@ public function testSaveBookmarkWithIdZero(): void $response = new SlimResponse(); $this->container->get('bookmarkService')->expects(static::once())->method('exists')->with(0)->willReturn(true); - $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(0)->willReturn(new Bookmark()); + $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(0) + ->willReturn(new Bookmark()); $result = $this->controller->save($request, $response); diff --git a/tests/front/controller/visitor/InstallControllerTest.php b/tests/front/controller/visitor/InstallControllerTest.php index 341868fdc..3a5be9253 100644 --- a/tests/front/controller/visitor/InstallControllerTest.php +++ b/tests/front/controller/visitor/InstallControllerTest.php @@ -202,7 +202,7 @@ public function testSaveInstallValid(): void ]; $request = (new FakeRequest('POST'))->withParsedBody(($providedParameters)); - $response = new SlimResponse; + $response = new SlimResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf') diff --git a/tests/front/controller/visitor/TagCloudControllerTest.php b/tests/front/controller/visitor/TagCloudControllerTest.php index 11e76c57a..0e364589f 100644 --- a/tests/front/controller/visitor/TagCloudControllerTest.php +++ b/tests/front/controller/visitor/TagCloudControllerTest.php @@ -105,7 +105,8 @@ public function testValidCloudControllerInvokeWithParameters(): void $this->assignTemplateVars($assignedVariables); $this->container->get('loginManager')->method('isLoggedin')->willReturn(true); - $this->container->get('sessionManager')->expects(static::once())->method('getSessionParameter')->willReturn('private'); + $this->container->get('sessionManager')->expects(static::once())->method('getSessionParameter') + ->willReturn('private'); $this->container->get('bookmarkService') ->expects(static::once()) diff --git a/tests/plugins/PluginAddlinkTest.php b/tests/plugins/PluginAddlinkTest.php index 8cd4db26c..c52dec9cb 100644 --- a/tests/plugins/PluginAddlinkTest.php +++ b/tests/plugins/PluginAddlinkTest.php @@ -5,7 +5,7 @@ use Shaarli\Plugin\PluginManager; use Shaarli\Render\TemplatePage; -require_once __DIR__.'/../../plugins/addlink_toolbar/addlink_toolbar.php'; +require_once __DIR__ . '/../../plugins/addlink_toolbar/addlink_toolbar.php'; /** * Unit test for the Addlink toolbar plugin diff --git a/tests/updater/UpdaterTest.php b/tests/updater/UpdaterTest.php index 7f4bcc227..b62174a32 100644 --- a/tests/updater/UpdaterTest.php +++ b/tests/updater/UpdaterTest.php @@ -52,7 +52,7 @@ protected function setUp(): void $this->refDB = new ReferenceLinkDB(); $this->refDB->write(self::$testDatastore); - copy(__DIR__.'/../../tests/utils/config/configJson.json.php', self::$configFile . '.json.php'); + copy(__DIR__ . '/../../tests/utils/config/configJson.json.php', self::$configFile . '.json.php'); $this->conf = new ConfigManager(self::$configFile); $this->bookmarkService = new BookmarkFileService( $this->conf, From 19862660bf135a384157125156a0efd67d9ba059 Mon Sep 17 00:00:00 2001 From: Beutlin Date: Tue, 11 Apr 2023 23:17:05 +0200 Subject: [PATCH 04/12] fix types --- application/api/controllers/ApiController.php | 6 +++--- .../front/controller/visitor/ShaarliVisitorController.php | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/application/api/controllers/ApiController.php b/application/api/controllers/ApiController.php index 86299c241..1d81f49e5 100644 --- a/application/api/controllers/ApiController.php +++ b/application/api/controllers/ApiController.php @@ -76,11 +76,11 @@ public function getCi() * Simple helper, which writes data as JSON to the body * * @param Response $response - * @param mixed $data - * @param mixed $jsonStyle + * @param array $data + * @param int $jsonStyle * @return Response */ - protected function respondWithJson(Response $response, mixed $data, mixed $jsonStyle): Response + protected function respondWithJson(Response $response, array $data, int $jsonStyle): Response { $jsonStyle = $jsonStyle ?? 0; $response->getBody()->write(json_encode($data, $jsonStyle)); diff --git a/application/front/controller/visitor/ShaarliVisitorController.php b/application/front/controller/visitor/ShaarliVisitorController.php index c1f0ed9ff..142ee5903 100644 --- a/application/front/controller/visitor/ShaarliVisitorController.php +++ b/application/front/controller/visitor/ShaarliVisitorController.php @@ -193,11 +193,11 @@ protected function redirectFromReferer( * Simple helper, which writes data as JSON to the body * * @param Response $response - * @param mixed $data + * @param array $data * @param int $jsonStyle * @return Response */ - protected function respondWithJson(Response $response, mixed $data, int $jsonStyle = 0): Response + protected function respondWithJson(Response $response, array $data, int $jsonStyle = 0): Response { $response->getBody()->write(json_encode($data, $jsonStyle)); return $response->withHeader('Content-Type', 'application/json'); From 97e6421914a59289772889b7cb5adf99c513d2a8 Mon Sep 17 00:00:00 2001 From: Beutlin Date: Wed, 12 Apr 2023 00:05:56 +0200 Subject: [PATCH 05/12] fix types --- application/api/controllers/ApiController.php | 4 ++-- .../front/controller/visitor/ShaarliVisitorController.php | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/application/api/controllers/ApiController.php b/application/api/controllers/ApiController.php index 1d81f49e5..645325fa6 100644 --- a/application/api/controllers/ApiController.php +++ b/application/api/controllers/ApiController.php @@ -77,10 +77,10 @@ public function getCi() * * @param Response $response * @param array $data - * @param int $jsonStyle + * @param ?int $jsonStyle * @return Response */ - protected function respondWithJson(Response $response, array $data, int $jsonStyle): Response + protected function respondWithJson(Response $response, array $data, ?int $jsonStyle): Response { $jsonStyle = $jsonStyle ?? 0; $response->getBody()->write(json_encode($data, $jsonStyle)); diff --git a/application/front/controller/visitor/ShaarliVisitorController.php b/application/front/controller/visitor/ShaarliVisitorController.php index 142ee5903..2c91cc3d0 100644 --- a/application/front/controller/visitor/ShaarliVisitorController.php +++ b/application/front/controller/visitor/ShaarliVisitorController.php @@ -194,10 +194,10 @@ protected function redirectFromReferer( * * @param Response $response * @param array $data - * @param int $jsonStyle + * @param ?int $jsonStyle * @return Response */ - protected function respondWithJson(Response $response, array $data, int $jsonStyle = 0): Response + protected function respondWithJson(Response $response, array $data, ?int $jsonStyle = 0): Response { $response->getBody()->write(json_encode($data, $jsonStyle)); return $response->withHeader('Content-Type', 'application/json'); From 6f6cc387b84ed05dfca2c4d1583cd8e09ab3a0cd Mon Sep 17 00:00:00 2001 From: Beutlin Date: Wed, 19 Apr 2023 00:26:01 +0200 Subject: [PATCH 06/12] Fix wrong default-values changes of previous code --- application/api/controllers/HistoryController.php | 2 +- application/api/controllers/Tags.php | 4 ++-- application/front/controller/admin/ConfigureController.php | 2 +- .../front/controller/admin/ShaarePublishController.php | 2 +- application/front/controller/visitor/InstallController.php | 3 ++- application/legacy/LegacyController.php | 2 +- 6 files changed, 8 insertions(+), 7 deletions(-) diff --git a/application/api/controllers/HistoryController.php b/application/api/controllers/HistoryController.php index d2e43470a..b0e8fae53 100644 --- a/application/api/controllers/HistoryController.php +++ b/application/api/controllers/HistoryController.php @@ -31,7 +31,7 @@ public function getHistory($request, $response) $history = $this->history->getHistory(); // Return history operations from the {offset}th, starting from {since}. - $since = \DateTime::createFromFormat(\DateTime::ATOM, $request->getQueryParams()['since'] ?? null); + $since = \DateTime::createFromFormat(\DateTime::ATOM, $request->getQueryParams()['since'] ?? ''); $offset = $request->getQueryParams()['offset'] ?? null; if (empty($offset)) { $offset = 0; diff --git a/application/api/controllers/Tags.php b/application/api/controllers/Tags.php index 66c70428b..448e50c4c 100644 --- a/application/api/controllers/Tags.php +++ b/application/api/controllers/Tags.php @@ -35,11 +35,11 @@ class Tags extends ApiController */ public function getTags($request, $response) { - $visibility = $request->getQueryParams()['visibility'] ?? ''; + $visibility = $request->getQueryParams()['visibility'] ?? null; $tags = $this->bookmarkService->bookmarksCountPerTag([], $visibility); // Return tags from the {offset}th tag, starting from 0. - $offset = $request->getQueryParams()['offset'] ?? ''; + $offset = $request->getQueryParams()['offset'] ?? null; if (! empty($offset) && ! ctype_digit($offset)) { throw new ApiBadParametersException('Invalid offset'); } diff --git a/application/front/controller/admin/ConfigureController.php b/application/front/controller/admin/ConfigureController.php index 3d4b80a29..7a13609e0 100644 --- a/application/front/controller/admin/ConfigureController.php +++ b/application/front/controller/admin/ConfigureController.php @@ -113,7 +113,7 @@ public function save(Request $request, Response $response): Response } $thumbnailsMode = extension_loaded('gd') ? - $request->getParsedBody()['enableThumbnails'] ?? null : Thumbnailer::MODE_NONE; + ($request->getParsedBody()['enableThumbnails'] ?? null) : Thumbnailer::MODE_NONE; if ( $thumbnailsMode !== Thumbnailer::MODE_NONE && $thumbnailsMode !== $this->container->get('conf')->get('thumbnails.mode', Thumbnailer::MODE_NONE) diff --git a/application/front/controller/admin/ShaarePublishController.php b/application/front/controller/admin/ShaarePublishController.php index 232b21216..37b3283b2 100644 --- a/application/front/controller/admin/ShaarePublishController.php +++ b/application/front/controller/admin/ShaarePublishController.php @@ -205,7 +205,7 @@ protected function buildLinkDataFromUrl(array $params, string $url): array $description = $params['description'] ?? null; $tags = $params['tags'] ?? null; if (($params['private'] ?? null) !== null) { - $private = filter_var($params['private'], FILTER_VALIDATE_BOOLEAN); + $private = filter_var($params['private'] ?? null, FILTER_VALIDATE_BOOLEAN); } else { $private = $this->container->get('conf')->get('privacy.default_private_links', false); } diff --git a/application/front/controller/visitor/InstallController.php b/application/front/controller/visitor/InstallController.php index a934ccf08..4f3c49044 100644 --- a/application/front/controller/visitor/InstallController.php +++ b/application/front/controller/visitor/InstallController.php @@ -121,7 +121,8 @@ public function save(Request $request, Response $response): Response $request->getParsedBody()['city'] ?? null ) ) { - $timezone = $request->getParsedBody()['continent'] . '/' . $request->getParsedBody()['city']; + $timezone = ($request->getParsedBody()['continent'] ?? null) . '/' . + ($request->getParsedBody()['city'] ?? null); } $this->container->get('conf')->set('general.timezone', $timezone); diff --git a/application/legacy/LegacyController.php b/application/legacy/LegacyController.php index f61138060..043f728da 100644 --- a/application/legacy/LegacyController.php +++ b/application/legacy/LegacyController.php @@ -107,7 +107,7 @@ protected function taglist(Request $request, Response $response): Response protected function daily(Request $request, Response $response): Response { $dayParam = !empty($request->getQueryParams()['day'] ?? null) ? - '?day=' . escape($request->getQueryParams()['day']) : ''; + '?day=' . escape($request->getQueryParams()['day'] ?? null) : ''; return $this->redirect($response, '/daily' . $dayParam); } From e4b3133f7abf019c55278f48f7e5671f6c395aec Mon Sep 17 00:00:00 2001 From: Beutlin Date: Wed, 19 Apr 2023 03:47:55 +0200 Subject: [PATCH 07/12] incorporation of code review --- application/api/controllers/Links.php | 6 -- application/api/exceptions/ApiException.php | 1 - application/container/ContainerBuilder.php | 5 +- application/front/ShaarliAdminMiddleware.php | 2 +- application/front/ShaarliErrorHandler.php | 74 ++--------------- application/front/ShaarliMiddleware.php | 2 +- application/front/controller/PageTrait.php | 72 +++++++++++++++++ .../controller/visitor/ErrorController.php | 51 ------------ .../visitor/ErrorNotFoundController.php | 35 -------- .../visitor/ShaarliVisitorController.php | 69 +--------------- application/helper/DailyPageHelper.php | 2 +- composer.json | 1 + index.php | 12 +-- phpunit.xml | 8 +- ...erTest.php => ShaarliErrorHandlerTest.php} | 80 +++++++++++++++---- .../visitor/ErrorNotFoundControllerTest.php | 68 ---------------- tests/languages/en/UtilsEnTest.php | 4 +- 17 files changed, 161 insertions(+), 331 deletions(-) create mode 100644 application/front/controller/PageTrait.php delete mode 100644 application/front/controller/visitor/ErrorController.php delete mode 100644 application/front/controller/visitor/ErrorNotFoundController.php rename tests/front/{controller/visitor/ErrorControllerTest.php => ShaarliErrorHandlerTest.php} (51%) delete mode 100644 tests/front/controller/visitor/ErrorNotFoundControllerTest.php diff --git a/application/api/controllers/Links.php b/application/api/controllers/Links.php index 578cec3a3..55104a2c7 100644 --- a/application/api/controllers/Links.php +++ b/application/api/controllers/Links.php @@ -2,7 +2,6 @@ namespace Shaarli\Api\Controllers; -use DI\Container; use Psr\Http\Message\ResponseInterface as Response; use Psr\Http\Message\ServerRequestInterface as Request; use Shaarli\Api\ApiUtils; @@ -25,11 +24,6 @@ class Links extends ApiController */ public static $DEFAULT_LIMIT = 20; - public function __construct(Container $ci) - { - parent::__construct($ci); - } - /** * Retrieve a list of bookmarks, allowing different filters. * diff --git a/application/api/exceptions/ApiException.php b/application/api/exceptions/ApiException.php index ce3d750ae..0386b51de 100644 --- a/application/api/exceptions/ApiException.php +++ b/application/api/exceptions/ApiException.php @@ -2,7 +2,6 @@ namespace Shaarli\Api\Exceptions; -use Slim\Http\Response; use Slim\Psr7\Response as SlimResponse; /** diff --git a/application/container/ContainerBuilder.php b/application/container/ContainerBuilder.php index 4e23e3b00..08bcb24f4 100644 --- a/application/container/ContainerBuilder.php +++ b/application/container/ContainerBuilder.php @@ -6,14 +6,13 @@ use DI\Container; use malkusch\lock\mutex\FlockMutex; +use Psr\Container\ContainerInterface; use Psr\Log\LoggerInterface; use Shaarli\Bookmark\BookmarkFileService; use Shaarli\Bookmark\BookmarkServiceInterface; use Shaarli\Config\ConfigManager; use Shaarli\Feed\FeedBuilder; use Shaarli\Formatter\FormatterFactory; -use Shaarli\Front\Controller\Visitor\ErrorController; -use Shaarli\Front\Controller\Visitor\ErrorNotFoundController; use Shaarli\History; use Shaarli\Http\HttpAccess; use Shaarli\Http\MetadataRetriever; @@ -76,7 +75,7 @@ public function __construct( $this->logger = $logger; } - public function build(): Container + public function build(): ContainerInterface { $container = new Container(); diff --git a/application/front/ShaarliAdminMiddleware.php b/application/front/ShaarliAdminMiddleware.php index 807e6e90e..d2a72bf51 100644 --- a/application/front/ShaarliAdminMiddleware.php +++ b/application/front/ShaarliAdminMiddleware.php @@ -18,7 +18,7 @@ public function __invoke(Request $request, RequestHandler $handler): Response $this->initBasePath($request); if (true !== $this->container->get('loginManager')->isLoggedIn()) { - $returnUrl = urlencode($request->getServerParams()['REQUEST_URI'] ?? null); + $returnUrl = urlencode($request->getServerParams()['REQUEST_URI']); return $this->redirect($this->container->get('basePath') . '/login?returnurl=' . $returnUrl); } diff --git a/application/front/ShaarliErrorHandler.php b/application/front/ShaarliErrorHandler.php index a98a2f6d9..84adcc46e 100644 --- a/application/front/ShaarliErrorHandler.php +++ b/application/front/ShaarliErrorHandler.php @@ -9,19 +9,20 @@ use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Log\LoggerInterface; -use Shaarli\Bookmark\BookmarkFilter; +use Shaarli\Front\Controller\PageTrait; use Shaarli\Front\Exception\ShaarliFrontException; use Shaarli\Render\TemplatePage; use Slim\Exception\HttpNotFoundException; use Slim\Handlers\ErrorHandler; use Slim\Interfaces\CallableResolverInterface; -use Slim\Psr7\Response; use Slim\Psr7\Response as SlimResponse; use Slim\Routing\RouteContext; use Throwable; class ShaarliErrorHandler extends ErrorHandler { + use PageTrait; + private ?Container $container; public function __construct( @@ -41,8 +42,8 @@ public function __invoke( bool $logErrors, bool $logErrorDetails ): ResponseInterface { - $resp = parent::__invoke($request, $exception, $displayErrorDetails, $logErrors, $logErrorDetails); - $response = new Response(); + parent::__invoke($request, $exception, $displayErrorDetails, $logErrors, $logErrorDetails); + $response = new SlimResponse(); // Unknown error encountered $this->container->get('pageBuilder')->reset(); if ($exception instanceof HttpNotFoundException) { @@ -72,74 +73,11 @@ public function __invoke( $response = $response->withStatus(500); } - $response->getBody()->write($this->render(TemplatePage::ERROR)); return $response; } - protected function assignView(string $name, $value): self - { - $this->container->get('pageBuilder')->assign($name, $value); - - return $this; - } - - /** - * Call plugin hooks for header, footer and includes, specifying which page will be rendered. - * Then assign generated data to RainTPL. - */ - protected function executeDefaultHooks(string $template): void - { - $common_hooks = [ - 'includes', - 'header', - 'footer', - ]; - - $parameters = $this->buildPluginParameters($template); - - foreach ($common_hooks as $name) { - $pluginData = []; - $this->container->get('pluginManager')->executeHooks( - 'render_' . $name, - $pluginData, - $parameters - ); - $this->assignView('plugins_' . $name, $pluginData); - } - } - - protected function buildPluginParameters(?string $template): array - { - $basePath = $this->container->get('basePath') ?? ''; - return [ - 'target' => $template, - 'loggedin' => $this->container->get('loginManager')->isLoggedIn(), - 'basePath' => $this->container->get('basePath'), - 'rootPath' => preg_replace('#/index\.php$#', '', $basePath), - 'bookmarkService' => $this->container->get('bookmarkService') - ]; - } - - protected function render(string $template): string - { - // Legacy key that used to be injected by PluginManager - $this->assignView('_PAGE_', $template); - $this->assignView('template', $template); - - $this->assignView('linkcount', $this->container->get('bookmarkService')->count(BookmarkFilter::$ALL)); - $this->assignView('privateLinkcount', $this->container->get('bookmarkService') - ->count(BookmarkFilter::$PRIVATE)); - - $this->executeDefaultHooks($template); - - $this->assignView('plugin_errors', $this->container->get('pluginManager')->getErrors()); - - $basePath = $this->container->get('basePath') ?? ''; - return $this->container->get('pageBuilder')->render($template, $basePath); - } - - protected function showError404($request): Response + protected function showError404($request): ResponseInterface { $response = new SlimResponse(); // Request from the API diff --git a/application/front/ShaarliMiddleware.php b/application/front/ShaarliMiddleware.php index b5a1c01aa..1224d22fa 100644 --- a/application/front/ShaarliMiddleware.php +++ b/application/front/ShaarliMiddleware.php @@ -56,7 +56,7 @@ public function __invoke(Request $request, RequestHandler $handler): Response return $handler->handle($request); } catch (UnauthorizedException $e) { - $returnUrl = urlencode($request->getServerParams()['REQUEST_URI'] ?? null); + $returnUrl = urlencode($request->getServerParams()['REQUEST_URI']); return $this->redirect($this->container->get('basePath') . '/login?returnurl=' . $returnUrl); } diff --git a/application/front/controller/PageTrait.php b/application/front/controller/PageTrait.php new file mode 100644 index 000000000..82ccfbbd3 --- /dev/null +++ b/application/front/controller/PageTrait.php @@ -0,0 +1,72 @@ +container->get('pageBuilder')->assign($name, $value); + + return $this; + } + + /** + * Call plugin hooks for header, footer and includes, specifying which page will be rendered. + * Then assign generated data to RainTPL. + */ + protected function executeDefaultHooks(string $template): void + { + $common_hooks = [ + 'includes', + 'header', + 'footer', + ]; + + $parameters = $this->buildPluginParameters($template); + + foreach ($common_hooks as $name) { + $pluginData = []; + $this->container->get('pluginManager')->executeHooks( + 'render_' . $name, + $pluginData, + $parameters + ); + $this->assignView('plugins_' . $name, $pluginData); + } + } + + protected function buildPluginParameters(?string $template): array + { + $basePath = $this->container->get('basePath') ?? ''; + return [ + 'target' => $template, + 'loggedin' => $this->container->get('loginManager')->isLoggedIn(), + 'basePath' => $this->container->get('basePath'), + 'rootPath' => preg_replace('#/index\.php$#', '', $basePath), + 'bookmarkService' => $this->container->get('bookmarkService') + ]; + } + + protected function render(string $template): string + { + // Legacy key that used to be injected by PluginManager + $this->assignView('_PAGE_', $template); + $this->assignView('template', $template); + + $this->assignView('linkcount', $this->container->get('bookmarkService')->count(BookmarkFilter::$ALL)); + $this->assignView('privateLinkcount', $this->container->get('bookmarkService') + ->count(BookmarkFilter::$PRIVATE)); + + $this->executeDefaultHooks($template); + + $this->assignView('plugin_errors', $this->container->get('pluginManager')->getErrors()); + + $basePath = $this->container->get('basePath') ?? ''; + return $this->container->get('pageBuilder')->render($template, $basePath); + } +} diff --git a/application/front/controller/visitor/ErrorController.php b/application/front/controller/visitor/ErrorController.php deleted file mode 100644 index d3dde12fd..000000000 --- a/application/front/controller/visitor/ErrorController.php +++ /dev/null @@ -1,51 +0,0 @@ -container->get('pageBuilder')->reset(); - - if ($throwable instanceof ShaarliFrontException) { - // Functional error - $this->assignView('message', nl2br($throwable->getMessage())); - - $response = $response->withStatus($throwable->getCode()); - } else { - // Internal error (any other Throwable) - if ( - $this->container->get('conf')->get('dev.debug', false) || - $this->container->get('loginManager')->isLoggedIn() - ) { - $this->assignView('message', t('Error: ') . $throwable->getMessage()); - $this->assignView( - 'text', - '' - . t('Please report it on Github.') - . '' - ); - $this->assignView('stacktrace', exception2text($throwable)); - } else { - $this->assignView('message', t('An unexpected error occurred.')); - } - - $response = $response->withStatus(500); - } - - return $this->respondWithTemplate($response, TemplatePage::ERROR); - } -} diff --git a/application/front/controller/visitor/ErrorNotFoundController.php b/application/front/controller/visitor/ErrorNotFoundController.php deleted file mode 100644 index 7fd30916d..000000000 --- a/application/front/controller/visitor/ErrorNotFoundController.php +++ /dev/null @@ -1,35 +0,0 @@ -getRequestTarget(), '/api/v1')) { - return $response->withStatus(404); - } - $basePathFromRequest = $request->getAttribute(RouteContext::BASE_PATH); - - // This is required because the middleware is ignored if the route is not found. - $this->container->set('basePath', rtrim($basePathFromRequest, '/')); - - $this->assignView('error_message', t('Requested page could not be found.')); - - $response = $response->withStatus(404); - return $this->respondWithTemplate($response, TemplatePage::ERROR_404); - } -} diff --git a/application/front/controller/visitor/ShaarliVisitorController.php b/application/front/controller/visitor/ShaarliVisitorController.php index 2c91cc3d0..e127bf75c 100644 --- a/application/front/controller/visitor/ShaarliVisitorController.php +++ b/application/front/controller/visitor/ShaarliVisitorController.php @@ -7,7 +7,7 @@ use DI\Container; use Psr\Http\Message\ResponseInterface as Response; use Psr\Http\Message\ServerRequestInterface as Request; -use Shaarli\Bookmark\BookmarkFilter; +use Shaarli\Front\Controller\PageTrait; /** * Class ShaarliVisitorController @@ -19,6 +19,8 @@ */ abstract class ShaarliVisitorController { + use PageTrait; + /** @var Container */ protected $container; @@ -28,18 +30,6 @@ public function __construct(Container $container) $this->container = $container; } - /** - * Assign variables to RainTPL template through the PageBuilder. - * - * @param mixed $value Value to assign to the template - */ - protected function assignView(string $name, $value): self - { - $this->container->get('pageBuilder')->assign($name, $value); - - return $this; - } - /** * Assign variables to RainTPL template through the PageBuilder. * @@ -54,48 +44,6 @@ protected function assignAllView(array $data): self return $this; } - protected function render(string $template): string - { - // Legacy key that used to be injected by PluginManager - $this->assignView('_PAGE_', $template); - $this->assignView('template', $template); - - $this->assignView('linkcount', $this->container->get('bookmarkService')->count(BookmarkFilter::$ALL)); - $this->assignView('privateLinkcount', $this->container->get('bookmarkService') - ->count(BookmarkFilter::$PRIVATE)); - - $this->executeDefaultHooks($template); - - $this->assignView('plugin_errors', $this->container->get('pluginManager')->getErrors()); - - return $this->container->get('pageBuilder')->render($template, $this->container->get('basePath')); - } - - /** - * Call plugin hooks for header, footer and includes, specifying which page will be rendered. - * Then assign generated data to RainTPL. - */ - protected function executeDefaultHooks(string $template): void - { - $common_hooks = [ - 'includes', - 'header', - 'footer', - ]; - - $parameters = $this->buildPluginParameters($template); - - foreach ($common_hooks as $name) { - $pluginData = []; - $this->container->get('pluginManager')->executeHooks( - 'render_' . $name, - $pluginData, - $parameters - ); - $this->assignView('plugins_' . $name, $pluginData); - } - } - protected function executePageHooks(string $hook, array &$data, string $template = null): void { $this->container->get('pluginManager')->executeHooks( @@ -105,17 +53,6 @@ protected function executePageHooks(string $hook, array &$data, string $template ); } - protected function buildPluginParameters(?string $template): array - { - return [ - 'target' => $template, - 'loggedin' => $this->container->get('loginManager')->isLoggedIn(), - 'basePath' => $this->container->get('basePath'), - 'rootPath' => preg_replace('#/index\.php$#', '', $this->container->get('basePath')), - 'bookmarkService' => $this->container->get('bookmarkService') - ]; - } - /** * Simple helper which prepend the base path to redirect path. * diff --git a/application/helper/DailyPageHelper.php b/application/helper/DailyPageHelper.php index 80dbbe508..8be652464 100644 --- a/application/helper/DailyPageHelper.php +++ b/application/helper/DailyPageHelper.php @@ -21,7 +21,7 @@ class DailyPageHelper * * @param Request $request HTTP request * - * @return string|null month/week/day + * @return string month/week/day */ public static function extractRequestedType(Request $request): string { diff --git a/composer.json b/composer.json index ad75bcf31..b8cd69878 100644 --- a/composer.json +++ b/composer.json @@ -58,6 +58,7 @@ "Shaarli\\Feed\\": "application/feed", "Shaarli\\Formatter\\": "application/formatter", "Shaarli\\Front\\": "application/front", + "Shaarli\\Front\\Controller\\": "application/front/controller", "Shaarli\\Front\\Controller\\Admin\\": "application/front/controller/admin", "Shaarli\\Front\\Controller\\Visitor\\": "application/front/controller/visitor", "Shaarli\\Front\\Exception\\": "application/front/exceptions", diff --git a/index.php b/index.php index 13c6b7f23..ea3c42d3b 100644 --- a/index.php +++ b/index.php @@ -27,8 +27,6 @@ require_once __DIR__ . '/init.php'; use Katzgrau\KLogger\Logger; -use Psr\Http\Message\ResponseInterface as Response; -use Psr\Http\Message\ServerRequestInterface as Request; use Psr\Log\LogLevel; use Shaarli\Api\Controllers as ApiControllers; use Shaarli\Config\ConfigManager; @@ -49,20 +47,14 @@ // Manually override root URL for complex server configurations define('SHAARLI_ROOT_URL', $conf->get('general.root_url', null)); -// In dev mode, throw exception on any warning -$displayErrorDetails = $conf->get('dev.debug', false); // // See all errors (for debugging only) +$displayErrorDetails = $conf->get('dev.debug', false); // In dev mode, throw exception on any warning -if ($conf->get('dev.debug', false)) { +if ($displayErrorDetails) { // See all errors (for debugging only) error_reporting(-1); set_error_handler(function ($errno, $errstr, $errfile, $errline, array $errcontext = []) { - // Skip PHP 8 deprecation warning with Pimple. - if (strpos($errfile, 'src/Pimple/Container.php') !== -1 && strpos($errstr, 'ArrayAccess::') !== -1) { - return error_log($errstr); - } - throw new ErrorException($errstr, 0, $errno, $errfile, $errline); }); } diff --git a/phpunit.xml b/phpunit.xml index 383595a20..90167eb5a 100644 --- a/phpunit.xml +++ b/phpunit.xml @@ -1,9 +1,14 @@ + + + application + + tests @@ -19,5 +24,4 @@ tests/languages/fr - diff --git a/tests/front/controller/visitor/ErrorControllerTest.php b/tests/front/ShaarliErrorHandlerTest.php similarity index 51% rename from tests/front/controller/visitor/ErrorControllerTest.php rename to tests/front/ShaarliErrorHandlerTest.php index df784c01c..7381d6518 100644 --- a/tests/front/controller/visitor/ErrorControllerTest.php +++ b/tests/front/ShaarliErrorHandlerTest.php @@ -2,26 +2,34 @@ declare(strict_types=1); -namespace Shaarli\Front\Controller\Visitor; +namespace Shaarli\Front; +use Shaarli\Front\Controller\Visitor\FrontControllerMockHelper; use Shaarli\Front\Exception\ShaarliFrontException; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; +use Slim\CallableResolver; +use Slim\Exception\HttpNotFoundException; +use Slim\Psr7\Factory\ResponseFactory; use Slim\Psr7\Uri; +use Slim\Routing\RouteContext; -class ErrorControllerTest extends TestCase +class ShaarliErrorHandlerTest extends TestCase { use FrontControllerMockHelper; /** @var ErrorController */ - protected $controller; + protected $errorHandler; public function setUp(): void { $this->createContainer(); - - $this->controller = new ErrorController($this->container); + $this->errorHandler = new ShaarliErrorHandler( + new CallableResolver(), + new ResponseFactory(), + null, + $this->container + ); } /** @@ -33,23 +41,21 @@ public function testDisplayFrontExceptionError(): void 'POST', new Uri('', '') ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - $response = new SlimResponse(); $message = 'error message'; $errorCode = 418; + $exception = new class ($message, $errorCode) extends ShaarliFrontException { + }; + // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $result = ($this->controller)( - $request, - $response, - new class ($message, $errorCode) extends ShaarliFrontException { - } - ); + $result = ($this->errorHandler)($request, $exception, false, true, true); static::assertSame($errorCode, $result->getStatusCode()); + static::assertSame('error', (string) $result->getBody()); static::assertSame($message, $assignedVariables['message']); static::assertArrayNotHasKey('stacktrace', $assignedVariables); } @@ -61,7 +67,7 @@ public function testDisplayFrontExceptionError(): void public function testDisplayAnyExceptionErrorNoDebugLoggedIn(): void { $request = new FakeRequest(); - $response = new SlimResponse(); + $exception = new \Exception('abc'); // Save RainTPL assigned variables $assignedVariables = []; @@ -69,9 +75,10 @@ public function testDisplayAnyExceptionErrorNoDebugLoggedIn(): void $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); - $result = ($this->controller)($request, $response, new \Exception('abc')); + $result = ($this->errorHandler)($request, $exception, false, true, true); static::assertSame(500, $result->getStatusCode()); + static::assertSame('error', (string) $result->getBody()); static::assertSame('Error: abc', $assignedVariables['message']); static::assertContainsPolyfill('Please report it on Github', $assignedVariables['text']); static::assertArrayHasKey('stacktrace', $assignedVariables); @@ -84,7 +91,7 @@ public function testDisplayAnyExceptionErrorNoDebugLoggedIn(): void public function testDisplayAnyExceptionErrorNoDebug(): void { $request = new FakeRequest(); - $response = new SlimResponse(); + $exception = new \Exception('abc'); // Save RainTPL assigned variables $assignedVariables = []; @@ -92,11 +99,50 @@ public function testDisplayAnyExceptionErrorNoDebug(): void $this->container->get('loginManager')->method('isLoggedIn')->willReturn(false); - $result = ($this->controller)($request, $response, new \Exception('abc')); + $result = ($this->errorHandler)($request, $exception, false, true, true); static::assertSame(500, $result->getStatusCode()); + static::assertSame('error', (string) $result->getBody()); static::assertSame('An unexpected error occurred.', $assignedVariables['message']); static::assertArrayNotHasKey('text', $assignedVariables); static::assertArrayNotHasKey('stacktrace', $assignedVariables); } + + /** + * Test displaying 404 error + */ + public function testDisplayNotFoundError(): void + { + $request = (new FakeRequest())->withAttribute(RouteContext::BASE_PATH, '/subfolder'); + $exception = new HttpNotFoundException($request); + + // Save RainTPL assigned variables + $assignedVariables = []; + $this->assignTemplateVars($assignedVariables); + + $result = ($this->errorHandler)($request, $exception, false, true, true); + + static::assertSame(404, $result->getStatusCode()); + static::assertSame('404', (string) $result->getBody()); + static::assertSame('Requested page could not be found.', $assignedVariables['error_message']); + } + + /** + * Test displaying 404 error from REST API + */ + public function testDisplayNotFoundErrorFromAPI(): void + { + $request = (new FakeRequest())->withAttribute(RouteContext::BASE_PATH, '/subfolder'); + $exception = new HttpNotFoundException($request); + + // Save RainTPL assigned variables + $assignedVariables = []; + $this->assignTemplateVars($assignedVariables); + + $result = ($this->errorHandler)($request, $exception, false, true, true); + + static::assertSame(404, $result->getStatusCode()); + // next line does not work after Slim4 migration + // static::assertSame([], $assignedVariables); + } } diff --git a/tests/front/controller/visitor/ErrorNotFoundControllerTest.php b/tests/front/controller/visitor/ErrorNotFoundControllerTest.php deleted file mode 100644 index c862bb065..000000000 --- a/tests/front/controller/visitor/ErrorNotFoundControllerTest.php +++ /dev/null @@ -1,68 +0,0 @@ -createContainer(); - - $this->controller = new ErrorNotFoundController($this->container); - } - - /** - * Test displaying 404 error - */ - public function testDisplayNotFoundError(): void - { - $request = (new FakeRequest())->withAttribute(RouteContext::BASE_PATH, '/subfolder'); - - $response = new SlimResponse(); - - // Save RainTPL assigned variables - $assignedVariables = []; - $this->assignTemplateVars($assignedVariables); - - $result = ($this->controller)( - $request, - $response - ); - - static::assertSame(404, $result->getStatusCode()); - static::assertSame('404', (string) $result->getBody()); - static::assertSame('Requested page could not be found.', $assignedVariables['error_message']); - } - - /** - * Test displaying 404 error from REST API - */ - public function testDisplayNotFoundErrorFromAPI(): void - { - $request = (new FakeRequest())->withAttribute(RouteContext::BASE_PATH, '/subfolder'); - - $response = new SlimResponse(); - - // Save RainTPL assigned variables - $assignedVariables = []; - $this->assignTemplateVars($assignedVariables); - - $result = ($this->controller)($request, $response); - - static::assertSame(404, $result->getStatusCode()); - // next line does not work after Slim4 migration - // static::assertSame([], $assignedVariables); - } -} diff --git a/tests/languages/en/UtilsEnTest.php b/tests/languages/en/UtilsEnTest.php index f1e21b9a3..a59f989b5 100644 --- a/tests/languages/en/UtilsEnTest.php +++ b/tests/languages/en/UtilsEnTest.php @@ -23,7 +23,9 @@ public function testDateFormat() $current = setlocale(LC_ALL, 0); autoLocale('en_US.UTF-8'); $date = DateTime::createFromFormat('Ymd_His', '20170102_201112'); - $this->assertRegExp('/January 2, 2017 (at )?8:11:12 PM GMT\+0?3(:00)?/', format_date($date, true, true)); + // Replace No-Break-Space with simple space + $formatedDate = str_replace(' ', ' ', format_date($date, true, true)); + $this->assertRegExp('/January 2, 2017 (at )?8:11:12 PM GMT\+0?3(:00)?/', $formatedDate); setlocale(LC_ALL, $current); } From 6766bc0b0da8801dae42ae89722d207aaaef76e3 Mon Sep 17 00:00:00 2001 From: Beutlin Date: Tue, 25 Apr 2023 04:05:54 +0200 Subject: [PATCH 08/12] use slim factories for request and response --- application/api/exceptions/ApiException.php | 4 +- application/front/ShaarliErrorHandler.php | 6 +- application/front/ShaarliMiddleware.php | 6 +- tests/TestCase.php | 15 ++ tests/api/ApiMiddlewareTest.php | 114 ++++----- tests/api/controllers/history/HistoryTest.php | 36 ++- tests/api/controllers/info/InfoTest.php | 10 +- .../api/controllers/links/DeleteLinkTest.php | 14 +- tests/api/controllers/links/GetLinkIdTest.php | 18 +- tests/api/controllers/links/GetLinksTest.php | 222 ++++++++---------- tests/api/controllers/links/PostLinkTest.php | 68 +++--- tests/api/controllers/links/PutLinkTest.php | 73 +++--- tests/api/controllers/tags/DeleteTagTest.php | 36 +-- tests/api/controllers/tags/GetTagNameTest.php | 40 ++-- tests/api/controllers/tags/GetTagsTest.php | 49 ++-- tests/api/controllers/tags/PutTagTest.php | 41 ++-- tests/feed/FeedBuilderTest.php | 2 +- tests/front/ShaarliAdminMiddlewareTest.php | 40 ++-- tests/front/ShaarliErrorHandlerTest.php | 18 +- tests/front/ShaarliMiddlewareTest.php | 103 ++++---- .../admin/ConfigureControllerTest.php | 35 ++- .../controller/admin/ExportControllerTest.php | 33 ++- .../controller/admin/ImportControllerTest.php | 43 ++-- .../controller/admin/LogoutControllerTest.php | 6 +- .../admin/ManageTagControllerTest.php | 84 +++---- .../admin/PasswordControllerTest.php | 40 ++-- .../admin/PluginsControllerTest.php | 31 +-- .../controller/admin/ServerControllerTest.php | 26 +- .../admin/SessionFilterControllerTest.php | 43 ++-- .../admin/ShaareAddControllerTest.php | 10 +- .../AddOrDeleteTagTest.php | 75 +++--- .../ChangeVisibilityBookmarkTest.php | 74 ++---- .../DeleteBookmarkTest.php | 66 ++---- .../PinBookmarkTest.php | 18 +- .../SharePrivateTest.php | 14 +- .../DisplayCreateBatchFormTest.php | 11 +- .../DisplayCreateFormTest.php | 62 ++--- .../DisplayEditFormTest.php | 18 +- .../SaveBookmarkTest.php | 67 +++--- .../admin/ShaarliAdminControllerTest.php | 11 +- .../admin/ThumbnailsControllerTest.php | 22 +- .../controller/admin/TokenControllerTest.php | 6 +- .../controller/admin/ToolsControllerTest.php | 18 +- .../visitor/BookmarkListControllerTest.php | 140 +++++------ .../visitor/DailyControllerTest.php | 96 ++++---- .../controller/visitor/FeedControllerTest.php | 33 ++- .../visitor/InstallControllerTest.php | 35 +-- .../visitor/LoginControllerTest.php | 98 ++++---- .../visitor/OpenSearchControllerTest.php | 11 +- .../visitor/PictureWallControllerTest.php | 10 +- .../PublicSessionFilterControllerTest.php | 51 ++-- .../visitor/ShaarliVisitorControllerTest.php | 88 +++---- .../visitor/TagCloudControllerTest.php | 32 ++- .../controller/visitor/TagControllerTest.php | 105 +++++---- tests/helper/DailyPageHelperTest.php | 4 +- tests/legacy/LegacyControllerTest.php | 17 +- tests/netscape/BookmarkImportTest.php | 17 +- tests/utils/FakeRequest.php | 42 ---- tests/utils/FakeRequestHandler.php | 33 --- tests/utils/FakeRouteCollector.php | 35 --- tests/utils/RequestHandlerFactory.php | 27 +++ 61 files changed, 1135 insertions(+), 1467 deletions(-) delete mode 100644 tests/utils/FakeRequest.php delete mode 100644 tests/utils/FakeRequestHandler.php delete mode 100644 tests/utils/FakeRouteCollector.php create mode 100644 tests/utils/RequestHandlerFactory.php diff --git a/application/api/exceptions/ApiException.php b/application/api/exceptions/ApiException.php index 0386b51de..70df4ef0c 100644 --- a/application/api/exceptions/ApiException.php +++ b/application/api/exceptions/ApiException.php @@ -2,7 +2,7 @@ namespace Shaarli\Api\Exceptions; -use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Factory\ResponseFactory; /** * Abstract class ApiException @@ -57,7 +57,7 @@ protected function getApiResponseBody() protected function buildApiResponse($code) { $style = $this->debug ? JSON_PRETTY_PRINT : null; - $response = $this->response ?? new SlimResponse(); + $response = $this->response ?? (new ResponseFactory())->createResponse(); $response->getBody()->write(json_encode($this->getApiResponseBody(), $style)); return $response->withStatus($code); } diff --git a/application/front/ShaarliErrorHandler.php b/application/front/ShaarliErrorHandler.php index 84adcc46e..99e323c1c 100644 --- a/application/front/ShaarliErrorHandler.php +++ b/application/front/ShaarliErrorHandler.php @@ -15,7 +15,7 @@ use Slim\Exception\HttpNotFoundException; use Slim\Handlers\ErrorHandler; use Slim\Interfaces\CallableResolverInterface; -use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Factory\ResponseFactory; use Slim\Routing\RouteContext; use Throwable; @@ -43,7 +43,7 @@ public function __invoke( bool $logErrorDetails ): ResponseInterface { parent::__invoke($request, $exception, $displayErrorDetails, $logErrors, $logErrorDetails); - $response = new SlimResponse(); + $response = (new ResponseFactory())->createResponse(); // Unknown error encountered $this->container->get('pageBuilder')->reset(); if ($exception instanceof HttpNotFoundException) { @@ -79,7 +79,7 @@ public function __invoke( protected function showError404($request): ResponseInterface { - $response = new SlimResponse(); + $response = (new ResponseFactory())->createResponse(); // Request from the API if (false !== strpos($request->getRequestTarget(), '/api/v1')) { return $response->withStatus(404); diff --git a/application/front/ShaarliMiddleware.php b/application/front/ShaarliMiddleware.php index 1224d22fa..7163a470a 100644 --- a/application/front/ShaarliMiddleware.php +++ b/application/front/ShaarliMiddleware.php @@ -7,7 +7,7 @@ use Psr\Http\Message\ServerRequestInterface as Request; use Psr\Http\Server\RequestHandlerInterface as RequestHandler; use Shaarli\Front\Exception\UnauthorizedException; -use Slim\Psr7\Response as SlimResponse; +use Slim\Psr7\Factory\ResponseFactory; use Slim\Routing\RouteContext; /** @@ -123,7 +123,7 @@ protected function initBasePath(Request $request): void */ protected function redirect(string $url): Response { - $response = new SlimResponse(); - return $response->withHeader('Location', $url)->withStatus(302); + return (new ResponseFactory())->createResponse(302) + ->withHeader('Location', $url); } } diff --git a/tests/TestCase.php b/tests/TestCase.php index 781e7aa36..2056bf463 100644 --- a/tests/TestCase.php +++ b/tests/TestCase.php @@ -4,12 +4,27 @@ namespace Shaarli; +use Slim\Psr7\Factory\RequestFactory; +use Slim\Psr7\Factory\ResponseFactory; +use Slim\Psr7\Factory\ServerRequestFactory; + /** * Helper class extending \PHPUnit\Framework\TestCase. * Used to make Shaarli UT run on multiple versions of PHPUnit. */ class TestCase extends \PHPUnit\Framework\TestCase { + protected ServerRequestFactory $serverRequestFactory; + protected RequestFactory $requestFactory; + protected ResponseFactory $responseFactory; + + protected function initRequestResponseFactories(): void + { + $this->requestFactory = new RequestFactory(); + $this->serverRequestFactory = new ServerRequestFactory(); + $this->responseFactory = new ResponseFactory(); + } + /** * expectExceptionMessageRegExp has been removed and replaced by expectExceptionMessageMatches in PHPUnit 9. */ diff --git a/tests/api/ApiMiddlewareTest.php b/tests/api/ApiMiddlewareTest.php index 443ebab59..6960316c3 100644 --- a/tests/api/ApiMiddlewareTest.php +++ b/tests/api/ApiMiddlewareTest.php @@ -9,8 +9,7 @@ use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\FakeRequestHandler; use Shaarli\Tests\Utils\ReferenceLinkDB; -use Slim\Psr7\Headers; -use Slim\Psr7\Uri; +use Shaarli\Tests\Utils\RequestHandlerFactory; /** * Class ApiMiddlewareTest @@ -44,11 +43,19 @@ class ApiMiddlewareTest extends \Shaarli\TestCase */ protected $container; + /** + * @var RequestHandlerFactory instance + */ + private $requestHandlerFactory; + /** * Before every test, instantiate a new Api with its config, plugins and bookmarks. */ protected function setUp(): void { + $this->initRequestResponseFactories(); + $this->requestHandlerFactory = new RequestHandlerFactory(); + $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('api.secret', 'NapoleonWasALizard'); @@ -77,14 +84,12 @@ protected function tearDown(): void public function testInvokeMiddlewareWithValidToken(): void { $mw = new ApiMiddleware($this->container); - $request = new FakeRequest( - 'GET', - (new Uri('', ''))->withPath('/hello'), - new Headers([ - 'HTTP_AUTHORIZATION' => 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard') - ]) - ); - $response = $mw($request, new FakeRequestHandler()); + $token = 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard'); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/hello') + ->withHeader('HTTP_AUTHORIZATION', $token); + + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + $response = $mw($request, $requestHandler); $this->assertEquals(200, $response->getStatusCode()); } @@ -97,16 +102,11 @@ public function testInvokeMiddlewareWithValidTokenFromRedirectedHeader(): void { $token = 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard'); $mw = new ApiMiddleware($this->container); - $request = new FakeRequest( - 'GET', - (new Uri('', ''))->withPath('/hello'), - new Headers([]), - [], - [ - 'REDIRECT_HTTP_AUTHORIZATION' => $token, - ] - ); - $response = $mw($request, new FakeRequestHandler()); + $serverParams = ['REDIRECT_HTTP_AUTHORIZATION' => $token]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli/hello', $serverParams); + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + + $response = $mw($request, $requestHandler); $this->assertEquals(200, $response->getStatusCode()); } @@ -121,14 +121,11 @@ public function testInvokeMiddlewareApiDisabled() $this->container->set('conf', $this->conf); $mw = new ApiMiddleware($this->container); - $request = new FakeRequest( - 'GET', - (new Uri('', ''))->withPath('/hello'), - new Headers([ - 'HTTP_AUTHORIZATION' => 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard') - ]) - ); - $response = $mw($request, new FakeRequestHandler()); + $token = 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard'); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/hello') + ->withHeader('HTTP_AUTHORIZATION', $token); + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + $response = $mw($request, $requestHandler); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -146,14 +143,11 @@ public function testInvokeMiddlewareApiDisabledDebug() $this->container->set('conf', $this->conf); $mw = new ApiMiddleware($this->container); - $request = new FakeRequest( - 'GET', - (new Uri('', ''))->withPath('/hello'), - new Headers([ - 'HTTP_AUTHORIZATION' => 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard') - ]) - ); - $response = $mw($request, new FakeRequestHandler()); + $token = 'Bearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard'); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/hello') + ->withHeader('HTTP_AUTHORIZATION', $token); + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + $response = $mw($request, $requestHandler); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -171,11 +165,9 @@ public function testInvokeMiddlewareNoTokenProvidedDebug() $this->container->set('conf', $this->conf); $mw = new ApiMiddleware($this->container); - $request = new FakeRequest( - 'GET', - (new Uri('', ''))->withPath('/hello') - ); - $response = $mw($request, new FakeRequestHandler()); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/hello'); + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + $response = $mw($request, $requestHandler); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -194,14 +186,12 @@ public function testInvokeMiddlewareNoSecretSetDebug() $this->container->set('conf', $this->conf); $mw = new ApiMiddleware($this->container); - $request = new FakeRequest( - 'GET', - (new Uri('', ''))->withPath('/hello'), - new Headers([ - 'HTTP_AUTHORIZATION' => 'Bearer jwt' - ]) - ); - $response = $mw($request, new FakeRequestHandler()); + $token = 'Bearer jwt'; + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/hello') + ->withHeader('HTTP_AUTHORIZATION', $token); + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + + $response = $mw($request, $requestHandler); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -217,15 +207,12 @@ public function testInvalidJwtAuthHeaderDebug() $this->conf->set('dev.debug', true); $this->container->set('conf', $this->conf); + $token = 'PolarBearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard'); $mw = new ApiMiddleware($this->container); - $request = new FakeRequest( - 'GET', - (new Uri('', ''))->withPath('/hello'), - new Headers([ - 'HTTP_AUTHORIZATION' => 'PolarBearer ' . ApiUtilsTest::generateValidJwtToken('NapoleonWasALizard') - ]) - ); - $response = $mw($request, new FakeRequestHandler()); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/hello') + ->withHeader('HTTP_AUTHORIZATION', $token); + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + $response = $mw($request, $requestHandler); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); @@ -244,15 +231,12 @@ public function testInvokeMiddlewareInvalidJwtDebug() $this->conf->set('dev.debug', true); $this->container->set('conf', $this->conf); + $token = 'Bearer jwt'; $mw = new ApiMiddleware($this->container); - $request = new FakeRequest( - 'GET', - (new Uri('', ''))->withPath('/hello'), - new Headers([ - 'HTTP_AUTHORIZATION' => 'Bearer jwt' - ]) - ); - $response = $mw($request, new FakeRequestHandler()); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/hello') + ->withHeader('HTTP_AUTHORIZATION', $token); + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + $response = $mw($request, $requestHandler); $this->assertEquals(401, $response->getStatusCode()); $body = json_decode((string) $response->getBody()); diff --git a/tests/api/controllers/history/HistoryTest.php b/tests/api/controllers/history/HistoryTest.php index 4e89b6d9b..4012f5f0f 100644 --- a/tests/api/controllers/history/HistoryTest.php +++ b/tests/api/controllers/history/HistoryTest.php @@ -10,7 +10,6 @@ use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceHistory; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; class HistoryTest extends TestCase { @@ -44,6 +43,7 @@ class HistoryTest extends TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->refHistory = new ReferenceHistory(); $this->refHistory->write(self::$testHistory); @@ -68,11 +68,9 @@ protected function tearDown(): void */ public function testGetHistory() { - $request = new FakeRequest( - 'GET' - ); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); - $response = $this->controller->getHistory($request, new SlimResponse()); + $response = $this->controller->getHistory($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -119,11 +117,10 @@ public function testGetHistory() */ public function testGetHistoryLimit() { - $request = (new FakeRequest( - 'GET' - ))->withQueryParams(['limit' => '1']); + $query = http_build_query(['limit' => 1]); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); - $response = $this->controller->getHistory($request, new SlimResponse()); + $response = $this->controller->getHistory($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -142,11 +139,10 @@ public function testGetHistoryLimit() */ public function testGetHistoryOffset() { - $request = (new FakeRequest( - 'GET' - ))->withQueryParams(['offset' => '4']); + $query = http_build_query(['offset' => 4]); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); - $response = $this->controller->getHistory($request, new SlimResponse()); + $response = $this->controller->getHistory($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -165,11 +161,10 @@ public function testGetHistoryOffset() */ public function testGetHistorySince() { - $request = (new FakeRequest( - 'GET' - ))->withQueryParams(['since' => '2017-03-03T00:00:00+00:00']); + $query = http_build_query(['since' => '2017-03-03T00:00:00+00:00']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); - $response = $this->controller->getHistory($request, new SlimResponse()); + $response = $this->controller->getHistory($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -188,11 +183,10 @@ public function testGetHistorySince() */ public function testGetHistorySinceOffsetLimit() { - $request = (new FakeRequest( - 'GET' - ))->withQueryParams(['since' => '2017-02-01T00:00:00%2B00:00', 'offset' => '1', 'limit' => '1']); + $query = http_build_query(['since' => '2017-02-01T00:00:00%2B00:00', 'offset' => '1', 'limit' => '1']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); - $response = $this->controller->getHistory($request, new SlimResponse()); + $response = $this->controller->getHistory($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); diff --git a/tests/api/controllers/info/InfoTest.php b/tests/api/controllers/info/InfoTest.php index 82d618513..6f431e3a9 100644 --- a/tests/api/controllers/info/InfoTest.php +++ b/tests/api/controllers/info/InfoTest.php @@ -13,7 +13,6 @@ use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; /** * Class InfoTest @@ -59,6 +58,7 @@ class InfoTest extends TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -94,11 +94,9 @@ protected function tearDown(): void */ public function testGetInfo() { - $request = new FakeRequest( - 'GET' - ); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); - $response = $this->controller->getInfo($request, new SlimResponse()); + $response = $this->controller->getInfo($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -121,7 +119,7 @@ public function testGetInfo() $this->conf->set('general.enabled_plugins', $enabledPlugins); $this->conf->set('privacy.default_private_links', $defaultPrivateLinks); - $response = $this->controller->getInfo($request, new SlimResponse()); + $response = $this->controller->getInfo($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); diff --git a/tests/api/controllers/links/DeleteLinkTest.php b/tests/api/controllers/links/DeleteLinkTest.php index f8715ab8a..43c2d6b70 100644 --- a/tests/api/controllers/links/DeleteLinkTest.php +++ b/tests/api/controllers/links/DeleteLinkTest.php @@ -13,7 +13,6 @@ use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; class DeleteLinkTest extends \Shaarli\TestCase { @@ -68,6 +67,7 @@ class DeleteLinkTest extends \Shaarli\TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $this->mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -109,11 +109,9 @@ public function testDeleteLinkValid() { $id = '41'; $this->assertTrue($this->bookmarkService->exists($id)); - $request = new FakeRequest( - 'DELETE' - ); + $request = $this->requestFactory->createRequest('DELETE', 'http://shaarli'); - $response = $this->controller->deleteLink($request, new SlimResponse(), ['id' => $id]); + $response = $this->controller->deleteLink($request, $this->responseFactory->createResponse(), ['id' => $id]); $this->assertEquals(204, $response->getStatusCode()); $this->assertEmpty((string) $response->getBody()); @@ -143,10 +141,8 @@ public function testDeleteLink404() $id = -1; $this->assertFalse($this->bookmarkService->exists($id)); - $request = new FakeRequest( - 'DELETE' - ); + $request = $this->requestFactory->createRequest('DELETE', 'http://shaarli'); - $this->controller->deleteLink($request, new SlimResponse(), ['id' => $id]); + $this->controller->deleteLink($request, $this->responseFactory->createResponse(), ['id' => $id]); } } diff --git a/tests/api/controllers/links/GetLinkIdTest.php b/tests/api/controllers/links/GetLinkIdTest.php index 78238db46..ef03ec6d5 100644 --- a/tests/api/controllers/links/GetLinkIdTest.php +++ b/tests/api/controllers/links/GetLinkIdTest.php @@ -13,7 +13,6 @@ use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; /** * Class GetLinkIdTest @@ -61,6 +60,7 @@ class GetLinkIdTest extends \Shaarli\TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -96,17 +96,11 @@ protected function tearDown(): void */ public function testGetLinkId() { - // Used by index_url(). - $_SERVER['SERVER_NAME'] = 'domain.tld'; - $_SERVER['SERVER_PORT'] = 80; - $_SERVER['SCRIPT_NAME'] = '/'; - $id = 41; - $request = (new FakeRequest( - 'GET' - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = $this->controller->getLink($request, new SlimResponse(), ['id' => $id]); + $response = $this->controller->getLink($request, $this->responseFactory->createResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); @@ -137,8 +131,8 @@ public function testGetLink404() $this->expectException(\Shaarli\Api\Exceptions\ApiLinkNotFoundException::class); $this->expectExceptionMessage('Link not found'); - $request = new FakeRequest(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); - $this->controller->getLink($request, new SlimResponse(), ['id' => -1]); + $this->controller->getLink($request, $this->responseFactory->createResponse(), ['id' => -1]); } } diff --git a/tests/api/controllers/links/GetLinksTest.php b/tests/api/controllers/links/GetLinksTest.php index ca78dcde4..422b9b922 100644 --- a/tests/api/controllers/links/GetLinksTest.php +++ b/tests/api/controllers/links/GetLinksTest.php @@ -14,8 +14,7 @@ use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; +use Slim\Psr7\Factory\ServerserverRequestFactory; /** * Class GetLinksTest @@ -63,6 +62,7 @@ class GetLinksTest extends \Shaarli\TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -98,11 +98,10 @@ protected function tearDown(): void */ public function testGetLinks() { - $request = (new FakeRequest( - 'GET' - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = $this->controller->getLinks($request, new SlimResponse()); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals($this->refDB->countLinks(), count($data)); @@ -149,12 +148,11 @@ public function testGetLinks() */ public function testGetLinksOffsetLimit() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'offset=3&limit=1'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['offset' => 3, 'limit' => 1]); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); - $response = $this->controller->getLinks($request, new SlimResponse()); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -167,11 +165,10 @@ public function testGetLinksOffsetLimit() */ public function testGetLinksLimitAll() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'limit=all'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['limit' => 'all']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals($this->refDB->countLinks(), count($data)); @@ -190,11 +187,10 @@ public function testGetLinksLimitAll() */ public function testGetLinksOffsetTooHigh() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'offset=100'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['offset' => '100']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEmpty(count($data)); @@ -205,11 +201,10 @@ public function testGetLinksOffsetTooHigh() */ public function testGetLinksVisibilityAll() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'visibility=all'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['visibility' => 'all']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string)$response->getBody(), true); $this->assertEquals($this->refDB->countLinks(), count($data)); @@ -223,11 +218,10 @@ public function testGetLinksVisibilityAll() */ public function testGetLinksVisibilityPrivate() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'visibility=private'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['visibility' => 'private']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals($this->refDB->countPrivateLinks(), count($data)); @@ -240,11 +234,10 @@ public function testGetLinksVisibilityPrivate() */ public function testGetLinksVisibilityPublic() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'visibility=public'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['visibility' => 'public']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string)$response->getBody(), true); $this->assertEquals($this->refDB->countPublicLinks(), count($data)); @@ -260,14 +253,10 @@ public function testGetLinksVisibilityPublic() public function testGetLinksSearchTerm() { // Only in description - 1 result - $request = new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchterm=Tropical'), - null, - [], - ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80] - ); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchterm' => 'Tropical']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -275,11 +264,10 @@ public function testGetLinksSearchTerm() $this->assertEquals(self::NB_FIELDS_LINK, count($data[0])); // Only in tags - 1 result - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchterm=tag3'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchterm' => 'tag3']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -287,14 +275,11 @@ public function testGetLinksSearchTerm() $this->assertEquals(self::NB_FIELDS_LINK, count($data[0])); // Multiple results (2) - $request = new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchterm=stallman'), - null, - [], - ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80] - ); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchterm' => 'stallman']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); @@ -304,11 +289,10 @@ public function testGetLinksSearchTerm() $this->assertEquals(self::NB_FIELDS_LINK, count($data[1])); // Multiword - 2 results - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchterm=stallman+software'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchterm' => 'stallman software']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); @@ -318,11 +302,10 @@ public function testGetLinksSearchTerm() $this->assertEquals(self::NB_FIELDS_LINK, count($data[1])); // URL encoding - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchterm=' . urlencode('@web')), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchterm' => '@web']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); @@ -334,11 +317,10 @@ public function testGetLinksSearchTerm() public function testGetLinksSearchTermNoResult() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchterm=nope'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchterm' => 'nope']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(0, count($data)); @@ -347,11 +329,10 @@ public function testGetLinksSearchTermNoResult() public function testGetLinksSearchTags() { // Single tag - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=dev'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => 'dev']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); @@ -361,11 +342,10 @@ public function testGetLinksSearchTags() $this->assertEquals(self::NB_FIELDS_LINK, count($data[1])); // Multitag + exclude - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=stuff+-gnu') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => 'stuff -gnu']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -373,50 +353,40 @@ public function testGetLinksSearchTags() $this->assertEquals(self::NB_FIELDS_LINK, count($data[0])); // wildcard: placeholder at the start - $request = new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=*Tuff'), - null, - [], - ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80] - ); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => '*Tuff']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); $this->assertEquals(41, $data[0]['id']); // wildcard: placeholder at the end - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=c*') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => 'c*']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(5, count($data)); $this->assertEquals(6, $data[0]['id']); // wildcard: placeholder at the middle - $request = new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=w*b'), - null, - [], - ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80] - ); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => 'w*b']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(4, count($data)); $this->assertEquals(6, $data[0]['id']); // wildcard: match all - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=*') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => '*']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(ReferenceLinkDB::$NB_LINKS_TOTAL, count($data)); @@ -424,33 +394,30 @@ public function testGetLinksSearchTags() $this->assertEquals(41, $data[2]['id']); // wildcard: optional ('*' does not need to expand) - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=*stuff*') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => '*stuff*']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(2, count($data)); $this->assertEquals(41, $data[0]['id']); // wildcard: exclusions - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=*a*+-*e*') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => '*a* -*e*']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); $this->assertEquals(41, $data[0]['id']); // finds '#hashtag' in descr. // wildcard: exclude all - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchtags=-*'), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchtags' => '-*']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(0, count($data)); @@ -461,11 +428,10 @@ public function testGetLinksSearchTags() */ public function testGetLinksSearchTermsAndTags() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'searchterm=poke&searchtags=dev') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => '80']); - $response = $this->controller->getLinks($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $query = http_build_query(['searchterm' => 'poke', 'searchtags' => 'dev']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->controller->getLinks($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); diff --git a/tests/api/controllers/links/PostLinkTest.php b/tests/api/controllers/links/PostLinkTest.php index aba5c30cc..0169bcb48 100644 --- a/tests/api/controllers/links/PostLinkTest.php +++ b/tests/api/controllers/links/PostLinkTest.php @@ -15,10 +15,11 @@ use Shaarli\Tests\Utils\FakeRouteCollector; use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; +use Slim\CallableResolver; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; +use Slim\Psr7\Factory\ServerserverRequestFactory; use Slim\Router; +use Slim\Routing\RouteCollector; use Slim\Routing\RouteContext; /** @@ -86,6 +87,7 @@ class PostLinkTest extends TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -108,9 +110,12 @@ protected function setUp(): void $this->container->set('history', $this->history); $this->controller = new Links($this->container); - $this->routeParser = (new FakeRouteCollector()) - ->addRoute('POST', '/api/v1/bookmarks/{id:[\d]+}', 'getLink') - ->getRouteParser(); + + $routeCollector = new RouteCollector($this->responseFactory, new CallableResolver(), $this->container); + $routeCollector->map(['POST'], '/api/v1/bookmarks/{id:[\d]+}', function () { + })->setName('getLink'); + + $this->routeParser = $routeCollector->getRouteParser(); } /** @@ -127,13 +132,10 @@ protected function tearDown(): void */ public function testPostLinkMinimal() { - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - - $response = $this->controller->postLink($request, new SlimResponse()); + $response = $this->controller->postLink($request, $this->responseFactory->createResponse()); $this->assertEquals(201, $response->getStatusCode()); $this->assertEquals('/api/v1/bookmarks/43', $response->getHeader('Location')[0]); $data = json_decode((string) $response->getBody(), true); @@ -174,13 +176,11 @@ public function testPostLinkFull() 'updated' => '2016-06-05T14:32:10+03:00', ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'website.tld', 'SERVER_PORT' => 80]) + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($link); - $response = $this->controller->postLink($request, new SlimResponse()); + $response = $this->controller->postLink($request, $this->responseFactory->createResponse()); $this->assertEquals(201, $response->getStatusCode()); $this->assertEquals('/api/v1/bookmarks/43', $response->getHeader('Location')[0]); @@ -210,13 +210,11 @@ public function testPostLinkDuplicate() 'private' => true, ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) - ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $request = $request->withParsedBody($link); - $response = $this->controller->postLink($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser) + ->withParsedBody($link); + $response = $this->controller->postLink($request, $this->responseFactory->createResponse()); $this->assertEquals(409, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -246,13 +244,11 @@ public function testPostLinkWithTagString(): void $link = [ 'tags' => 'one two', ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) - ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $request = $request->withParsedBody($link); - $response = $this->controller->postLink($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser) + ->withParsedBody($link); + $response = $this->controller->postLink($request, $this->responseFactory->createResponse()); $this->assertEquals(201, $response->getStatusCode()); $this->assertEquals('/api/v1/bookmarks/43', $response->getHeader('Location')[0]); @@ -269,13 +265,11 @@ public function testPostLinkWithTagString2(): void $link = [ 'tags' => ['one two'], ]; - $request = (new FakeRequest( - 'POST', - new Uri('', ''), - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) - ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $request = $request->withParsedBody($link); - $response = $this->controller->postLink($request, new SlimResponse()); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser) + ->withParsedBody($link); + $response = $this->controller->postLink($request, $this->responseFactory->createResponse()); $this->assertEquals(201, $response->getStatusCode()); $this->assertEquals('/api/v1/bookmarks/43', $response->getHeader('Location')[0]); diff --git a/tests/api/controllers/links/PutLinkTest.php b/tests/api/controllers/links/PutLinkTest.php index b697360a0..6254ddf79 100644 --- a/tests/api/controllers/links/PutLinkTest.php +++ b/tests/api/controllers/links/PutLinkTest.php @@ -14,9 +14,10 @@ use Shaarli\Tests\Utils\FakeRouteCollector; use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; +use Slim\CallableResolver; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; +use Slim\Psr7\Factory\ServerserverRequestFactory; +use Slim\Routing\RouteCollector; use Slim\Routing\RouteContext; class PutLinkTest extends \Shaarli\TestCase @@ -76,6 +77,7 @@ class PutLinkTest extends \Shaarli\TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -99,9 +101,10 @@ protected function setUp(): void $this->controller = new Links($this->container); - $this->routeParser = (new FakeRouteCollector()) - ->addRoute('POST', '/api/v1/bookmarks/{id:[\d]+}', 'getLink') - ->getRouteParser(); + $routeCollector = new RouteCollector($this->responseFactory, new CallableResolver(), $this->container); + $routeCollector->map(['POST'], '/api/v1/bookmarks/{id:[\d]+}', function () { + })->setName('getLink'); + $this->routeParser = $routeCollector->getRouteParser(); } /** @@ -119,13 +122,10 @@ protected function tearDown(): void public function testPutLinkMinimal() { $id = '41'; - $request = (new FakeRequest( - 'PUT', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('PUT', 'http://shaarli', $serverParams) ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - - $response = $this->controller->putLink($request, new SlimResponse(), ['id' => $id]); + $response = $this->controller->putLink($request, $this->responseFactory->createResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); @@ -165,14 +165,12 @@ public function testPutLinkWithValues() 'tags' => ['corneille', 'rodrigue'], 'private' => true, ]; - $request = (new FakeRequest( - 'PUT', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('PUT', 'http://shaarli', $serverParams) ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); $request = $request->withParsedBody($update); - $response = $this->controller->putLink($request, new SlimResponse(), ['id' => $id]); + $response = $this->controller->putLink($request, $this->responseFactory->createResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_LINK, count($data)); @@ -205,13 +203,11 @@ public function testPutLinkDuplicate() 'private' => true, ]; - $request = (new FakeRequest( - 'PUT', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) - ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $request = $request->withParsedBody($link); - $response = $this->controller->putLink($request, new SlimResponse(), ['id' => 41]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('PUT', 'http://shaarli', $serverParams) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser) + ->withParsedBody($link); + $response = $this->controller->putLink($request, $this->responseFactory->createResponse(), ['id' => 41]); $this->assertEquals(409, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -241,13 +237,11 @@ public function testGetLink404() $this->expectException(\Shaarli\Api\Exceptions\ApiLinkNotFoundException::class); $this->expectExceptionMessage('Link not found'); - $request = (new FakeRequest( - 'PUT', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('PUT', 'http://shaarli', $serverParams) ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $this->controller->putLink($request, new SlimResponse(), ['id' => -1]); + $this->controller->putLink($request, $this->responseFactory->createResponse(), ['id' => -1]); } /** @@ -260,13 +254,11 @@ public function testPutLinkWithTagString(): void ]; $id = '41'; - $request = (new FakeRequest( - 'PUT', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]) - ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser); - $request = $request->withParsedBody($link); - $response = $this->controller->putLink($request, new SlimResponse(), ['id' => $id]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('PUT', 'http://shaarli', $serverParams) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser) + ->withParsedBody($link); + $response = $this->controller->putLink($request, $this->responseFactory->createResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); @@ -284,12 +276,11 @@ public function testPutLinkWithTagString2(): void ]; $id = '41'; - $request = (new FakeRequest( - 'DELETE', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - $request = $request->withParsedBody($link); - $response = $this->controller->putLink($request, new SlimResponse(), ['id' => $id]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('DELETE', 'http://shaarli', $serverParams) + ->withAttribute(RouteContext::ROUTE_PARSER, $this->routeParser) + ->withParsedBody($link); + $response = $this->controller->putLink($request, $this->responseFactory->createResponse(), ['id' => $id]); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); diff --git a/tests/api/controllers/tags/DeleteTagTest.php b/tests/api/controllers/tags/DeleteTagTest.php index 83f212ac1..9f8072ec0 100644 --- a/tests/api/controllers/tags/DeleteTagTest.php +++ b/tests/api/controllers/tags/DeleteTagTest.php @@ -14,8 +14,7 @@ use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; +use Slim\Psr7\Factory\ServerserverRequestFactory; class DeleteTagTest extends \Shaarli\TestCase { @@ -70,6 +69,7 @@ class DeleteTagTest extends \Shaarli\TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $this->mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -112,12 +112,14 @@ public function testDeleteTagValid() $tagName = 'gnu'; $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertTrue($tags[$tagName] > 0); - $request = (new FakeRequest( - 'DELETE', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('DELETE', 'http://shaarli', $serverParams); - $response = $this->controller->deleteTag($request, new SlimResponse(), ['tagName' => $tagName]); + $response = $this->controller->deleteTag( + $request, + $this->responseFactory->createResponse(), + ['tagName' => $tagName] + ); $this->assertEquals(204, $response->getStatusCode()); $this->assertEmpty((string) $response->getBody()); @@ -152,12 +154,14 @@ public function testDeleteTagCaseSensitivity() $tagName = 'sTuff'; $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertTrue($tags[$tagName] > 0); - $request = (new FakeRequest( - 'DELETE', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('DELETE', 'http://shaarli', $serverParams); - $response = $this->controller->deleteTag($request, new SlimResponse(), ['tagName' => $tagName]); + $response = $this->controller->deleteTag( + $request, + $this->responseFactory->createResponse(), + ['tagName' => $tagName] + ); $this->assertEquals(204, $response->getStatusCode()); $this->assertEmpty((string) $response->getBody()); @@ -190,11 +194,9 @@ public function testDeleteLink404() $tagName = 'nopenope'; $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertFalse(isset($tags[$tagName])); - $request = (new FakeRequest( - 'DELETE', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('DELETE', 'http://shaarli', $serverParams); - $this->controller->deleteTag($request, new SlimResponse(), ['tagName' => $tagName]); + $this->controller->deleteTag($request, $this->responseFactory->createResponse(), ['tagName' => $tagName]); } } diff --git a/tests/api/controllers/tags/GetTagNameTest.php b/tests/api/controllers/tags/GetTagNameTest.php index 2ed279804..29a7dafc8 100644 --- a/tests/api/controllers/tags/GetTagNameTest.php +++ b/tests/api/controllers/tags/GetTagNameTest.php @@ -13,8 +13,7 @@ use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; +use Slim\Psr7\Factory\ServerserverRequestFactory; /** * Class GetTagNameTest @@ -63,6 +62,7 @@ class GetTagNameTest extends \Shaarli\TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -99,12 +99,14 @@ protected function tearDown(): void public function testGetTag() { $tagName = 'gnu'; - $request = (new FakeRequest( - 'GET', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - - $response = $this->controller->getTag($request, new SlimResponse(), ['tagName' => $tagName]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + + $response = $this->controller->getTag( + $request, + $this->responseFactory->createResponse(), + ['tagName' => $tagName] + ); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_TAG, count($data)); @@ -118,12 +120,14 @@ public function testGetTag() public function testGetTagNotCaseSensitive() { $tagName = 'sTuff'; - $request = (new FakeRequest( - 'GET', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); - - $response = $this->controller->getTag($request, new SlimResponse(), ['tagName' => $tagName]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + + $response = $this->controller->getTag( + $request, + $this->responseFactory->createResponse(), + ['tagName' => $tagName] + ); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_TAG, count($data)); @@ -139,11 +143,9 @@ public function testGetTag404() $this->expectException(\Shaarli\Api\Exceptions\ApiTagNotFoundException::class); $this->expectExceptionMessage('Tag not found'); - $request = (new FakeRequest( - 'GET', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $this->controller->getTag($request, new SlimResponse(), ['tagName' => 'nopenope']); + $this->controller->getTag($request, $this->responseFactory->createResponse(), ['tagName' => 'nopenope']); } } diff --git a/tests/api/controllers/tags/GetTagsTest.php b/tests/api/controllers/tags/GetTagsTest.php index 0d15529c9..010f29abb 100644 --- a/tests/api/controllers/tags/GetTagsTest.php +++ b/tests/api/controllers/tags/GetTagsTest.php @@ -13,8 +13,6 @@ use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Tests\Utils\ReferenceLinkDB; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; /** * Class GetTagsTest @@ -68,6 +66,7 @@ class GetTagsTest extends \Shaarli\TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -104,11 +103,9 @@ protected function tearDown(): void public function testGetTagsAll() { $tags = $this->bookmarkService->bookmarksCountPerTag(); - $request = (new FakeRequest( - 'GET' - )); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); - $response = $this->controller->getTags($request, new SlimResponse()); + $response = $this->controller->getTags($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(count($tags), count($data)); @@ -136,11 +133,9 @@ public function testGetTagsAll() */ public function testGetTagsOffsetLimit() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'offset=1&limit=1') - )); - $response = $this->controller->getTags($request, new SlimResponse()); + $query = http_build_query(['offset' => 1, 'limit' => 1]); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->controller->getTags($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(1, count($data)); @@ -155,11 +150,9 @@ public function testGetTagsOffsetLimit() public function testGetTagsLimitAll() { $tags = $this->bookmarkService->bookmarksCountPerTag(); - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'limit=all') - )); - $response = $this->controller->getTags($request, new SlimResponse()); + $query = http_build_query(['limit' => 'all']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli' . $query); + $response = $this->controller->getTags($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(count($tags), count($data)); @@ -171,11 +164,9 @@ public function testGetTagsLimitAll() */ public function testGetTagsOffsetTooHigh() { - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'offset=100') - )); - $response = $this->controller->getTags($request, new SlimResponse()); + $query = http_build_query(['offset' => 100]); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->controller->getTags($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEmpty(count($data)); @@ -187,11 +178,9 @@ public function testGetTagsOffsetTooHigh() public function testGetTagsVisibilityPrivate() { $tags = $this->bookmarkService->bookmarksCountPerTag([], 'private'); - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'visibility=private') - )); - $response = $this->controller->getTags($request, new SlimResponse()); + $query = http_build_query(['visibility' => 'private']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->controller->getTags($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(count($tags), count($data)); @@ -207,11 +196,9 @@ public function testGetTagsVisibilityPublic() { $tags = $this->bookmarkService->bookmarksCountPerTag([], 'public'); - $request = (new FakeRequest( - 'GET', - new Uri('', '', 80, '', 'visibility=public') - )); - $response = $this->controller->getTags($request, new SlimResponse()); + $query = http_build_query(['visibility' => 'public']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->controller->getTags($request, $this->responseFactory->createResponse()); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string)$response->getBody(), true); $this->assertEquals(count($tags), count($data)); diff --git a/tests/api/controllers/tags/PutTagTest.php b/tests/api/controllers/tags/PutTagTest.php index 701c5eabb..0cb516d87 100644 --- a/tests/api/controllers/tags/PutTagTest.php +++ b/tests/api/controllers/tags/PutTagTest.php @@ -15,7 +15,6 @@ use Shaarli\Tests\Utils\ReferenceHistory; use Shaarli\Tests\Utils\ReferenceLinkDB; use Slim\Http\Environment; -use Slim\Psr7\Response as SlimResponse; class PutTagTest extends \Shaarli\TestCase { @@ -72,6 +71,7 @@ class PutTagTest extends \Shaarli\TestCase */ protected function setUp(): void { + $this->initRequestResponseFactories(); $mutex = new NoMutex(); $this->conf = new ConfigManager('tests/utils/config/configJson'); $this->conf->set('resource.datastore', self::$testDatastore); @@ -113,12 +113,14 @@ public function testPutLinkValid() { $tagName = 'gnu'; $update = ['name' => $newName = 'newtag']; - $request = new FakeRequest( - 'PUT' - ); - $request = $request->withParsedBody($update); + $request = $this->requestFactory->createRequest('PUT', 'http://shaarli') + ->withParsedBody($update); - $response = $this->controller->putTag($request, new SlimResponse(), ['tagName' => $tagName]); + $response = $this->controller->putTag( + $request, + $this->responseFactory->createResponse(), + ['tagName' => $tagName] + ); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_TAG, count($data)); @@ -154,12 +156,14 @@ public function testPutTagMerge() $this->assertEquals(2, $tags[$tagName]); $update = ['name' => $newName]; - $request = new FakeRequest( - 'PUT' - ); - $request = $request->withParsedBody($update); + $request = $this->requestFactory->createRequest('PUT', 'http://shaarli') + ->withParsedBody($update); - $response = $this->controller->putTag($request, new SlimResponse(), ['tagName' => $tagName]); + $response = $this->controller->putTag( + $request, + $this->responseFactory->createResponse(), + ['tagName' => $tagName] + ); $this->assertEquals(200, $response->getStatusCode()); $data = json_decode((string) $response->getBody(), true); $this->assertEquals(self::NB_FIELDS_TAG, count($data)); @@ -185,15 +189,12 @@ public function testPutTagEmpty() $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertEquals(2, $tags[$tagName]); - $request = new FakeRequest( - 'PUT' - ); - $update = ['name' => $newName]; - $request = $request->withParsedBody($update); + $request = $this->requestFactory->createRequest('PUT', 'http://shaarli') + ->withParsedBody($update); try { - $this->controller->putTag($request, new SlimResponse(), ['tagName' => $tagName]); + $this->controller->putTag($request, $this->responseFactory->createResponse(), ['tagName' => $tagName]); } catch (ApiBadParametersException $e) { $tags = $this->bookmarkService->bookmarksCountPerTag(); $this->assertEquals(2, $tags[$tagName]); @@ -209,10 +210,8 @@ public function testPutTag404() $this->expectException(\Shaarli\Api\Exceptions\ApiTagNotFoundException::class); $this->expectExceptionMessage('Tag not found'); - $request = new FakeRequest( - 'PUT' - ); + $request = $this->requestFactory->createRequest('PUT', 'http://shaarli'); - $this->controller->putTag($request, new SlimResponse(), ['tagName' => 'nopenope']); + $this->controller->putTag($request, $this->responseFactory->createResponse(), ['tagName' => 'nopenope']); } } diff --git a/tests/feed/FeedBuilderTest.php b/tests/feed/FeedBuilderTest.php index 2ba6decb4..76ca26e42 100644 --- a/tests/feed/FeedBuilderTest.php +++ b/tests/feed/FeedBuilderTest.php @@ -69,7 +69,7 @@ public static function setUpBeforeClass(): void self::$serverInfo = [ 'HTTPS' => 'Off', 'SERVER_NAME' => 'host.tld', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'SCRIPT_NAME' => '/index.php', 'REQUEST_URI' => '/feed/atom', ]; diff --git a/tests/front/ShaarliAdminMiddlewareTest.php b/tests/front/ShaarliAdminMiddlewareTest.php index c5eeb80e5..6ac68382d 100644 --- a/tests/front/ShaarliAdminMiddlewareTest.php +++ b/tests/front/ShaarliAdminMiddlewareTest.php @@ -5,14 +5,15 @@ namespace Shaarli\Front; use DI\Container as DIContainer; +use Psr\Http\Message\ServerRequestInterface; +use Psr\Http\Server\RequestHandlerInterface; use Shaarli\Config\ConfigManager; use Shaarli\Security\LoginManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Shaarli\Tests\Utils\FakeRequestHandler; +use Shaarli\Tests\Utils\RequestHandlerFactory; use Shaarli\Updater\Updater; use Slim\Http\Uri; -use Slim\Psr7\Response as SlimResponse; class ShaarliAdminMiddlewareTest extends TestCase { @@ -26,6 +27,7 @@ class ShaarliAdminMiddlewareTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->container = new DIContainer(); touch(static::TMP_MOCK_FILE); @@ -38,6 +40,7 @@ public function setUp(): void $this->container->set('basePath', '/subfolder'); $this->middleware = new ShaarliAdminMiddleware($this->container); + $this->requestHandlerFactory = new RequestHandlerFactory(); } public function tearDown(): void @@ -53,16 +56,12 @@ public function testMiddlewareWhileLoggedOut(): void $this->container->get('loginManager')->expects(static::once())->method('isLoggedIn')->willReturn(false); - $request = new FakeRequest( - 'GET', - (new \Slim\Psr7\Uri('http', 'shaarli'))->withPath('/subfolder/path'), - null, - [], - ['REQUEST_URI' => 'http://shaarli/subfolder/path'] - ); + $serverParams = ['REQUEST_URI' => 'http://shaarli/subfolder/path']; + $request = $this->serverRequestFactory + ->createServerRequest('GET', 'http://shaarli/subfolder/path', $serverParams); - $fakeResponse = new SlimResponse(); - $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse)); + $requestHandler = $this->requestHandlerFactory->createRequestHandler(); + $result = ($this->middleware)($request, $requestHandler); static::assertSame(302, $result->getStatusCode()); static::assertSame( @@ -78,16 +77,17 @@ public function testMiddlewareWhileLoggedIn(): void { $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); - $request = new FakeRequest( - 'GET', - (new \Slim\Psr7\Uri('http', 'shaarli'))->withPath('/subfolder/path'), - null, - [], - ['REQUEST_URI' => 'http://shaarli/subfolder/path'] - ); + $serverParams = ['REQUEST_URI' => 'http://shaarli/subfolder/path']; + $request = $this->serverRequestFactory + ->createServerRequest('GET', 'http://shaarli/subfolder/path', $serverParams); - $fakeResponse = (new SlimResponse())->withStatus(418); - $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse)); + $responseFactory = $this->responseFactory; + $requestHandler = $this->requestHandlerFactory->createRequestHandler( + function (ServerRequestInterface $request, RequestHandlerInterface $next) use ($responseFactory) { + return $responseFactory->createResponse()->withStatus(418); + } + ); + $result = ($this->middleware)($request, $requestHandler); static::assertSame(418, $result->getStatusCode()); diff --git a/tests/front/ShaarliErrorHandlerTest.php b/tests/front/ShaarliErrorHandlerTest.php index 7381d6518..927bb765e 100644 --- a/tests/front/ShaarliErrorHandlerTest.php +++ b/tests/front/ShaarliErrorHandlerTest.php @@ -11,7 +11,6 @@ use Slim\CallableResolver; use Slim\Exception\HttpNotFoundException; use Slim\Psr7\Factory\ResponseFactory; -use Slim\Psr7\Uri; use Slim\Routing\RouteContext; class ShaarliErrorHandlerTest extends TestCase @@ -23,6 +22,7 @@ class ShaarliErrorHandlerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->errorHandler = new ShaarliErrorHandler( new CallableResolver(), @@ -37,10 +37,8 @@ public function setUp(): void */ public function testDisplayFrontExceptionError(): void { - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withServerParams(['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]); + $serverParams = ['SERVER_NAME' => 'domain.tld', 'SERVER_PORT' => 80]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams); $message = 'error message'; $errorCode = 418; @@ -66,7 +64,7 @@ public function testDisplayFrontExceptionError(): void */ public function testDisplayAnyExceptionErrorNoDebugLoggedIn(): void { - $request = new FakeRequest(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); $exception = new \Exception('abc'); // Save RainTPL assigned variables @@ -90,7 +88,7 @@ public function testDisplayAnyExceptionErrorNoDebugLoggedIn(): void */ public function testDisplayAnyExceptionErrorNoDebug(): void { - $request = new FakeRequest(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); $exception = new \Exception('abc'); // Save RainTPL assigned variables @@ -113,7 +111,8 @@ public function testDisplayAnyExceptionErrorNoDebug(): void */ public function testDisplayNotFoundError(): void { - $request = (new FakeRequest())->withAttribute(RouteContext::BASE_PATH, '/subfolder'); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli') + ->withAttribute(RouteContext::BASE_PATH, '/subfolder'); $exception = new HttpNotFoundException($request); // Save RainTPL assigned variables @@ -132,7 +131,8 @@ public function testDisplayNotFoundError(): void */ public function testDisplayNotFoundErrorFromAPI(): void { - $request = (new FakeRequest())->withAttribute(RouteContext::BASE_PATH, '/subfolder'); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli') + ->withAttribute(RouteContext::BASE_PATH, '/subfolder'); $exception = new HttpNotFoundException($request); // Save RainTPL assigned variables diff --git a/tests/front/ShaarliMiddlewareTest.php b/tests/front/ShaarliMiddlewareTest.php index 3649e4a8e..4bb2fdbc2 100644 --- a/tests/front/ShaarliMiddlewareTest.php +++ b/tests/front/ShaarliMiddlewareTest.php @@ -6,6 +6,8 @@ use DI\Container as DIContainer; use Psr\Http\Message\ResponseInterface as Response; +use Psr\Http\Message\ServerRequestInterface; +use Psr\Http\Server\RequestHandlerInterface; use Shaarli\Config\ConfigManager; use Shaarli\Front\Exception\LoginBannedException; use Shaarli\Front\Exception\UnauthorizedException; @@ -14,10 +16,8 @@ use Shaarli\Security\LoginManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Shaarli\Tests\Utils\FakeRequestHandler; +use Shaarli\Tests\Utils\RequestHandlerFactory; use Shaarli\Updater\Updater; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class ShaarliMiddlewareTest extends TestCase { @@ -29,8 +29,11 @@ class ShaarliMiddlewareTest extends TestCase /** @var ShaarliMiddleware */ protected $middleware; + /** @var RequestHandlerFactory */ + private $requestHandlerFactory; public function setUp(): void { + $this->initRequestResponseFactories(); $this->container = new DIContainer(); touch(static::TMP_MOCK_FILE); @@ -44,6 +47,7 @@ public function setUp(): void $this->container->set('basePath', '/subfolder'); $this->middleware = new ShaarliMiddleware($this->container); + $this->requestHandlerFactory = new RequestHandlerFactory(); } public function tearDown(): void @@ -56,13 +60,16 @@ public function tearDown(): void */ public function testMiddlewareExecution(): void { - $request = new FakeRequest( - 'GET', - (new Uri('http', 'shaarli'))->withPath('/subfolder/path') + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/subfolder/path'); + + $responseFactory = $this->responseFactory; + $requestHandler = $this->requestHandlerFactory->createRequestHandler( + function (ServerRequestInterface $request, RequestHandlerInterface $next) use ($responseFactory) { + return $responseFactory->createResponse()->withStatus(418); // I'm a tea pot + } ); - $fakeResponse = (new SlimResponse())->withStatus(418); // I'm a tea pot - $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse)); + $result = ($this->middleware)($request, $requestHandler); static::assertInstanceOf(Response::class, $result); static::assertSame(418, $result->getStatusCode()); @@ -74,17 +81,14 @@ public function testMiddlewareExecution(): void */ public function testMiddlewareExecutionWithFrontException(): void { - $request = new FakeRequest( - 'GET', - (new Uri('http', 'shaarli'))->withPath('/subfolder/path') - ); - - $fakeResponse = (new SlimResponse())->withStatus(418); // I'm a tea pot - $callback = function ($request) { - $exception = new LoginBannedException(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli/subfolder/path'); - throw new $exception(); - }; + $requestHandler = $this->requestHandlerFactory->createRequestHandler( + function (ServerRequestInterface $request, RequestHandlerInterface $next) { + $exception = new LoginBannedException(); + throw new $exception(); + } + ); $pageBuilder = $this->createMock(PageBuilder::class); $pageBuilder->method('render')->willReturnCallback(function (string $message): string { @@ -93,7 +97,7 @@ public function testMiddlewareExecutionWithFrontException(): void $this->container->set('pageBuilder', $pageBuilder); $this->expectException(LoginBannedException::class); - ($this->middleware)($request, new FakeRequestHandler($fakeResponse, $callback)); + ($this->middleware)($request, $requestHandler); } /** @@ -102,20 +106,17 @@ public function testMiddlewareExecutionWithFrontException(): void */ public function testMiddlewareExecutionWithUnauthorizedException(): void { - $request = new FakeRequest( - 'GET', - (new Uri('http', 'shaarli'))->withPath('/subfolder/path'), - null, - [], - ['REQUEST_URI' => 'http://shaarli/subfolder/path'] + $serverParams = ['REQUEST_URI' => 'http://shaarli/subfolder/path']; + $request = $this->serverRequestFactory + ->createServerRequest('GET', 'http://shaarli/subfolder/path', $serverParams); + + $requestHandler = $this->requestHandlerFactory->createRequestHandler( + function (ServerRequestInterface $request, RequestHandlerInterface $next) { + throw new UnauthorizedException(); + } ); - $fakeResponse = new SlimResponse(); - $callback = function ($request) { - throw new UnauthorizedException(); - }; - - $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse, $callback)); + $result = ($this->middleware)($request, $requestHandler); static::assertSame(302, $result->getStatusCode()); static::assertSame( @@ -130,20 +131,17 @@ public function testMiddlewareExecutionWithUnauthorizedException(): void */ public function testMiddlewareExecutionWithServerException(): void { - $request = new FakeRequest( - 'GET', - (new Uri('http', 'shaarli'))->withPath('/subfolder/path'), - null, - [], - ['REQUEST_URI' => 'http://shaarli/subfolder/path'] - ); + $serverParams = ['REQUEST_URI' => 'http://shaarli/subfolder/path']; + $request = $this->serverRequestFactory + ->createServerRequest('GET', 'http://shaarli/subfolder/path', $serverParams); - $fakeResponse = new SlimResponse(); $dummyException = new class () extends \Exception { }; - $callback = function ($request) use ($dummyException) { - throw $dummyException; - }; + $requestHandler = $this->requestHandlerFactory->createRequestHandler( + function (ServerRequestInterface $request, RequestHandlerInterface $next) use ($dummyException) { + throw $dummyException; + } + ); $pageBuilder = $this->createMock(PageBuilder::class); $pageBuilder->method('render')->willReturnCallback(function (string $message): string { @@ -159,21 +157,22 @@ public function testMiddlewareExecutionWithServerException(): void $this->container->set('pageBuilder', $pageBuilder); $this->expectException(get_class($dummyException)); - ($this->middleware)($request, new FakeRequestHandler($fakeResponse, $callback)); + ($this->middleware)($request, $requestHandler); } public function testMiddlewareExecutionWithUpdates(): void { - $request = new FakeRequest( - 'GET', - (new Uri('http', 'shaarli'))->withPath('/subfolder/path'), - null, - [], - ['REQUEST_URI' => 'http://shaarli/subfolder/path'] + $serverParams = ['REQUEST_URI' => 'http://shaarli/subfolder/path']; + $request = $this->serverRequestFactory + ->createServerRequest('GET', 'http://shaarli/subfolder/path', $serverParams); + + $responseFactory = $this->responseFactory; + $requestHandler = $this->requestHandlerFactory->createRequestHandler( + function (ServerRequestInterface $request, RequestHandlerInterface $next) use ($responseFactory) { + return $responseFactory->createResponse()->withStatus(418); // I'm a tea pot; + } ); - $fakeResponse = (new SlimResponse())->withStatus(418); // I'm a tea pot; - $this->container->set('loginManager', $this->createMock(LoginManager::class)); $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); @@ -199,7 +198,7 @@ public function testMiddlewareExecutionWithUpdates(): void ->with('resource.updates', $updates) ; - $result = ($this->middleware)($request, new FakeRequestHandler($fakeResponse)); + $result = ($this->middleware)($request, $requestHandler); static::assertInstanceOf(Response::class, $result); static::assertSame(418, $result->getStatusCode()); diff --git a/tests/front/controller/admin/ConfigureControllerTest.php b/tests/front/controller/admin/ConfigureControllerTest.php index 2101c20a7..0b9e01a2b 100644 --- a/tests/front/controller/admin/ConfigureControllerTest.php +++ b/tests/front/controller/admin/ConfigureControllerTest.php @@ -10,8 +10,6 @@ use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class ConfigureControllerTest extends TestCase { @@ -22,6 +20,7 @@ class ConfigureControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new ConfigureController($this->container); @@ -35,8 +34,8 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf')->method('get')->willReturnCallback(function (string $key) { @@ -114,12 +113,10 @@ public function testSaveNewConfig(): void 'thumbnails.mode' => $parameters['enableThumbnails'], ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf') @@ -154,8 +151,8 @@ public function testSaveNewConfigWrongToken(): void $this->container->get('conf')->expects(static::never())->method('set'); $this->container->get('conf')->expects(static::never())->method('write'); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->expectException(WrongTokenException::class); @@ -170,12 +167,10 @@ public function testSaveNewConfigThumbnailsActivation(): void $session = []; $this->assignSessionVars($session); - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody(['enableThumbnails' => Thumbnailer::MODE_ALL]); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['enableThumbnails' => Thumbnailer::MODE_ALL]); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $result = $this->controller->save($request, $response); @@ -200,11 +195,9 @@ public function testSaveNewConfigThumbnailsAlreadyActive(): void $session = []; $this->assignSessionVars($session); - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody(['enableThumbnails' => Thumbnailer::MODE_ALL]); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['enableThumbnails' => Thumbnailer::MODE_ALL]); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf') diff --git a/tests/front/controller/admin/ExportControllerTest.php b/tests/front/controller/admin/ExportControllerTest.php index 1c873ce1d..263f9451b 100644 --- a/tests/front/controller/admin/ExportControllerTest.php +++ b/tests/front/controller/admin/ExportControllerTest.php @@ -11,8 +11,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class ExportControllerTest extends TestCase { @@ -23,6 +21,7 @@ class ExportControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new ExportController($this->container); @@ -36,8 +35,8 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->index($request, $response); @@ -60,15 +59,14 @@ public function testExportDefault(): void 'prepend_note_url' => 'on', ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters)->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $bookmarks = [ (new Bookmark())->setUrl('http://link1.tld')->setTitle('Title 1'), @@ -120,8 +118,8 @@ function ( */ public function testExportSelectionMissing(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -144,15 +142,14 @@ public function testExportErrorEncountered(): void 'selection' => 'all', ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters)->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->set('netscapeBookmarkUtils', $this->createMock(NetscapeBookmarkUtils::class)); $this->container->get('netscapeBookmarkUtils') diff --git a/tests/front/controller/admin/ImportControllerTest.php b/tests/front/controller/admin/ImportControllerTest.php index a07179029..703730cae 100644 --- a/tests/front/controller/admin/ImportControllerTest.php +++ b/tests/front/controller/admin/ImportControllerTest.php @@ -9,9 +9,8 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\UploadedFile; -use Slim\Psr7\Uri; +use Slim\Psr7\Factory\StreamFactory; +use Slim\Psr7\Factory\UploadedFileFactory; class ImportControllerTest extends TestCase { @@ -22,6 +21,7 @@ class ImportControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new ImportController($this->container); @@ -35,8 +35,8 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->index($request, $response); @@ -53,19 +53,21 @@ public function testIndex(): void */ public function testImportDefault(): void { + $uploadedFileFactory = new UploadedFileFactory(); + $streamFactory = new StreamFactory(); + $parameters = [ 'abc' => 'def', 'other' => 'param', ]; - $requestFile = new UploadedFile('file', 'name', 'type', 123); + $requestFile = $uploadedFileFactory->createUploadedFile($streamFactory->createStream(), 123); - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody($parameters)->withUploadedFiles(['filetoupload' => $requestFile]); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters) + ->withUploadedFiles(['filetoupload' => $requestFile]); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->set('netscapeBookmarkUtils', $this->createMock(NetscapeBookmarkUtils::class)); $this->container->get('netscapeBookmarkUtils') ->expects(static::once()) @@ -103,8 +105,8 @@ function ( */ public function testImportFileMissing(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -123,13 +125,16 @@ public function testImportFileMissing(): void */ public function testImportEmptyFile(): void { - $requestFile = new UploadedFile('file', 'name', 'type', 0); + $uploadedFileFactory = new UploadedFileFactory(); + $streamFactory = new StreamFactory(); + + $requestFile = $uploadedFileFactory->createUploadedFile( + $streamFactory->createStream('') + ); - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withUploadedFiles(['filetoupload' => $requestFile]); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withUploadedFiles(['filetoupload' => $requestFile]); + $response = $this->responseFactory->createResponse(); $this->container->set('netscapeBookmarkUtils', $this->createMock(NetscapeBookmarkUtils::class)); $this->container->get('netscapeBookmarkUtils')->expects(static::never())->method('filterAndFormat'); diff --git a/tests/front/controller/admin/LogoutControllerTest.php b/tests/front/controller/admin/LogoutControllerTest.php index d1fdb26cf..3c4eaaca6 100644 --- a/tests/front/controller/admin/LogoutControllerTest.php +++ b/tests/front/controller/admin/LogoutControllerTest.php @@ -9,7 +9,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class LogoutControllerTest extends TestCase { @@ -20,6 +19,7 @@ class LogoutControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new LogoutController($this->container); @@ -27,8 +27,8 @@ public function setUp(): void public function testValidControllerInvoke(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('pageCacheManager')->expects(static::once())->method('invalidateCaches'); diff --git a/tests/front/controller/admin/ManageTagControllerTest.php b/tests/front/controller/admin/ManageTagControllerTest.php index cccd0bfcf..782f7d817 100644 --- a/tests/front/controller/admin/ManageTagControllerTest.php +++ b/tests/front/controller/admin/ManageTagControllerTest.php @@ -12,8 +12,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class ManageTagControllerTest extends TestCase { @@ -24,6 +22,7 @@ class ManageTagControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new ManageTagController($this->container); @@ -37,12 +36,9 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery('fromtag=fromtag') - )); - $response = new SlimResponse(); + $query = http_build_query(['fromtag' => 'fromtag']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $result = $this->controller->index($request, $response); @@ -67,8 +63,8 @@ public function testIndexWhitespaceSeparator(): void return $key === 'general.tags_separator' ? ' ' : $key; }); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->controller->index($request, $response); @@ -89,11 +85,9 @@ public function testSaveRenameTagValid(): void 'fromtag' => 'old-tag', 'totag' => 'new-tag', ]; - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody($requestParameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($requestParameters); + $response = $this->responseFactory->createResponse(); $bookmark1 = $this->createMock(Bookmark::class); $bookmark2 = $this->createMock(Bookmark::class); @@ -139,11 +133,9 @@ public function testSaveDeleteTagValid(): void 'deletetag' => 'delete', 'fromtag' => 'old-tag', ]; - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody($requestParameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($requestParameters); + $response = $this->responseFactory->createResponse(); $bookmark1 = $this->createMock(Bookmark::class); $bookmark2 = $this->createMock(Bookmark::class); @@ -187,8 +179,8 @@ public function testSaveWrongToken(): void $this->container->get('conf')->expects(static::never())->method('set'); $this->container->get('conf')->expects(static::never())->method('write'); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->expectException(WrongTokenException::class); @@ -206,11 +198,9 @@ public function testSaveRenameTagMissingFrom(): void $requestParameters = [ 'renametag' => 'rename', ]; - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody($requestParameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($requestParameters); + $response = $this->responseFactory->createResponse(); $result = $this->controller->save($request, $response); @@ -234,11 +224,9 @@ public function testSaveDeleteTagMissingFrom(): void $requestParameters = [ 'deletetag' => 'delete', ]; - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody($requestParameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($requestParameters); + $response = $this->responseFactory->createResponse(); $result = $this->controller->save($request, $response); @@ -263,11 +251,9 @@ public function testSaveRenameTagMissingTo(): void 'renametag' => 'rename', 'fromtag' => 'old-tag' ]; - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody($requestParameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($requestParameters); + $response = $this->responseFactory->createResponse(); $result = $this->controller->save($request, $response); @@ -290,12 +276,10 @@ public function testChangeSeparatorValid(): void $session = []; $this->assignSessionVars($session); - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody(['separator' => $toSeparator]); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['separator' => $toSeparator]); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->get('conf') ->expects(static::once()) @@ -327,11 +311,9 @@ public function testChangeSeparatorInvalidTooLong(): void $session = []; $this->assignSessionVars($session); - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody(['separator' => $toSeparator]); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['separator' => $toSeparator]); + $response = $this->responseFactory->createResponse(); $this->container->get('conf')->expects(static::never())->method('set'); @@ -359,11 +341,9 @@ public function testChangeSeparatorInvalidReservedCharacter(): void $session = []; $this->assignSessionVars($session); - $request = (new FakeRequest( - 'POST', - (new Uri('', '')) - ))->withParsedBody(['separator' => $toSeparator]); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['separator' => $toSeparator]); + $response = $this->responseFactory->createResponse(); $this->container->get('conf')->expects(static::never())->method('set'); diff --git a/tests/front/controller/admin/PasswordControllerTest.php b/tests/front/controller/admin/PasswordControllerTest.php index c9fdceefa..f73328350 100644 --- a/tests/front/controller/admin/PasswordControllerTest.php +++ b/tests/front/controller/admin/PasswordControllerTest.php @@ -10,8 +10,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class PasswordControllerTest extends TestCase { @@ -25,6 +23,7 @@ class PasswordControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->assignTemplateVars($this->assignedVariables); @@ -36,8 +35,8 @@ public function setUp(): void */ public function testGetPage(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->index($request, $response); @@ -51,11 +50,9 @@ public function testGetPage(): void */ public function testPostNewPasswordDefault(): void { - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withParsedBody(['oldpassword' => 'old', 'setpassword' => 'new']); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['oldpassword' => 'old', 'setpassword' => 'new']); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { @@ -88,11 +85,9 @@ public function testPostNewPasswordDefault(): void */ public function testPostNewPasswordWrongOldPassword(): void { - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withParsedBody(['oldpassword' => 'wrong', 'setpassword' => 'new']); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['oldpassword' => 'wrong', 'setpassword' => 'new']); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { @@ -130,8 +125,8 @@ public function testPostNewPasswordWrongToken(): void $this->container->get('conf')->expects(static::never())->method('set'); $this->container->get('conf')->expects(static::never())->method('write'); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->expectException(WrongTokenException::class); @@ -152,11 +147,10 @@ public function testPostNewEmptyPassword(): void $this->container->get('conf')->expects(static::never())->method('set'); $this->container->get('conf')->expects(static::never())->method('write'); - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withParsedBody(['oldpassword' => 'old', 'setpassword' => '']); - $response = new SlimResponse(); + + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['oldpassword' => 'old', 'setpassword' => '']); + $response = $this->responseFactory->createResponse(); $result = $this->controller->change($request, $response); @@ -173,8 +167,8 @@ public function testPostNewPasswordOnOpenShaarli(): void $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf')->method('get')->with('security.open_shaarli')->willReturn(true); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->expectException(OpenShaarliPasswordException::class); diff --git a/tests/front/controller/admin/PluginsControllerTest.php b/tests/front/controller/admin/PluginsControllerTest.php index 74f879c9b..6f839f348 100644 --- a/tests/front/controller/admin/PluginsControllerTest.php +++ b/tests/front/controller/admin/PluginsControllerTest.php @@ -10,8 +10,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class PluginsControllerTest extends TestCase { @@ -24,6 +22,7 @@ class PluginsControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new PluginsController($this->container); @@ -52,8 +51,8 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $data = [ 'plugin1' => ['order' => 2, 'other' => 'field'], @@ -94,11 +93,9 @@ public function testSaveEnabledPlugins(): void 'plugin2' => 'on', ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('pluginManager') ->expects(static::once()) @@ -129,11 +126,9 @@ public function testSavePluginParameters(): void 'token' => 'this parameter should not be saved' ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('pluginManager') ->expects(static::once()) @@ -157,8 +152,8 @@ public function testSavePluginParameters(): void */ public function testSaveWithError(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf') @@ -192,8 +187,8 @@ public function testSaveWrongToken(): void $this->container->set('sessionManager', $this->createMock(SessionManager::class)); $this->container->get('sessionManager')->method('checkToken')->willReturn(false); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->expectException(WrongTokenException::class); diff --git a/tests/front/controller/admin/ServerControllerTest.php b/tests/front/controller/admin/ServerControllerTest.php index 6c7b99ae2..00bf2a28c 100644 --- a/tests/front/controller/admin/ServerControllerTest.php +++ b/tests/front/controller/admin/ServerControllerTest.php @@ -8,8 +8,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; /** * Test Server administration controller. @@ -23,6 +21,7 @@ class ServerControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new ServerController($this->container); @@ -52,12 +51,13 @@ public function tearDown(): void */ public function testIndex(): void { - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'REMOTE_ADDR' => '1.2.3.4', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -112,11 +112,9 @@ public function testClearMainCache(): void ->with(SessionManager::KEY_SUCCESS_MESSAGES, ['Shaarli\'s cache folder has been cleared!']) ; - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery('type=main') - )); - $response = new SlimResponse(); + $query = http_build_query(['type' => 'main']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $result = $this->controller->clearCache($request, $response); @@ -166,11 +164,9 @@ public function testClearThumbnailsCache(): void }); ; - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery('type=thumbnails') - )); - $response = new SlimResponse(); + $query = http_build_query(['type' => 'thumbnails']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $result = $this->controller->clearCache($request, $response); diff --git a/tests/front/controller/admin/SessionFilterControllerTest.php b/tests/front/controller/admin/SessionFilterControllerTest.php index 8d7a8199d..0be72857c 100644 --- a/tests/front/controller/admin/SessionFilterControllerTest.php +++ b/tests/front/controller/admin/SessionFilterControllerTest.php @@ -9,7 +9,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class SessionFilterControllerTest extends TestCase { @@ -20,6 +19,7 @@ class SessionFilterControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new SessionFilterController($this->container); @@ -39,12 +39,13 @@ public function testVisibility(): void ->with(SessionManager::KEY_VISIBILITY, 'private') ; - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->visibility($request, $response, $arg); @@ -76,13 +77,13 @@ public function testVisibilityToggleOff(): void ->with(SessionManager::KEY_VISIBILITY) ; - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli' - ]); - $response = new SlimResponse(); - + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->visibility($request, $response, $arg); static::assertInstanceOf(Response::class, $result); @@ -109,8 +110,8 @@ public function testVisibilitySwitch(): void ->with(SessionManager::KEY_VISIBILITY, 'private') ; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->visibility($request, $response, $arg); @@ -137,12 +138,13 @@ public function testVisibilityInvalidValue(): void ->with(SessionManager::KEY_VISIBILITY) ; - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->visibility($request, $response, $arg); @@ -170,12 +172,13 @@ public function testVisibilityLoggedOut(): void ->with(SessionManager::KEY_VISIBILITY) ; - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->visibility($request, $response, $arg); diff --git a/tests/front/controller/admin/ShaareAddControllerTest.php b/tests/front/controller/admin/ShaareAddControllerTest.php index e4638af7a..b5e95f3a8 100644 --- a/tests/front/controller/admin/ShaareAddControllerTest.php +++ b/tests/front/controller/admin/ShaareAddControllerTest.php @@ -9,7 +9,6 @@ use Shaarli\Http\HttpAccess; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class ShaareAddControllerTest extends TestCase { @@ -20,6 +19,7 @@ class ShaareAddControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -34,8 +34,8 @@ public function testAddShaare(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $expectedTags = [ 'tag1' => 32, @@ -73,8 +73,8 @@ public function testAddShaareWithoutMd(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $expectedTags = [ 'tag1' => 32, diff --git a/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php b/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php index 73547fffe..e1f0441ce 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/AddOrDeleteTagTest.php @@ -14,8 +14,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class AddOrDeleteTagTest extends TestCase { @@ -26,6 +24,7 @@ class AddOrDeleteTagTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -39,12 +38,10 @@ public function testAddOneTagOnOneBookmark(): void { $parameters = ['id' => '123', 'tag' => 'newtag', 'action' => 'add']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark()) ->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setTagsString('first second'); @@ -88,12 +85,10 @@ public function testAddTwoTagsOnTwoBookmarks(): void { $parameters = ['id' => '123 456', 'tag' => 'newtag@othertag', 'action' => 'add']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $bookmark1 = (new Bookmark()) ->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setTagsString('first second'); @@ -142,11 +137,9 @@ public function testDeleteOneTagOnOneBookmark(): void { $parameters = ['id' => '123', 'tag' => 'second', 'action' => 'delete']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark()) ->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setTagsString('first second third'); @@ -189,11 +182,9 @@ public function testDeleteTwoTagOnTwoBookmarks(): void { $parameters = ['id' => '123 456', 'tag' => 'second@first', 'action' => 'delete']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $bookmark1 = (new Bookmark()) ->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setTagsString('first second third other'); @@ -242,11 +233,9 @@ public function testDeleteTwoTagOnTwoBookmarks(): void public function testAddTagWithoutId(): void { $parameters = ['tag' => 'newtag', 'action' => 'add']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -266,11 +255,9 @@ public function testAddTagWithoutId(): void public function testDeleteTagWithoutId(): void { $parameters = ['tag' => 'newtag', 'action' => 'delete']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -290,11 +277,9 @@ public function testDeleteTagWithoutId(): void public function testAddTagWithoutAction(): void { $parameters = ['id' => '123', 'tag' => 'newtag']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -314,11 +299,9 @@ public function testAddTagWithoutAction(): void public function testAddTagWithoutValue(): void { $parameters = ['id' => '123', 'tag' => '', 'action' => 'add']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -338,11 +321,9 @@ public function testAddTagWithoutValue(): void public function testDeleteTagWithoutValue(): void { $parameters = ['id' => '123', 'tag' => '', 'action' => 'delete']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) diff --git a/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php b/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php index 62b9ac35c..98a407c30 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/ChangeVisibilityBookmarkTest.php @@ -15,8 +15,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class ChangeVisibilityBookmarkTest extends TestCase { @@ -27,6 +25,7 @@ class ChangeVisibilityBookmarkTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -41,12 +40,8 @@ public function testSetSingleBookmarkPrivate(): void $parameters = ['id' => '123', 'newVisibility' => 'private']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setPrivate(false); @@ -90,12 +85,8 @@ public function testSetSingleBookmarkPublic(): void $parameters = ['id' => '123', 'newVisibility' => 'public']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(true); @@ -136,12 +127,11 @@ public function testSetSinglePrivateBookmarkPrivate(): void $parameters = ['id' => '123', 'newVisibility' => 'private']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query) + + + ; + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') ->setPrivate(true); @@ -183,12 +173,8 @@ public function testSetMultipleBookmarksPrivate(): void $parameters = ['id' => '123 456 789', 'newVisibility' => 'private']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $bookmarks = [ (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(false), @@ -243,12 +229,8 @@ public function testChangeVisibilitySingleBookmarkNotFound(): void $parameters = ['id' => '123', 'newVisibility' => 'private']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) @@ -286,12 +268,8 @@ public function testChangeVisibilityMultipleBookmarksOneNotFound(): void $parameters = ['id' => '123 456 789', 'newVisibility' => 'public']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $bookmarks = [ (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123')->setPrivate(true), @@ -348,12 +326,8 @@ public function testChangeVisibilityInvalidId(): void $parameters = ['id' => 'nope not an ID', 'newVisibility' => 'private']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -372,8 +346,8 @@ public function testChangeVisibilityInvalidId(): void */ public function testChangeVisibilityEmptyId(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -395,12 +369,8 @@ public function testChangeVisibilityWithInvalidVisibility(): void $parameters = ['id' => '123', 'newVisibility' => 'invalid']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) diff --git a/tests/front/controller/admin/ShaareManageControllerTest/DeleteBookmarkTest.php b/tests/front/controller/admin/ShaareManageControllerTest/DeleteBookmarkTest.php index cc2bc7e7f..f4a5d433d 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/DeleteBookmarkTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/DeleteBookmarkTest.php @@ -14,8 +14,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class DeleteBookmarkTest extends TestCase { @@ -26,6 +24,7 @@ class DeleteBookmarkTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -40,12 +39,8 @@ public function testDeleteSingleBookmark(): void $parameters = ['id' => '123']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123'); @@ -92,17 +87,14 @@ public function testDeleteMultipleBookmarks(): void $parameters = ['id' => '123 456 789']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('http', 'shaarli', 80, '/subfolder', '')) - ->withQuery($query) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'HTTP_REFERER' => 'http://shaarli/subfolder/?searchtags=abcdef', 'SCRIPT_NAME' => '/subfolder/index.php', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); $bookmarks = [ (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123'), @@ -168,12 +160,8 @@ public function testDeleteSingleBookmarkNotFound(): void $parameters = ['id' => '123']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) @@ -216,12 +204,8 @@ public function testDeleteMultipleBookmarksOneNotFound(): void $parameters = ['id' => '123 456 789']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $bookmarks = [ (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123'), @@ -300,12 +284,8 @@ public function testDeleteInvalidId(): void $parameters = ['id' => 'nope not an ID']; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -324,8 +304,8 @@ public function testDeleteInvalidId(): void */ public function testDeleteEmptyId(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -350,12 +330,8 @@ public function testDeleteBookmarkFromBookmarklet(): void ]; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService')->method('get')->with('123')->willReturn( (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') @@ -391,12 +367,8 @@ public function testDeleteBookmarkFromBatch(): void ]; $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService')->method('get')->with('123')->willReturn( (new Bookmark())->setId(123)->setUrl('http://domain.tld')->setTitle('Title 123') diff --git a/tests/front/controller/admin/ShaareManageControllerTest/PinBookmarkTest.php b/tests/front/controller/admin/ShaareManageControllerTest/PinBookmarkTest.php index 3f2db16a1..b60541644 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/PinBookmarkTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/PinBookmarkTest.php @@ -12,7 +12,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class PinBookmarkTest extends TestCase { @@ -23,6 +22,7 @@ class PinBookmarkTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -38,8 +38,8 @@ public function testPinBookmarkIsStickyNull(?bool $sticky, bool $expectedValue): { $id = 123; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark()) ->setId(123) @@ -80,8 +80,8 @@ public function testDisplayEditFormInvalidId(): void { $id = 'invalid'; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -100,8 +100,8 @@ public function testDisplayEditFormInvalidId(): void */ public function testDisplayEditFormIdNotProvided(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -122,8 +122,8 @@ public function testDisplayEditFormBookmarkNotFound(): void { $id = 123; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) diff --git a/tests/front/controller/admin/ShaareManageControllerTest/SharePrivateTest.php b/tests/front/controller/admin/ShaareManageControllerTest/SharePrivateTest.php index 1595ee712..b2d558beb 100644 --- a/tests/front/controller/admin/ShaareManageControllerTest/SharePrivateTest.php +++ b/tests/front/controller/admin/ShaareManageControllerTest/SharePrivateTest.php @@ -10,7 +10,6 @@ use Shaarli\Http\HttpAccess; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; /** * Test GET /admin/shaare/private/{hash} @@ -24,6 +23,7 @@ class SharePrivateTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -36,8 +36,8 @@ public function setUp(): void public function testSharePrivateWithNewPrivateBookmark(): void { $hash = 'abcdcef'; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark()) ->setId(123) @@ -76,8 +76,8 @@ public function testSharePrivateWithExistingPrivateBookmark(): void { $hash = 'abcdcef'; $existingKey = 'this is a private key'; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark()) ->setId(123) @@ -110,8 +110,8 @@ public function testSharePrivateWithExistingPrivateBookmark(): void public function testSharePrivateWithPublicBookmark(): void { $hash = 'abcdcef'; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark()) ->setId(123) diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateBatchFormTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateBatchFormTest.php index a0ccc521f..6f8d6f3f1 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateBatchFormTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateBatchFormTest.php @@ -10,8 +10,6 @@ use Shaarli\Http\MetadataRetriever; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class DisplayCreateBatchFormTest extends TestCase { @@ -22,6 +20,7 @@ class DisplayCreateBatchFormTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -41,11 +40,9 @@ public function testDisplayCreateFormBatch(): void 'https://domain3.tld/url3', ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody(['urls' => implode(PHP_EOL, $urls)]); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['urls' => implode(PHP_EOL, $urls)]); + $response = $this->responseFactory->createResponse(); $assignedVariables = []; $this->assignTemplateVars($assignedVariables); diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateFormTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateFormTest.php index eb28f7adf..3d59519ce 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateFormTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayCreateFormTest.php @@ -12,8 +12,6 @@ use Shaarli\Http\MetadataRetriever; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class DisplayCreateFormTest extends TestCase { @@ -24,6 +22,7 @@ class DisplayCreateFormTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -47,18 +46,14 @@ public function testDisplayCreateFormWithUrlAndWithMetadataRetrieval(): void $remoteTags = 'abc def'; $referer = 'http://shaarli/subfolder/controller/?searchtag=abc'; - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery('post=' . urlencode($url)) - ))->withServerParams([ - 'HTTP_REFERER' => $referer - ]); + $query = http_build_query(['post' => $url]); + $serverParams = ['HTTP_REFERER' => $referer]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); /*$request->method('getParam')->willReturnCallback(function (string $key) use ($url): ?string { return $key === 'post' ? $url : null; });*/ - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf')->method('get')->willReturnCallback(function (string $param, $default) { @@ -131,15 +126,11 @@ public function testDisplayCreateFormWithUrlAndWithoutMetadata(): void $referer = 'http://shaarli/subfolder/controller/?searchtag=abc'; $expectedUrl = str_replace('&utm_ad=pay', '', $url); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery('post=' . urlencode($url)) - ))->withServerParams([ - 'HTTP_REFERER' => $referer - ]); + $query = http_build_query(['post' => $url]); + $serverParams = ['HTTP_REFERER' => $referer]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->get('metadataRetriever')->expects(static::never())->method('retrieve'); @@ -206,12 +197,8 @@ public function testDisplayCreateFormWithFullParameters(): void $expectedUrl = str_replace('&utm_ad=pay', '', $parameters['post']); $query = http_build_query($parameters); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery($query) - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $result = $this->controller->displayCreateForm($request, $response); @@ -238,8 +225,8 @@ public function testDisplayCreateFormEmpty(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('httpAccess')->expects(static::never())->method('getHttpResponse'); $this->container->get('httpAccess')->expects(static::never())->method('getCurlDownloadCallback'); @@ -266,13 +253,9 @@ public function testDisplayCreateFormNotHttp(): void $this->assignTemplateVars($assignedVariables); $url = 'magnet://kubuntu.torrent'; - $request = new FakeRequest(); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery('post=' . urlencode($url)) - )); - $response = new SlimResponse(); + $query = http_build_query(['post' => $url]); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('httpAccess')->expects(static::never())->method('getHttpResponse'); $this->container->get('httpAccess')->expects(static::never())->method('getCurlDownloadCallback'); @@ -306,8 +289,8 @@ public function testDisplayCreateFormWithMarkdownEnabled(): void }) ; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->displayCreateForm($request, $response); @@ -328,12 +311,9 @@ public function testDisplayCreateFormWithExistingUrl(): void $url = 'http://url.tld/other?part=3&utm_ad=pay#hash'; $expectedUrl = str_replace('&utm_ad=pay', '', $url); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ->withQuery('post=' . urlencode($url)) - )); - $response = new SlimResponse(); + $query = http_build_query(['post' => $url]); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('httpAccess')->expects(static::never())->method('getHttpResponse'); $this->container->get('httpAccess')->expects(static::never())->method('getCurlDownloadCallback'); diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayEditFormTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayEditFormTest.php index b40c5517c..ad412cbd5 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/DisplayEditFormTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/DisplayEditFormTest.php @@ -12,7 +12,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class DisplayEditFormTest extends TestCase { @@ -23,6 +22,7 @@ class DisplayEditFormTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -40,8 +40,8 @@ public function testDisplayEditFormDefault(): void $id = 11; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('httpAccess')->expects(static::never())->method('getHttpResponse'); $this->container->get('httpAccess')->expects(static::never())->method('getCurlDownloadCallback'); @@ -87,8 +87,8 @@ public function testDisplayEditFormInvalidId(): void { $id = 'invalid'; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -108,8 +108,8 @@ public function testDisplayEditFormInvalidId(): void */ public function testDisplayEditFormIdNotProvided(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -131,8 +131,8 @@ public function testDisplayEditFormBookmarkNotFound(): void { $id = 123; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) diff --git a/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php b/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php index f096dc626..b6fa18540 100644 --- a/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php +++ b/tests/front/controller/admin/ShaarePublishControllerTest/SaveBookmarkTest.php @@ -14,8 +14,6 @@ use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class SaveBookmarkTest extends TestCase { @@ -26,6 +24,7 @@ class SaveBookmarkTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('httpAccess', $this->createMock(HttpAccess::class)); @@ -47,12 +46,10 @@ public function testSaveBookmark(): void 'returnurl' => 'http://shaarli/subfolder/admin/add-shaare' ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters) - ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); - $response = new SlimResponse(); + $serverParams = ['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $checkBookmark = function (Bookmark $bookmark) use ($parameters) { static::assertSame($parameters['lf_url'], $bookmark->getUrl()); @@ -131,12 +128,10 @@ public function testSaveExistingBookmark(): void 'returnurl' => 'http://shaarli/subfolder/?page=2' ]; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters) - ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); - $response = new SlimResponse(); + $serverParams = ['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $checkBookmark = function (Bookmark $bookmark) use ($parameters, $id) { static::assertSame($id, $bookmark->getId()); @@ -210,13 +205,11 @@ public function testSaveBookmarkWithThumbnailSync(): void { $parameters = ['lf_url' => 'http://url.tld/other?part=3#hash']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters) - ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); + $serverParams = ['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { @@ -259,12 +252,10 @@ public function testSaveBookmarkWithIdZero(): void { $parameters = ['lf_id' => '0']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters) - ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); - $response = new SlimResponse(); + $serverParams = ['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService')->expects(static::once())->method('exists')->with(0)->willReturn(true); $this->container->get('bookmarkService')->expects(static::once())->method('get')->with(0) @@ -282,12 +273,10 @@ public function testSaveBookmarkWithThumbnailAsync(): void { $parameters = ['lf_url' => 'http://url.tld/other?part=3#hash']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters) - ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); - $response = new SlimResponse(); + $serverParams = ['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $default) { @@ -325,12 +314,10 @@ public function testSaveBookmarkFromBookmarklet(): void { $parameters = ['source' => 'bookmarklet']; - $request = (new FakeRequest( - 'POST', - new Uri('', '', 80, '') - ))->withParsedBody($parameters) - ->withServerParams(['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']); - $response = new SlimResponse(); + $serverParams = ['SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli']; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $result = $this->controller->save($request, $response); @@ -349,8 +336,8 @@ public function testSaveBookmarkWrongToken(): void $this->container->get('bookmarkService')->expects(static::never())->method('addOrSet'); $this->container->get('bookmarkService')->expects(static::never())->method('set'); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->expectException(WrongTokenException::class); diff --git a/tests/front/controller/admin/ShaarliAdminControllerTest.php b/tests/front/controller/admin/ShaarliAdminControllerTest.php index b3d96c168..367be1399 100644 --- a/tests/front/controller/admin/ShaarliAdminControllerTest.php +++ b/tests/front/controller/admin/ShaarliAdminControllerTest.php @@ -25,6 +25,7 @@ class ShaarliAdminControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new class ($this->container) extends ShaarliAdminController @@ -58,9 +59,8 @@ public function testCheckTokenWithValidToken(): void { $token = '12345'; - $request = (new FakeRequest())->withParsedBody([ - 'token' => $token - ]); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['token' => $token]); $this->container->set('sessionManager', $this->createMock(SessionManager::class)); $this->container->get('sessionManager')->method('checkToken')->with($token)->willReturn(true); @@ -75,9 +75,8 @@ public function testCheckTokenWithNotValidToken(): void { $token = '12345'; - $request = (new FakeRequest())->withParsedBody([ - 'token' => $token - ]); + $request = $this->requestFactory->createRequest('POST', 'http://shaarli') + ->withParsedBody(['token' => $token]); $this->container->set('sessionManager', $this->createMock(SessionManager::class)); $this->container->get('sessionManager')->method('checkToken')->with($token)->willReturn(false); diff --git a/tests/front/controller/admin/ThumbnailsControllerTest.php b/tests/front/controller/admin/ThumbnailsControllerTest.php index b4660f3ac..f3a81824b 100644 --- a/tests/front/controller/admin/ThumbnailsControllerTest.php +++ b/tests/front/controller/admin/ThumbnailsControllerTest.php @@ -10,7 +10,6 @@ use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Psr7\Response as SlimResponse; class ThumbnailsControllerTest extends TestCase { @@ -21,6 +20,7 @@ class ThumbnailsControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new ThumbnailsController($this->container); @@ -35,8 +35,8 @@ public function testIndex(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) @@ -63,8 +63,8 @@ public function testIndex(): void */ public function testAjaxUpdateValid(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $bookmark = (new Bookmark()) ->setId($id = 123) @@ -113,8 +113,8 @@ public function testAjaxUpdateValid(): void */ public function testAjaxUpdateInvalidId(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->ajaxUpdate($request, $response, ['id' => 'nope']); @@ -126,8 +126,8 @@ public function testAjaxUpdateInvalidId(): void */ public function testAjaxUpdateNoId(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->ajaxUpdate($request, $response, []); @@ -140,8 +140,8 @@ public function testAjaxUpdateNoId(): void public function testAjaxUpdateBookmarkNotFound(): void { $id = 123; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) diff --git a/tests/front/controller/admin/TokenControllerTest.php b/tests/front/controller/admin/TokenControllerTest.php index 40c69dcea..0b5e552bf 100644 --- a/tests/front/controller/admin/TokenControllerTest.php +++ b/tests/front/controller/admin/TokenControllerTest.php @@ -6,7 +6,6 @@ use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class TokenControllerTest extends TestCase { @@ -17,6 +16,7 @@ class TokenControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new TokenController($this->container); @@ -24,8 +24,8 @@ public function setUp(): void public function testGetToken(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) diff --git a/tests/front/controller/admin/ToolsControllerTest.php b/tests/front/controller/admin/ToolsControllerTest.php index ce1902af1..4442d24a8 100644 --- a/tests/front/controller/admin/ToolsControllerTest.php +++ b/tests/front/controller/admin/ToolsControllerTest.php @@ -6,7 +6,6 @@ use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class ToolsControllerTest extends TestCase { @@ -17,6 +16,7 @@ class ToolsControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new ToolsController($this->container); @@ -24,12 +24,13 @@ public function setUp(): void public function testDefaultInvokeWithHttps(): void { - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', 'SERVER_PORT' => 443, 'HTTPS' => 'on', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -45,11 +46,12 @@ public function testDefaultInvokeWithHttps(): void public function testDefaultInvokeWithoutHttps(): void { - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => 80 - ]); - $response = new SlimResponse(); + 'SERVER_PORT' => 80, + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; diff --git a/tests/front/controller/visitor/BookmarkListControllerTest.php b/tests/front/controller/visitor/BookmarkListControllerTest.php index 3f24969f0..4c25b32d0 100644 --- a/tests/front/controller/visitor/BookmarkListControllerTest.php +++ b/tests/front/controller/visitor/BookmarkListControllerTest.php @@ -12,8 +12,6 @@ use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class BookmarkListControllerTest extends TestCase { @@ -24,6 +22,7 @@ class BookmarkListControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new BookmarkListController($this->container); @@ -37,11 +36,12 @@ public function testIndexDefaultFirstPage(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) @@ -108,14 +108,13 @@ public function testIndexDefaultSecondPage(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery('page=2') - ))->withServerParams([ + $query = http_build_query(['page' => 2]); + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) @@ -177,17 +176,14 @@ public function testIndexDefaultWithFilters(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery( - http_build_query(['searchtags' => 'abc@def', 'searchterm' => 'ghi jkl']) - ) - ))->withServerParams([ + $query = http_build_query(['searchtags' => 'abc@def', 'searchterm' => 'ghi jkl']); + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', - ]); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->method('getSessionParameter') @@ -243,14 +239,12 @@ public function testPermalinkValid(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) @@ -284,8 +278,8 @@ public function testPermalinkNotFound(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) @@ -316,14 +310,13 @@ public function testPermalinkWithPrivateKey(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query(['key' => $privateKey])) - ))->withServerParams([ + $query = http_build_query(['key' => $privateKey]); + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once()) @@ -345,14 +338,12 @@ public function testPermalinkWithPrivateKey(): void */ public function testThumbnailUpdateFromLinkList(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->set('loginManager', $this->createMock(LoginManager::class)); $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); @@ -407,14 +398,12 @@ public function testThumbnailUpdateFromLinkList(): void */ public function testThumbnailUpdateFromPermalink(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->set('loginManager', $this->createMock(LoginManager::class)); $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); @@ -456,14 +445,12 @@ public function testThumbnailUpdateFromPermalink(): void */ public function testThumbnailUpdateFromPermalinkAsync(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->set('loginManager', $this->createMock(LoginManager::class)); $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); @@ -504,15 +491,11 @@ public function testThumbnailUpdateFromPermalinkAsync(): void public function testLegacyControllerPermalink(): void { $hash = 'abcdef'; - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ))->withServerParams([ - 'SERVER_PORT' => 80, - 'SERVER_NAME' => 'shaarli', + $serverParams = [ 'QUERY_STRING' => $hash, - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->index($request, $response); @@ -525,14 +508,13 @@ public function testLegacyControllerPermalink(): void */ public function testLegacyControllerDoPage(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query(['do' => 'picwall'])) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, - 'SERVER_NAME' => 'shaarli' - ]); - $response = new SlimResponse(); + 'SERVER_NAME' => 'shaarli', + ]; + $query = http_build_query(['do' => 'picwall']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->index($request, $response); @@ -545,14 +527,13 @@ public function testLegacyControllerDoPage(): void */ public function testLegacyControllerUnknownDoPage(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query(['do' => 'nope'])) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, - 'SERVER_NAME' => 'shaarli' - ]); - $response = new SlimResponse(); + 'SERVER_NAME' => 'shaarli', + ]; + $query = http_build_query(['do' => 'nope']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->index($request, $response); @@ -566,14 +547,13 @@ public function testLegacyControllerUnknownDoPage(): void public function testLegacyControllerGetParameter(): void { $url = 'http://url.tld'; - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query(['post' => $url])) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, - 'SERVER_NAME' => 'shaarli' - ]); - $response = new SlimResponse(); + 'SERVER_NAME' => 'shaarli', + ]; + $query = http_build_query(['post' => $url]); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->set('loginManager', $this->createMock(LoginManager::class)); $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); diff --git a/tests/front/controller/visitor/DailyControllerTest.php b/tests/front/controller/visitor/DailyControllerTest.php index 8922448b4..48386fa91 100644 --- a/tests/front/controller/visitor/DailyControllerTest.php +++ b/tests/front/controller/visitor/DailyControllerTest.php @@ -9,8 +9,6 @@ use Shaarli\Feed\CachedPage; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class DailyControllerTest extends TestCase { @@ -21,6 +19,7 @@ class DailyControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); setlocale(LC_TIME, 'en_US.UTF-8'); $this->createContainer(); @@ -34,13 +33,9 @@ public function testValidIndexControllerInvokeDefault(): void $previousDate = new \DateTime('2 days ago 00:00:00'); $nextDate = new \DateTime('today 00:00:00'); - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query( - ['day' => $currentDay->format('Ymd')] - )) - )); - $response = new SlimResponse(); + $query = http_build_query(['day' => $currentDay->format('Ymd')]); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -179,13 +174,9 @@ public function testValidIndexControllerInvokeNoFutureOrPast(): void { $currentDay = new \DateTimeImmutable('2020-05-13'); - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query( - ['day' => $currentDay->format('Ymd')] - )) - )); - $response = new SlimResponse(); + $query = http_build_query(['day' => $currentDay->format('Ymd')]); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -247,8 +238,8 @@ public function testValidIndexControllerInvokeHeightAdjustment(): void { $currentDay = new \DateTimeImmutable('2020-05-13'); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -306,8 +297,8 @@ public function testValidIndexControllerInvokeHeightAdjustment(): void */ public function testValidIndexControllerInvokeNoBookmark(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -353,13 +344,14 @@ public function testValidRssControllerInvokeDefault(): void new \DateTimeImmutable('+1 month'), ]; - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', 'REQUEST_URI' => '/subfolder/daily-rss', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService')->expects(static::once())->method('search')->willReturn( SearchResult::getSearchResult([ @@ -442,13 +434,14 @@ public function testValidRssControllerInvokeDefault(): void */ public function testValidRssControllerInvokeTriggerCache(): void { - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', 'REQUEST_URI' => '/subfolder/daily-rss', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('pageCacheManager')->method('getCachePage')->willReturnCallback(function (): CachedPage { $cachedPage = $this->createMock(CachedPage::class); @@ -471,13 +464,14 @@ public function testValidRssControllerInvokeTriggerCache(): void */ public function testValidRssControllerInvokeNoBookmark(): void { - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', 'REQUEST_URI' => '/subfolder/daily-rss', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService') ->expects(static::once())->method('search') @@ -507,16 +501,15 @@ public function testSimpleIndexWeekly(): void $currentDay = new \DateTimeImmutable('2020-05-13'); $expectedDay = new \DateTimeImmutable('2020-05-11'); - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query(['week' => $currentDay->format('YW')])) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', 'REQUEST_URI' => '/subfolder/daily-rss', - ]); - $response = new SlimResponse(); + ]; + $query = http_build_query(['week' => $currentDay->format('YW')]); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -572,16 +565,15 @@ public function testSimpleIndexMonthly(): void $currentDay = new \DateTimeImmutable('2020-05-13'); $expectedDay = new \DateTimeImmutable('2020-05-01'); - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query(['month' => $currentDay->format('Ym')])) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', 'REQUEST_URI' => '/subfolder/daily-rss', - ]); - $response = new SlimResponse(); + ]; + $query = http_build_query(['month' => $currentDay->format('Ym')]); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -643,17 +635,16 @@ public function testSimpleRssWeekly(): void new \DateTimeImmutable('2020-05-17 23:59:59'), ]; - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query(['week' => ''])) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', 'REQUEST_URI' => '/subfolder/daily-rss', 'QUERY_STRING' => 'week', - ]); - $response = new SlimResponse(); + ]; + $query = http_build_query(['week' => '']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService')->expects(static::once())->method('search')->willReturn( SearchResult::getSearchResult([ @@ -711,17 +702,16 @@ public function testSimpleRssMonthly(): void new \DateTimeImmutable('2020-04-30 23:59:59'), ]; - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query(['month' => ''])) - ))->withServerParams([ + $serverParams = [ 'SERVER_PORT' => 80, 'SERVER_NAME' => 'shaarli', 'SCRIPT_NAME' => '/subfolder/index.php', 'REQUEST_URI' => '/subfolder/daily-rss', 'QUERY_STRING' => 'month', - ]); - $response = new SlimResponse(); + ]; + $query = http_build_query(['month' => '']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('bookmarkService')->expects(static::once())->method('search')->willReturn( SearchResult::getSearchResult([ diff --git a/tests/front/controller/visitor/FeedControllerTest.php b/tests/front/controller/visitor/FeedControllerTest.php index 3e6a6bc94..339ed6dc3 100644 --- a/tests/front/controller/visitor/FeedControllerTest.php +++ b/tests/front/controller/visitor/FeedControllerTest.php @@ -7,8 +7,6 @@ use Shaarli\Feed\FeedBuilder; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class FeedControllerTest extends TestCase { @@ -19,6 +17,7 @@ class FeedControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('feedBuilder', $this->createMock(FeedBuilder::class)); @@ -31,11 +30,12 @@ public function setUp(): void */ public function testDefaultRssController(): void { - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', 'SERVER_PORT' => 80, - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('feedBuilder')->expects(static::once())->method('setLocale'); $this->container->get('feedBuilder')->expects(static::once())->method('setHideDates')->with(false); @@ -75,11 +75,12 @@ public function testDefaultRssController(): void */ public function testDefaultAtomController(): void { - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', 'SERVER_PORT' => 80, - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('feedBuilder')->expects(static::once())->method('setLocale'); $this->container->get('feedBuilder')->expects(static::once())->method('setHideDates')->with(false); @@ -119,15 +120,13 @@ public function testDefaultAtomController(): void */ public function testAtomControllerWithParameters(): void { - $request = new FakeRequest(); - $request = (new FakeRequest('GET', (new Uri('', '')) - ->withQuery(http_build_query(['parameter' => 'value'])))) - ->withServerParams([ - 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', - ]); - $response = new SlimResponse(); - + $serverParams = [ + 'SERVER_NAME' => 'shaarli', + 'SERVER_PORT' => 80, + ]; + $query = http_build_query(['parameter' => 'value']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; $this->assignTemplateVars($assignedVariables); diff --git a/tests/front/controller/visitor/InstallControllerTest.php b/tests/front/controller/visitor/InstallControllerTest.php index 3a5be9253..aaded2799 100644 --- a/tests/front/controller/visitor/InstallControllerTest.php +++ b/tests/front/controller/visitor/InstallControllerTest.php @@ -9,7 +9,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class InstallControllerTest extends TestCase { @@ -22,6 +21,8 @@ class InstallControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('conf', $this->createMock(ConfigManager::class)); @@ -52,8 +53,8 @@ public function testInstallIndexWithValidSession(): void $assignedVariables = []; $this->assignTemplateVars($assignedVariables); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->set('sessionManager', $this->createMock(SessionManager::class)); $this->container->get('sessionManager') @@ -107,8 +108,8 @@ public function testInstallWithExistingConfigFile(): void */ public function testInstallRedirectToSessionTest(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->set('sessionManager', $this->createMock(SessionManager::class)); $this->container->get('sessionManager') @@ -128,8 +129,8 @@ public function testInstallRedirectToSessionTest(): void */ public function testInstallSessionTestValid(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->set('sessionManager', $this->createMock(SessionManager::class)); $this->container->get('sessionManager') @@ -152,8 +153,8 @@ public function testInstallSessionTestError(): void $assignedVars = []; $this->assignTemplateVars($assignedVars); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->set('sessionManager', $this->createMock(SessionManager::class)); $this->container->get('sessionManager') @@ -201,8 +202,10 @@ public function testSaveInstallValid(): void 'general.header_link' => '/subfolder', ]; - $request = (new FakeRequest('POST'))->withParsedBody(($providedParameters)); - $response = new SlimResponse(); + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli') + ->withParsedBody(($providedParameters)); + + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf') @@ -250,8 +253,8 @@ public function testSaveInstallDefaultValues(): void { $confSettings = []; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('conf')->method('set') ->willReturnCallback(function (string $key, $value) use (&$confSettings) { @@ -276,7 +279,7 @@ public function testSaveInstallDefaultValuesWithoutSubfolder(): void $this->container->set('environment', [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'REQUEST_URI' => '/install', 'REMOTE_ADDR' => '1.2.3.4', 'SCRIPT_NAME' => '/index.php', @@ -284,8 +287,8 @@ public function testSaveInstallDefaultValuesWithoutSubfolder(): void $this->container->set('basePath', ''); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('conf')->method('set') ->willReturnCallback(function (string $key, $value) use (&$confSettings) { diff --git a/tests/front/controller/visitor/LoginControllerTest.php b/tests/front/controller/visitor/LoginControllerTest.php index b648cf689..aa856563d 100644 --- a/tests/front/controller/visitor/LoginControllerTest.php +++ b/tests/front/controller/visitor/LoginControllerTest.php @@ -13,8 +13,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class LoginControllerTest extends TestCase { @@ -25,6 +23,7 @@ class LoginControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->container->set('cookieManager', $this->createMock(CookieManager::class)); @@ -38,13 +37,9 @@ public function setUp(): void */ public function testValidControllerInvoke(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query( - ['returnurl' => '> referer'] - )) - )); - $response = new SlimResponse(); + $query = http_build_query(['returnurl' => '> referer']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $assignedVariables = []; $this->container->get('pageBuilder') @@ -75,14 +70,11 @@ public function testValidControllerInvoke(): void public function testValidControllerInvokeWithUserName(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query( - ['login' => 'myUser>'] - )) - ))->withServerParams(['HTTP_REFERER' => '> referer']); + $serverParams = ['HTTP_REFERER' => '> referer']; + $query = http_build_query(['login' => 'myUser>']); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $assignedVariables = []; $this->container->get('pageBuilder') @@ -113,8 +105,8 @@ public function testValidControllerInvokeWithUserName(): void */ public function testLoginControllerWhileLoggedIn(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->expects(static::once())->method('isLoggedIn')->willReturn(true); @@ -130,8 +122,8 @@ public function testLoginControllerWhileLoggedIn(): void */ public function testLoginControllerOpenShaarli(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $conf = $this->createMock(ConfigManager::class); $conf->method('get')->willReturnCallback(function (string $parameter, $default) { @@ -154,8 +146,8 @@ public function testLoginControllerOpenShaarli(): void */ public function testLoginControllerWhileBanned(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->method('isLoggedIn')->willReturn(false); $this->container->get('loginManager')->method('canLogin')->willReturn(false); @@ -174,16 +166,17 @@ public function testProcessLoginWithValidParameters(): void 'login' => 'bob', 'password' => 'pass', ]; - $request = (new FakeRequest())->withParsedBody($parameters) - ->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'REQUEST_URI' => '/subfolder/daily-rss', 'REMOTE_ADDR' => '1.2.3.4', 'SCRIPT_NAME' => '/subfolder/index.php', - ]); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->method('canLogin')->willReturn(true); $this->container->get('loginManager')->expects(static::once())->method('handleSuccessfulLogin'); @@ -219,15 +212,17 @@ public function testProcessLoginWithReturnUrl(): void $parameters = [ 'returnurl' => 'http://shaarli/subfolder/admin/shaare', ]; - $request = (new FakeRequest())->withParsedBody($parameters) - ->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'REQUEST_URI' => '/subfolder/daily-rss', 'REMOTE_ADDR' => '1.2.3.4', 'SCRIPT_NAME' => '/subfolder/index.php', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->method('canLogin')->willReturn(true); $this->container->get('loginManager')->expects(static::once())->method('handleSuccessfulLogin'); @@ -248,15 +243,17 @@ public function testProcessLoginLongLastingSession(): void $parameters = [ 'longlastingsession' => true, ]; - $request = (new FakeRequest())->withParsedBody($parameters) - ->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'REQUEST_URI' => '/subfolder/daily-rss', 'REMOTE_ADDR' => '1.2.3.4', 'SCRIPT_NAME' => '/subfolder/index.php', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->method('canLogin')->willReturn(true); $this->container->get('loginManager')->expects(static::once())->method('handleSuccessfulLogin'); @@ -298,15 +295,16 @@ public function testProcessLoginWrongCredentials(): void $parameters = [ 'returnurl' => 'http://shaarli/subfolder/admin/shaare', ]; - $request = (new FakeRequest())->withParsedBody($parameters) - ->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'REQUEST_URI' => '/subfolder/daily-rss', 'REMOTE_ADDR' => '1.2.3.4', 'SCRIPT_NAME' => '/subfolder/index.php', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams) + ->withParsedBody($parameters); + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->method('canLogin')->willReturn(true); $this->container->get('loginManager')->expects(static::once())->method('handleFailedLogin'); @@ -329,8 +327,8 @@ public function testProcessLoginWrongCredentials(): void */ public function testProcessLoginWrongToken(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->set('sessionManager', $this->createMock(SessionManager::class)); $this->container->get('sessionManager')->method('checkToken')->willReturn(false); @@ -345,8 +343,8 @@ public function testProcessLoginWrongToken(): void */ public function testProcessLoginAlreadyLoggedIn(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->method('isLoggedIn')->willReturn(true); $this->container->get('loginManager')->expects(static::never())->method('handleSuccessfulLogin'); @@ -363,8 +361,8 @@ public function testProcessLoginAlreadyLoggedIn(): void */ public function testProcessLoginInOpenShaarli(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->set('conf', $this->createMock(ConfigManager::class)); $this->container->get('conf')->method('get')->willReturnCallback(function (string $key, $value) { @@ -385,8 +383,8 @@ public function testProcessLoginInOpenShaarli(): void */ public function testProcessLoginWhileBanned(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->method('canLogin')->willReturn(false); $this->container->get('loginManager')->expects(static::never())->method('handleSuccessfulLogin'); diff --git a/tests/front/controller/visitor/OpenSearchControllerTest.php b/tests/front/controller/visitor/OpenSearchControllerTest.php index d27b31fb1..7d30d94d1 100644 --- a/tests/front/controller/visitor/OpenSearchControllerTest.php +++ b/tests/front/controller/visitor/OpenSearchControllerTest.php @@ -6,7 +6,6 @@ use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; class OpenSearchControllerTest extends TestCase { @@ -17,6 +16,7 @@ class OpenSearchControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new OpenSearchController($this->container); @@ -24,12 +24,13 @@ public function setUp(): void public function testOpenSearchController(): void { - $request = (new FakeRequest())->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'SCRIPT_NAME' => '/subfolder/index.php', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('POST', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; diff --git a/tests/front/controller/visitor/PictureWallControllerTest.php b/tests/front/controller/visitor/PictureWallControllerTest.php index fe49975d3..7d495e69e 100644 --- a/tests/front/controller/visitor/PictureWallControllerTest.php +++ b/tests/front/controller/visitor/PictureWallControllerTest.php @@ -11,7 +11,6 @@ use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; use Shaarli\Thumbnailer; -use Slim\Psr7\Response as SlimResponse; class PictureWallControllerTest extends TestCase { @@ -22,6 +21,7 @@ class PictureWallControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new PictureWallController($this->container); @@ -29,8 +29,8 @@ public function setUp(): void public function testValidControllerInvokeDefault(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); // ConfigManager: thumbnails are enabled $this->container->set('conf', $this->createMock(ConfigManager::class)); @@ -106,8 +106,8 @@ public function testControllerWithThumbnailsDisabled(): void { $this->expectException(ThumbnailsDisabledException::class); - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); // ConfigManager: thumbnails are disabled $this->container->get('conf')->method('get')->willReturnCallback(function (string $parameter, $default) { diff --git a/tests/front/controller/visitor/PublicSessionFilterControllerTest.php b/tests/front/controller/visitor/PublicSessionFilterControllerTest.php index 3542cdaa2..d642c10c6 100644 --- a/tests/front/controller/visitor/PublicSessionFilterControllerTest.php +++ b/tests/front/controller/visitor/PublicSessionFilterControllerTest.php @@ -8,8 +8,6 @@ use Shaarli\Security\SessionManager; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class PublicSessionFilterControllerTest extends TestCase { @@ -20,6 +18,8 @@ class PublicSessionFilterControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new PublicSessionFilterController($this->container); @@ -30,16 +30,15 @@ public function setUp(): void */ public function testLinksPerPage(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery('nb=8') - ))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', - 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc' - ]); + 'SERVER_PORT' => 80, + 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc' + ]; + $query = http_build_query(['nb' => 8]); + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli?' . $query, $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -59,11 +58,9 @@ public function testLinksPerPage(): void */ public function testLinksPerPageNotValid(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery('nb=test') - )); - $response = new SlimResponse(); + $query = http_build_query(['nb' => 'test']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -83,15 +80,13 @@ public function testLinksPerPageNotValid(): void */ public function testUntaggedOnly(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', '')) - ))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->expects(static::once()) @@ -111,15 +106,13 @@ public function testUntaggedOnly(): void */ public function testUntaggedOnlyToggleOff(): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', '', 80, 'shaarli')) - ))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller/?searchtag=abc' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $this->container->get('sessionManager') ->method('getSessionParameter') diff --git a/tests/front/controller/visitor/ShaarliVisitorControllerTest.php b/tests/front/controller/visitor/ShaarliVisitorControllerTest.php index 1ca45ab62..92e5bb3f4 100644 --- a/tests/front/controller/visitor/ShaarliVisitorControllerTest.php +++ b/tests/front/controller/visitor/ShaarliVisitorControllerTest.php @@ -9,8 +9,6 @@ use Shaarli\Bookmark\BookmarkFilter; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; /** * Class ShaarliControllerTest @@ -33,6 +31,7 @@ class ShaarliVisitorControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new class ($this->container) extends ShaarliVisitorController @@ -115,13 +114,14 @@ public function testRender(): void */ public function testRedirectFromRefererDefault(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' - ]); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response); @@ -134,13 +134,13 @@ public function testRedirectFromRefererDefault(): void */ public function testRedirectFromRefererWithUnmatchedLoopTerm(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' - ]); - - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response, ['nope']); @@ -153,13 +153,14 @@ public function testRedirectFromRefererWithUnmatchedLoopTerm(): void */ public function testRedirectFromRefererWithMatchingLoopTermInPath(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' - ]); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response, ['nope', 'controller']); @@ -172,13 +173,13 @@ public function testRedirectFromRefererWithMatchingLoopTermInPath(): void */ public function testRedirectFromRefererWithMatchingLoopTermInQueryParam(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' - ]); - - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response, ['nope', 'other']); @@ -192,13 +193,14 @@ public function testRedirectFromRefererWithMatchingLoopTermInQueryParam(): void */ public function testRedirectFromRefererWithMatchingLoopTermInQueryValue(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' - ]); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response, ['nope', 'param']); @@ -212,13 +214,14 @@ public function testRedirectFromRefererWithMatchingLoopTermInQueryValue(): void */ public function testRedirectFromRefererWithLoopTermInDomain(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' - ]); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response, ['shaarli']); @@ -232,13 +235,14 @@ public function testRedirectFromRefererWithLoopTermInDomain(): void */ public function testRedirectFromRefererWithMatchingClearedParam(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/subfolder/controller?query=param&other=2' - ]); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response, ['query'], ['query']); @@ -251,13 +255,14 @@ public function testRedirectFromRefererWithMatchingClearedParam(): void */ public function testRedirectExternalReferer(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://other.domain.tld/controller?query=param&other=2' - ]); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response, ['query'], ['query']); @@ -270,13 +275,14 @@ public function testRedirectExternalReferer(): void */ public function testRedirectExternalRefererExplicitDomainName(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'my.shaarli.tld', - 'SERVER_PORT' => '80', - 'HTTP_REFERER' => 'http://your.shaarli.tld/controller?query=param&other=2' - ]); + 'SERVER_PORT' => 80, + 'HTTP_REFERER' => 'http://your.shaarli.tld/subfolder/controller?query=param&other=2' + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); $result = $this->controller->redirectFromReferer($request, $response, ['query'], ['query']); diff --git a/tests/front/controller/visitor/TagCloudControllerTest.php b/tests/front/controller/visitor/TagCloudControllerTest.php index 0e364589f..ec4e90da5 100644 --- a/tests/front/controller/visitor/TagCloudControllerTest.php +++ b/tests/front/controller/visitor/TagCloudControllerTest.php @@ -7,8 +7,6 @@ use Shaarli\Bookmark\BookmarkFilter; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class TagCloudControllerTest extends TestCase { @@ -19,6 +17,7 @@ class TagCloudControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new TagCloudController($this->container); @@ -36,8 +35,8 @@ public function testValidCloudControllerInvokeDefault(): void ]; $expectedOrder = ['abc', 'def', 'ghi']; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -95,10 +94,9 @@ public function testValidCloudControllerInvokeDefault(): void */ public function testValidCloudControllerInvokeWithParameters(): void { - $request = new FakeRequest(); - $request = new FakeRequest('GET', (new Uri('', '')) - ->withQuery(http_build_query(['searchtags' => 'ghi@def']))); - $response = new SlimResponse(); + $query = http_build_query(['searchtags' => 'ghi@def']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -154,8 +152,8 @@ public function testValidCloudControllerInvokeWithParameters(): void */ public function testEmptyCloud(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -208,8 +206,8 @@ public function testValidListControllerInvokeDefault(): void 'ghi' => 1, ]; - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -264,10 +262,10 @@ public function testValidListControllerInvokeDefault(): void */ public function testValidListControllerInvokeWithParameters(): void { - $request = new FakeRequest('GET', (new Uri('', '')) - ->withQuery(http_build_query(['searchtags' => 'ghi@def', 'sort' => 'alpha']))); + $query = http_build_query(['searchtags' => 'ghi@def', 'sort' => 'alpha']); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query, $serverParams); - $response = new SlimResponse(); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; @@ -319,8 +317,8 @@ public function testValidListControllerInvokeWithParameters(): void */ public function testEmptyList(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); // Save RainTPL assigned variables $assignedVariables = []; diff --git a/tests/front/controller/visitor/TagControllerTest.php b/tests/front/controller/visitor/TagControllerTest.php index ad0f24e37..4ce9ab290 100644 --- a/tests/front/controller/visitor/TagControllerTest.php +++ b/tests/front/controller/visitor/TagControllerTest.php @@ -7,8 +7,6 @@ use Psr\Http\Message\ResponseInterface as Response; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class TagControllerTest extends TestCase { @@ -18,6 +16,7 @@ class TagControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new TagController($this->container); @@ -25,12 +24,13 @@ public function setUp(): void public function testAddTagWithReferer(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $tags = ['newTag' => 'abc']; @@ -43,12 +43,13 @@ public function testAddTagWithReferer(): void public function testAddTagWithRefererAndExistingSearch(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def', - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $tags = ['newTag' => 'abc']; @@ -61,11 +62,12 @@ public function testAddTagWithRefererAndExistingSearch(): void public function testAddTagWithoutRefererAndExistingSearch(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', - ]); - $response = new SlimResponse(); + 'SERVER_PORT' => 80 + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $tags = ['newTag' => 'abc']; @@ -78,12 +80,13 @@ public function testAddTagWithoutRefererAndExistingSearch(): void public function testAddTagRemoveLegacyQueryParam(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def&addtag=abc' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $tags = ['newTag' => 'abc']; @@ -96,12 +99,13 @@ public function testAddTagRemoveLegacyQueryParam(): void public function testAddTagResetPagination(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def&page=12' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $tags = ['newTag' => 'abc']; @@ -114,12 +118,13 @@ public function testAddTagResetPagination(): void public function testAddTagWithRefererAndEmptySearch(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $tags = ['newTag' => 'abc']; @@ -132,12 +137,13 @@ public function testAddTagWithRefererAndEmptySearch(): void public function testAddTagWithoutNewTagWithReferer(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->addTag($request, $response, []); @@ -148,8 +154,8 @@ public function testAddTagWithoutNewTagWithReferer(): void public function testAddTagWithoutNewTagWithoutReferer(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->addTag($request, $response, []); @@ -160,12 +166,13 @@ public function testAddTagWithoutNewTagWithoutReferer(): void public function testRemoveTagWithoutMatchingTag(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/?searchtags=def' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $tags = ['tag' => 'abc']; @@ -178,12 +185,13 @@ public function testRemoveTagWithoutMatchingTag(): void public function testRemoveTagWithoutTagsearch(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $tags = ['tag' => 'abc']; @@ -196,8 +204,8 @@ public function testRemoveTagWithoutTagsearch(): void public function testRemoveTagWithoutReferer(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $tags = ['tag' => 'abc']; @@ -210,12 +218,13 @@ public function testRemoveTagWithoutReferer(): void public function testRemoveTagWithoutTag(): void { - $request = (new FakeRequest('GET', new Uri('', '')))->withServerParams([ + $serverParams = [ 'SERVER_NAME' => 'shaarli', - 'SERVER_PORT' => '80', + 'SERVER_PORT' => 80, 'HTTP_REFERER' => 'http://shaarli/controller/?searchtag=abc' - ]); - $response = new SlimResponse(); + ]; + $request = $this->serverRequestFactory->createServerRequest('GET', 'http://shaarli', $serverParams); + $response = $this->responseFactory->createResponse(); $result = $this->controller->removeTag($request, $response, []); @@ -226,8 +235,8 @@ public function testRemoveTagWithoutTag(): void public function testRemoveTagWithoutTagWithoutReferer(): void { - $request = new FakeRequest(); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $result = $this->controller->removeTag($request, $response, []); diff --git a/tests/helper/DailyPageHelperTest.php b/tests/helper/DailyPageHelperTest.php index e206510ff..06232a77d 100644 --- a/tests/helper/DailyPageHelperTest.php +++ b/tests/helper/DailyPageHelperTest.php @@ -15,6 +15,7 @@ class DailyPageHelperTest extends TestCase { public function setUp(): void { + $this->initRequestResponseFactories(); setlocale(LC_TIME, 'en_US.UTF-8'); } @@ -24,7 +25,8 @@ public function setUp(): void */ public function testExtractRequestedType(array $queryParams, string $expectedType): void { - $request = (new FakeRequest())->withQueryParams($queryParams); + $query = http_build_query($queryParams); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); $type = DailyPageHelper::extractRequestedType($request); diff --git a/tests/legacy/LegacyControllerTest.php b/tests/legacy/LegacyControllerTest.php index 4b9f80243..6565645f3 100644 --- a/tests/legacy/LegacyControllerTest.php +++ b/tests/legacy/LegacyControllerTest.php @@ -7,8 +7,6 @@ use Shaarli\Front\Controller\Visitor\FrontControllerMockHelper; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; -use Slim\Psr7\Response as SlimResponse; -use Slim\Psr7\Uri; class LegacyControllerTest extends TestCase { @@ -19,6 +17,7 @@ class LegacyControllerTest extends TestCase public function setUp(): void { + $this->initRequestResponseFactories(); $this->createContainer(); $this->controller = new LegacyController($this->container); @@ -29,11 +28,9 @@ public function setUp(): void */ public function testProcess(string $legacyRoute, array $queryParameters, string $slimRoute, bool $isLoggedIn): void { - $request = (new FakeRequest( - 'GET', - (new Uri('', ''))->withQuery(http_build_query($queryParameters)) - )); - $response = new SlimResponse(); + $query = http_build_query($queryParameters); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); + $response = $this->responseFactory->createResponse(); $this->container->get('loginManager')->method('isLoggedIn')->willReturn($isLoggedIn); @@ -44,10 +41,8 @@ public function testProcess(string $legacyRoute, array $queryParameters, string public function testProcessNotFound(): void { - $request = (new FakeRequest( - 'GET' - )); - $response = new SlimResponse(); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli'); + $response = $this->responseFactory->createResponse(); $this->expectException(UnknowLegacyRouteException::class); diff --git a/tests/netscape/BookmarkImportTest.php b/tests/netscape/BookmarkImportTest.php index 90eecaddd..c1e6d4d8a 100644 --- a/tests/netscape/BookmarkImportTest.php +++ b/tests/netscape/BookmarkImportTest.php @@ -12,7 +12,8 @@ use Shaarli\History; use Shaarli\Plugin\PluginManager; use Shaarli\TestCase; -use Slim\Psr7\UploadedFile; +use Slim\Psr7\Factory\StreamFactory; +use Slim\Psr7\Factory\UploadedFileFactory; /** * Utility function to load a file's metadata in a $_FILES-like array @@ -23,11 +24,15 @@ */ function file2array($filename) { - return new UploadedFile( - __DIR__ . '/input/' . $filename, - $filename, - null, - filesize(__DIR__ . '/input/' . $filename) + $uploadedFileFactory = new UploadedFileFactory(); + $streamFactory = new StreamFactory(); + $streamFile = $streamFactory->createStreamFromFile(__DIR__ . '/input/' . $filename); + + return $uploadedFileFactory->createUploadedFile( + $streamFile, + $streamFile->getSize(), + UPLOAD_ERR_OK, + $filename ); } diff --git a/tests/utils/FakeRequest.php b/tests/utils/FakeRequest.php deleted file mode 100644 index 0e02264b7..000000000 --- a/tests/utils/FakeRequest.php +++ /dev/null @@ -1,42 +0,0 @@ -serverParams = $serverParams; - return $this; - } -} diff --git a/tests/utils/FakeRequestHandler.php b/tests/utils/FakeRequestHandler.php deleted file mode 100644 index bf7ec4ada..000000000 --- a/tests/utils/FakeRequestHandler.php +++ /dev/null @@ -1,33 +0,0 @@ -response = $response ?? new Response(); - $this->callback = $callback; - } - public function handle(ServerRequestInterface $request): ResponseInterface - { - if ($this->callback) { - return ($this->callback)($request); - } - return $this->response; - } -} diff --git a/tests/utils/FakeRouteCollector.php b/tests/utils/FakeRouteCollector.php deleted file mode 100644 index 132a4b242..000000000 --- a/tests/utils/FakeRouteCollector.php +++ /dev/null @@ -1,35 +0,0 @@ -map($methods, $pattern, function () { - }); - if ($name) { - $route->setName($name); - } - return $this; - } - - public function getRouteParser(): RouteParserInterface - { - return parent::getRouteParser(); - } -} diff --git a/tests/utils/RequestHandlerFactory.php b/tests/utils/RequestHandlerFactory.php new file mode 100644 index 000000000..6b9c745b8 --- /dev/null +++ b/tests/utils/RequestHandlerFactory.php @@ -0,0 +1,27 @@ +createResponse(); + }; + } + $app->add($callable); + + return $app; + } +} From 09be21774ab83abde39cde82f37ef1b41f957cf6 Mon Sep 17 00:00:00 2001 From: Beutlin Date: Fri, 28 Apr 2023 13:00:27 +0200 Subject: [PATCH 09/12] Fix TagCloudController Test --- tests/front/controller/visitor/TagCloudControllerTest.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/front/controller/visitor/TagCloudControllerTest.php b/tests/front/controller/visitor/TagCloudControllerTest.php index ec4e90da5..98c82be9b 100644 --- a/tests/front/controller/visitor/TagCloudControllerTest.php +++ b/tests/front/controller/visitor/TagCloudControllerTest.php @@ -263,7 +263,7 @@ public function testValidListControllerInvokeDefault(): void public function testValidListControllerInvokeWithParameters(): void { $query = http_build_query(['searchtags' => 'ghi@def', 'sort' => 'alpha']); - $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query, $serverParams); + $request = $this->requestFactory->createRequest('GET', 'http://shaarli?' . $query); $response = $this->responseFactory->createResponse(); From 18c68c09c1f5a5c0c16c3071ec400346f301d4bf Mon Sep 17 00:00:00 2001 From: ArthurHoaro Date: Thu, 23 Nov 2023 12:24:11 -0500 Subject: [PATCH 10/12] Add middleware to auto-detect basePath --- application/front/ShaarliErrorHandler.php | 16 ++++--- application/front/ShaarliMiddleware.php | 2 +- composer.json | 1 + composer.lock | 54 ++++++++++++++++++++++- index.php | 4 +- 5 files changed, 66 insertions(+), 11 deletions(-) diff --git a/application/front/ShaarliErrorHandler.php b/application/front/ShaarliErrorHandler.php index 99e323c1c..42a17fb87 100644 --- a/application/front/ShaarliErrorHandler.php +++ b/application/front/ShaarliErrorHandler.php @@ -12,6 +12,7 @@ use Shaarli\Front\Controller\PageTrait; use Shaarli\Front\Exception\ShaarliFrontException; use Shaarli\Render\TemplatePage; +use Slim\App; use Slim\Exception\HttpNotFoundException; use Slim\Handlers\ErrorHandler; use Slim\Interfaces\CallableResolverInterface; @@ -23,15 +24,17 @@ class ShaarliErrorHandler extends ErrorHandler { use PageTrait; + private App $app; + private ?Container $container; public function __construct( - CallableResolverInterface $callableResolver, - ResponseFactoryInterface $responseFactory, + App $app, ?LoggerInterface $logger = null, - ?Container $container = null + ?Container $container = null, ) { - parent::__construct($callableResolver, $responseFactory, $logger); + parent::__construct($app->getCallableResolver(), $app->getResponseFactory(), $logger); + $this->app = $app; $this->container = $container; } @@ -84,10 +87,9 @@ protected function showError404($request): ResponseInterface if (false !== strpos($request->getRequestTarget(), '/api/v1')) { return $response->withStatus(404); } - $basePathFromRequest = $request->getAttribute(RouteContext::BASE_PATH) ?? ''; - // This is required because the middleware is ignored if the route is not found. - $this->container->set('basePath', rtrim($basePathFromRequest, '/')); + // This is required because the request handler throw the error before setting the base path. + $this->container->set('basePath', rtrim($this->app->getBasePath(), '/')); $this->assignView('error_message', t('Requested page could not be found.')); diff --git a/application/front/ShaarliMiddleware.php b/application/front/ShaarliMiddleware.php index 7163a470a..621078628 100644 --- a/application/front/ShaarliMiddleware.php +++ b/application/front/ShaarliMiddleware.php @@ -113,7 +113,7 @@ protected function checkOpenShaarli(Request $request, RequestHandler $handler): protected function initBasePath(Request $request): void { if (null === $this->container->get('basePath')) { - $this->container->set('basePath', rtrim($request->getAttribute('basePath'), '/')); + $this->container->set('basePath', rtrim($request->getAttribute(RouteContext::BASE_PATH), '/')); } } diff --git a/composer.json b/composer.json index 677acf936..200eb6457 100644 --- a/composer.json +++ b/composer.json @@ -27,6 +27,7 @@ "malkusch/lock": "^2.1", "php-di/php-di": "^6.4", "pubsubhubbub/publisher": "dev-master", + "selective/basepath": "^2.1", "shaarli/netscape-bookmark-parser": "^4.0", "slim/psr7": "^1.6", "slim/slim": "4.*" diff --git a/composer.lock b/composer.lock index 882e418b0..0b5e03b22 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "f528234eae54fec2c08e480246366930", + "content-hash": "cd0bf70a2b6566e8585f46b238109116", "packages": [ { "name": "arthurhoaro/web-thumbnailer", @@ -1264,6 +1264,56 @@ }, "time": "2019-03-08T08:55:37+00:00" }, + { + "name": "selective/basepath", + "version": "2.1.0", + "source": { + "type": "git", + "url": "https://github.com/selective-php/basepath.git", + "reference": "63961fbfcaf492bd0ae8e40653f6c3c750c2f8ad" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/selective-php/basepath/zipball/63961fbfcaf492bd0ae8e40653f6c3c750c2f8ad", + "reference": "63961fbfcaf492bd0ae8e40653f6c3c750c2f8ad", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0", + "psr/http-server-middleware": "^1" + }, + "require-dev": { + "friendsofphp/php-cs-fixer": "^2", + "overtrue/phplint": "^2", + "phpstan/phpstan": "0.*", + "phpunit/phpunit": "^8 || ^9", + "slim/psr7": "^1", + "slim/slim": "^4", + "squizlabs/php_codesniffer": "^3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Selective\\BasePath\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "A URL base path detector for Slim 4", + "homepage": "https://github.com/selective-php/basepath", + "keywords": [ + "basepath", + "slim", + "slim4" + ], + "support": { + "issues": "https://github.com/selective-php/basepath/issues", + "source": "https://github.com/selective-php/basepath/tree/2.1.0" + }, + "time": "2021-07-17T10:03:02+00:00" + }, { "name": "shaarli/netscape-bookmark-parser", "version": "v4.0.0", @@ -3960,5 +4010,5 @@ "platform-overrides": { "php": "7.4.33" }, - "plugin-api-version": "2.3.0" + "plugin-api-version": "2.6.0" } diff --git a/index.php b/index.php index 7e92dca8d..a731b8766 100644 --- a/index.php +++ b/index.php @@ -28,6 +28,7 @@ use Katzgrau\KLogger\Logger; use Psr\Log\LogLevel; +use Selective\BasePath\BasePathMiddleware; use Shaarli\Api\Controllers as ApiControllers; use Shaarli\Config\ConfigManager; use Shaarli\Container\ContainerBuilder; @@ -108,6 +109,7 @@ $container = $containerBuilder->build(); AppFactory::setContainer($container); $app = AppFactory::create(); +$app->add(new BasePathMiddleware($app)); // Main Shaarli routes $app->group('', function (RouteCollectorProxy $group) { @@ -202,7 +204,7 @@ $errorMiddleware = $app->addErrorMiddleware($displayErrorDetails, true, true); $errorMiddleware->setDefaultErrorHandler( - new ShaarliErrorHandler($app->getCallableResolver(), $app->getResponseFactory(), $logger, $container) + new ShaarliErrorHandler($app, $logger, $container) ); From 2abaf1007fd0cd7a4904811d3dcce72eb7a3813f Mon Sep 17 00:00:00 2001 From: ArthurHoaro Date: Thu, 23 Nov 2023 15:30:50 -0500 Subject: [PATCH 11/12] Temporary hack to make BasePathMiddleware work without a public/ subdirectory --- application/BasePathMiddleware.php | 53 ++++++++++++++++++++++++++++++ index.php | 2 +- 2 files changed, 54 insertions(+), 1 deletion(-) create mode 100644 application/BasePathMiddleware.php diff --git a/application/BasePathMiddleware.php b/application/BasePathMiddleware.php new file mode 100644 index 000000000..da1ca84d2 --- /dev/null +++ b/application/BasePathMiddleware.php @@ -0,0 +1,53 @@ +app = $app; + $this->phpSapi = $phpSapi; + } + + public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface + { + $params = $request->getServerParams(); + $pathParts = pathinfo($params['SCRIPT_NAME']); + $params['SCRIPT_NAME'] = $pathParts['dirname'] . '/public/' . $pathParts['basename']; + + $detector = new BasePathDetector($params, $this->phpSapi); + + $this->app->setBasePath($detector->getBasePath()); + + return $handler->handle($request); + } +} diff --git a/index.php b/index.php index a731b8766..def5b0889 100644 --- a/index.php +++ b/index.php @@ -28,8 +28,8 @@ use Katzgrau\KLogger\Logger; use Psr\Log\LogLevel; -use Selective\BasePath\BasePathMiddleware; use Shaarli\Api\Controllers as ApiControllers; +use Shaarli\BasePathMiddleware; use Shaarli\Config\ConfigManager; use Shaarli\Container\ContainerBuilder; use Shaarli\Front\Controller; From 9e1e734291becd741770f5292ea304f399b31919 Mon Sep 17 00:00:00 2001 From: ArthurHoaro Date: Sat, 25 Nov 2023 10:03:05 -0500 Subject: [PATCH 12/12] Linter + tests + PHP compatibility --- application/BasePathMiddleware.php | 7 ++++--- application/front/ShaarliErrorHandler.php | 2 +- tests/front/ShaarliAdminMiddlewareTest.php | 3 +++ tests/front/ShaarliErrorHandlerTest.php | 5 +++-- 4 files changed, 11 insertions(+), 6 deletions(-) diff --git a/application/BasePathMiddleware.php b/application/BasePathMiddleware.php index da1ca84d2..fc8ecc123 100644 --- a/application/BasePathMiddleware.php +++ b/application/BasePathMiddleware.php @@ -15,7 +15,8 @@ * This is a hack that to make BasePathMiddleware Selective's library without a public subdirectory, * and without re-implementing the dectector. */ -class BasePathMiddleware implements MiddlewareInterface { +class BasePathMiddleware implements MiddlewareInterface +{ /** * @var App The slim app */ @@ -37,13 +38,13 @@ public function __construct(App $app, string $phpSapi = null) $this->app = $app; $this->phpSapi = $phpSapi; } - + public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface { $params = $request->getServerParams(); $pathParts = pathinfo($params['SCRIPT_NAME']); $params['SCRIPT_NAME'] = $pathParts['dirname'] . '/public/' . $pathParts['basename']; - + $detector = new BasePathDetector($params, $this->phpSapi); $this->app->setBasePath($detector->getBasePath()); diff --git a/application/front/ShaarliErrorHandler.php b/application/front/ShaarliErrorHandler.php index 42a17fb87..6f52839fe 100644 --- a/application/front/ShaarliErrorHandler.php +++ b/application/front/ShaarliErrorHandler.php @@ -31,7 +31,7 @@ class ShaarliErrorHandler extends ErrorHandler public function __construct( App $app, ?LoggerInterface $logger = null, - ?Container $container = null, + ?Container $container = null ) { parent::__construct($app->getCallableResolver(), $app->getResponseFactory(), $logger); $this->app = $app; diff --git a/tests/front/ShaarliAdminMiddlewareTest.php b/tests/front/ShaarliAdminMiddlewareTest.php index 6ac68382d..cdd67c3ee 100644 --- a/tests/front/ShaarliAdminMiddlewareTest.php +++ b/tests/front/ShaarliAdminMiddlewareTest.php @@ -25,6 +25,9 @@ class ShaarliAdminMiddlewareTest extends TestCase /** @var ShaarliMiddleware */ protected $middleware; + /** @var RequestHandlerFactory */ + protected $requestHandlerFactory; + public function setUp(): void { $this->initRequestResponseFactories(); diff --git a/tests/front/ShaarliErrorHandlerTest.php b/tests/front/ShaarliErrorHandlerTest.php index 927bb765e..cec149567 100644 --- a/tests/front/ShaarliErrorHandlerTest.php +++ b/tests/front/ShaarliErrorHandlerTest.php @@ -8,8 +8,10 @@ use Shaarli\Front\Exception\ShaarliFrontException; use Shaarli\TestCase; use Shaarli\Tests\Utils\FakeRequest; +use Slim\App; use Slim\CallableResolver; use Slim\Exception\HttpNotFoundException; +use Slim\Factory\AppFactory; use Slim\Psr7\Factory\ResponseFactory; use Slim\Routing\RouteContext; @@ -25,8 +27,7 @@ public function setUp(): void $this->initRequestResponseFactories(); $this->createContainer(); $this->errorHandler = new ShaarliErrorHandler( - new CallableResolver(), - new ResponseFactory(), + AppFactory::create(), null, $this->container );