diff --git a/src/Router.php b/src/Router.php index b973e3b..55df548 100644 --- a/src/Router.php +++ b/src/Router.php @@ -64,7 +64,7 @@ class Router extends Configurable public function factory(array $request = null): self { // URLがない場合はconfigureのdefaultを取得 - $request['url'] = ($request['url'] ?? $this->configures['default_url']); + $request['url'] = ($request['url'] ?? $_SERVER['REQUEST_URI'] ?? $this->configures['default_url']); // URLをパース $this->parse($request['url']); diff --git a/tests/RouterTest.php b/tests/RouterTest.php index 5620f1c..69c08e3 100644 --- a/tests/RouterTest.php +++ b/tests/RouterTest.php @@ -68,4 +68,38 @@ public function factory_想定通り() $this->assertSame($router->action, $action); $this->assertSame($router->parameters, $parameters); } + + + + /** + * @test + * @throws ConfigureException + */ + public function factory_想定通りAPI() + { + // 設定値 + $configures = require(dirname(__DIR__) . '/tests/citrus-configure.php'); + + // 生成 + $router = Router::sharedInstance()->loadConfigures($configures); + + // URLパス設計 + $_SERVER['REQUEST_URI'] = '/api/user/login'; + $protocol = 'api'; + $documents = ['user']; + $action = 'login'; + $parameters = ['email' => 'hoge@example.com']; + $request = [ + ]; + $request = array_merge($request, $parameters); + + // アイテムの生成 + $router->factory($request); + + // 検証 + $this->assertSame($router->protocol, $protocol); + $this->assertSame($router->documents, $documents); + $this->assertSame($router->action, $action); + $this->assertSame($router->parameters, $parameters); + } }