Skip to content

Commit

Permalink
feat: add support for trailing slashes in routes and urls
Browse files Browse the repository at this point in the history
  • Loading branch information
christyjacob4 committed Jun 3, 2023
1 parent a2fb128 commit d25fe85
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 4 deletions.
8 changes: 8 additions & 0 deletions src/App.php
Original file line number Diff line number Diff line change
Expand Up @@ -502,6 +502,14 @@ public function match(Request $request, bool $fresh = false): ?Route
foreach (self::$routes[$method] as $routeUrl => $route) {
/** @var Route $route */

if(str_ends_with($routeUrl, '/') && substr_count($routeUrl, '/') > 1) {
$routeUrl = rtrim($routeUrl, '/');
}

if(str_ends_with($url, '/') && substr_count($url, '/') > 1) {
$url = rtrim($url, '/');
}

// convert urls like '/users/:uid/posts/:pid' to regular expression
$regex = '@'.\preg_replace('@:[^/]+@', '([^/]+)', $routeUrl).'@';

Expand Down
13 changes: 9 additions & 4 deletions tests/AppTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -400,6 +400,9 @@ public function providerRouteMatching(): array
return [
'GET request' => [App::REQUEST_METHOD_GET, '/path1'],
'GET request on different route' => [App::REQUEST_METHOD_GET, '/path2'],
'GET request with trailing slash #1' => [App::REQUEST_METHOD_GET, '/path3', '/path3/'],
'GET request with trailing slash #2' => [App::REQUEST_METHOD_GET, '/path3/', '/path3/'],
'GET request with trailing slash #3' => [App::REQUEST_METHOD_GET, '/path3/', '/path3'],
'POST request' => [App::REQUEST_METHOD_POST, '/path1'],
'PUT request' => [App::REQUEST_METHOD_PUT, '/path1'],
'PATCH request' => [App::REQUEST_METHOD_PATCH, '/path1'],
Expand All @@ -415,9 +418,9 @@ public function providerRouteMatching(): array
/**
* @dataProvider providerRouteMatching
*/
public function testCanMatchRoute(string $method, string $path, string $expected = null): void
public function testCanMatchRoute(string $method, string $path, string $url = null): void
{
$expected ??= $path;
$url ??= $path;

switch ($method) {
case App::REQUEST_METHOD_GET:
Expand All @@ -438,9 +441,11 @@ public function testCanMatchRoute(string $method, string $path, string $expected
}

$_SERVER['REQUEST_METHOD'] = $method;
$_SERVER['REQUEST_URI'] = $path;
$_SERVER['REQUEST_URI'] = $url;

$match = $this->app->match(new Request());

$this->assertEquals($expected, $this->app->match(new Request()));
$this->assertEquals($expected, $match);
$this->assertEquals($expected, $this->app->getRoute());
}

Expand Down

0 comments on commit d25fe85

Please sign in to comment.