diff --git a/flight/Engine.php b/flight/Engine.php index d52f498..27b44b4 100644 --- a/flight/Engine.php +++ b/flight/Engine.php @@ -42,13 +42,13 @@ use flight\net\Route; * Routes a PATCH URL to a callback function. * @method Route delete(string $pattern, callable|string $callback, bool $pass_route = false, string $alias = '') * Routes a DELETE URL to a callback function. - * @method void resource(string $pattern, string $controllerClass, array $methods = []) + * @method void resource(string $pattern, string $controllerClass, array> $methods = []) * Adds standardized RESTful routes for a controller. * @method Router router() Gets router * @method string getUrl(string $alias) Gets a url from an alias * * # Views - * @method void render(string $file, ?array $data = null, ?string $key = null) Renders template + * @method void render(string $file, ?array $data = null, ?string $key = null) Renders template * @method View view() Gets current view * * # Request-Response @@ -600,7 +600,8 @@ class Engine */ public function _error(Throwable $e): void { - $msg = sprintf(<<500 Internal Server Error

%s (%s)

%s
diff --git a/flight/Flight.php b/flight/Flight.php index 61de281..8887269 100644 --- a/flight/Flight.php +++ b/flight/Flight.php @@ -23,7 +23,7 @@ require_once __DIR__ . '/autoload.php'; * @method static void stop(?int $code = null) Stops the framework and sends a response. * @method static void halt(int $code = 200, string $message = '', bool $actuallyExit = true) * Stop the framework with an optional status code and message. - * @method static void register(string $name, string $class, array $params = [], ?callable $callback = null) + * @method static void register(string $name, string $class, array $params = [], ?callable $callback = null) * Registers a class to a framework method. * @method static void unregister(string $methodName) * Unregisters a class to a framework method. @@ -42,7 +42,7 @@ require_once __DIR__ . '/autoload.php'; * Routes a PATCH URL to a callback function. * @method static Route delete(string $pattern, callable|string $callback, bool $pass_route = false, string $alias = '') * Routes a DELETE URL to a callback function. - * @method static void resource(string $pattern, string $controllerClass, array $methods = []) + * @method static void resource(string $pattern, string $controllerClass, array> $methods = []) * Adds standardized RESTful routes for a controller. * @method static Router router() Returns Router instance. * @method static string getUrl(string $alias, array $params = []) Gets a url from an alias diff --git a/flight/net/Route.php b/flight/net/Route.php index 4e6e83c..05811ec 100644 --- a/flight/net/Route.php +++ b/flight/net/Route.php @@ -198,7 +198,7 @@ class Route public function hydrateUrl(array $params = []): string { $url = preg_replace_callback("/(?:@([\w]+)(?:\:([^\/]+))?\)*)/i", function ($match) use ($params) { - if (isset($match[1]) && isset($params[$match[1]])) { + if (isset($params[$match[1]]) === true) { return $params[$match[1]]; } }, $this->pattern); diff --git a/tests/FlightTest.php b/tests/FlightTest.php index cf0c9f0..54acf53 100644 --- a/tests/FlightTest.php +++ b/tests/FlightTest.php @@ -378,7 +378,7 @@ class FlightTest extends TestCase public function testKeepThePreviousStateOfOneViewComponentByDefault(): void { - $this->expectOutputString(<<expectOutputString(<<<'html'
Hi
Hi
diff --git a/tests/ViewTest.php b/tests/ViewTest.php index d6754c9..e95224d 100644 --- a/tests/ViewTest.php +++ b/tests/ViewTest.php @@ -175,7 +175,7 @@ class ViewTest extends TestCase public function testKeepThePreviousStateOfOneViewComponentByDefault(): void { - $this->expectOutputString(<<expectOutputString(<<<'html'
Hi
Hi
@@ -197,7 +197,7 @@ class ViewTest extends TestCase $this->view->set('prop', 'bar'); - $this->expectOutputString(<<expectOutputString(<<<'html'
qux
bar
@@ -211,7 +211,7 @@ class ViewTest extends TestCase { return [ [ - <<Hi
@@ -220,7 +220,7 @@ class ViewTest extends TestCase '/^Undefined variable:? \$?prop$/' ], [ - << diff --git a/tests/commands/ControllerCommandTest.php b/tests/commands/ControllerCommandTest.php index 82fb0c1..b16f6bc 100644 --- a/tests/commands/ControllerCommandTest.php +++ b/tests/commands/ControllerCommandTest.php @@ -11,11 +11,14 @@ use PHPUnit\Framework\TestCase; class ControllerCommandTest extends TestCase { - protected static $in = __DIR__ . '/input.test'; - protected static $ou = __DIR__ . '/output.test'; + protected static $in = ''; + protected static $ou = ''; public function setUp(): void { + // Need dynamic filenames to avoid unlink() issues with windows. + static::$in = __DIR__ . DIRECTORY_SEPARATOR . 'input.test' . uniqid('', true) . '.txt'; + static::$ou = __DIR__ . DIRECTORY_SEPARATOR . 'output.test' . uniqid('', true) . '.txt'; file_put_contents(static::$in, '', LOCK_EX); file_put_contents(static::$ou, '', LOCK_EX); } @@ -37,6 +40,10 @@ class ControllerCommandTest extends TestCase if (file_exists(__DIR__ . '/controllers/')) { rmdir(__DIR__ . '/controllers/'); } + + // Thanks Windows + clearstatcache(); + gc_collect_cycles(); } protected function newApp(string $name, string $version = '') diff --git a/tests/commands/RouteCommandTest.php b/tests/commands/RouteCommandTest.php index eae0b81..d58562d 100644 --- a/tests/commands/RouteCommandTest.php +++ b/tests/commands/RouteCommandTest.php @@ -13,13 +13,16 @@ use PHPUnit\Framework\TestCase; class RouteCommandTest extends TestCase { - protected static $in = __DIR__ . '/input.test'; - protected static $ou = __DIR__ . '/output.test'; + protected static $in = __DIR__ . DIRECTORY_SEPARATOR . 'input.test'; + protected static $ou = __DIR__ . DIRECTORY_SEPARATOR . 'output.test'; public function setUp(): void { - file_put_contents(static::$in, '', LOCK_EX); - file_put_contents(static::$ou, '', LOCK_EX); + // Need dynamic filenames to avoid unlink() issues with windows. + static::$in = __DIR__ . DIRECTORY_SEPARATOR . 'input.test' . uniqid('', true) . '.txt'; + static::$ou = __DIR__ . DIRECTORY_SEPARATOR . 'output.test' . uniqid('', true) . '.txt'; + file_put_contents(static::$in, ''); + file_put_contents(static::$ou, ''); $_SERVER = []; $_REQUEST = []; Flight::init(); @@ -43,6 +46,10 @@ class RouteCommandTest extends TestCase unset($_REQUEST); unset($_SERVER); Flight::clear(); + + // Thanks Windows + clearstatcache(); + gc_collect_cycles(); } protected function newApp(string $name, string $version = '') @@ -54,7 +61,7 @@ class RouteCommandTest extends TestCase protected function createIndexFile() { - $index = <<500 Internal Server Error

%s (%s)

%s