From 0ae7e6ac288f95ac28425ee9ad074a5a16ebb339 Mon Sep 17 00:00:00 2001 From: neznaika0 Date: Mon, 6 Nov 2023 13:29:15 +0300 Subject: [PATCH] test: Add test for routes containing `{locale}` --- .../Utilities/Routes/FilterFinderTest.php | 51 +++++++++++++++++-- 1 file changed, 48 insertions(+), 3 deletions(-) diff --git a/tests/system/Commands/Utilities/Routes/FilterFinderTest.php b/tests/system/Commands/Utilities/Routes/FilterFinderTest.php index c59c9b9aee8e..92923ccdaece 100644 --- a/tests/system/Commands/Utilities/Routes/FilterFinderTest.php +++ b/tests/system/Commands/Utilities/Routes/FilterFinderTest.php @@ -52,6 +52,13 @@ protected function setUp(): void $this->moduleConfig->enabled = false; } + protected function tearDown(): void + { + parent::tearDown(); + + $this->resetServices(); + } + private function createRouteCollection(array $routes = []): RouteCollection { $collection = new RouteCollection(Services::locator(), $this->moduleConfig, new Routing()); @@ -137,7 +144,7 @@ public function testFindGlobalsFiltersWithRedirectRoute(): void public function testFindGlobalsAndRouteFilters(): void { $collection = $this->createRouteCollection(); - $collection->get('admin', ' AdminController::index', ['filter' => 'honeypot']); + $collection->get('admin', 'AdminController::index', ['filter' => 'honeypot']); $router = $this->createRouter($collection); $filters = $this->createFilters(); @@ -155,7 +162,7 @@ public function testFindGlobalsAndRouteFilters(): void public function testFindGlobalsAndRouteClassnameFilters(): void { $collection = $this->createRouteCollection(); - $collection->get('admin', ' AdminController::index', ['filter' => InvalidChars::class]); + $collection->get('admin', 'AdminController::index', ['filter' => InvalidChars::class]); $router = $this->createRouter($collection); $filters = $this->createFilters(); @@ -173,7 +180,7 @@ public function testFindGlobalsAndRouteClassnameFilters(): void public function testFindGlobalsAndRouteMultipleFilters(): void { $collection = $this->createRouteCollection(); - $collection->get('admin', ' AdminController::index', ['filter' => ['honeypot', InvalidChars::class]]); + $collection->get('admin', 'AdminController::index', ['filter' => ['honeypot', InvalidChars::class]]); $router = $this->createRouter($collection); $filters = $this->createFilters(); @@ -314,4 +321,42 @@ public function testFilterOrderWithOldFilterOrder() ]; $this->assertSame($expected, $filters); } + + public function testFindFiltersWithAnyLocales(): void + { + $collection = $this->createRouteCollection(); + $collection->useSupportedLocalesOnly(false); + $collection->get('{locale}/admin/(:segment)', 'AdminController::index/$1'); + Services::injectMock('routes', $collection); + $router = $this->createRouter($collection); + $filters = $this->createFilters(); + $finder = new FilterFinder($router, $filters); + + $filters = $finder->find('{locale}/admin/settings'); + + $expected = [ + 'before' => ['csrf'], + 'after' => ['toolbar'], + ]; + $this->assertSame($expected, $filters); + } + + public function testFindFiltersWithSupportedLocalesOnly(): void + { + $collection = $this->createRouteCollection(); + $collection->useSupportedLocalesOnly(true); + $collection->get('{locale}/admin/(:segment)', 'AdminController::index/$1'); + Services::injectMock('routes', $collection); + $router = $this->createRouter($collection); + $filters = $this->createFilters(); + $finder = new FilterFinder($router, $filters); + + $filters = $finder->find('{locale}/admin/settings'); + + $expected = [ + 'before' => ['!csrf'], + 'after' => ['!toolbar'], + ]; + $this->assertSame($expected, $filters); + } }