From 5ab89da146929734a39c7a55619b8bf8298ab832 Mon Sep 17 00:00:00 2001 From: Daniel Weipert Date: Tue, 12 Aug 2025 18:02:39 +0200 Subject: implement phpunit integration tests --- .../ServerExtension/PostRunSubscriber.php | 19 +++++++++++ .../ServerExtension/PreRunSubscriber.php | 18 +++++++++++ .../Extensions/ServerExtension/ServerExtension.php | 19 +++++++++++ tests/PHPUnit/TestCases/HttpResponseTestCase.php | 37 ++++++++++++++++++++++ tests/ServerImplementationTest.php | 36 +++++++++++++++++++++ 5 files changed, 129 insertions(+) create mode 100644 tests/PHPUnit/Extensions/ServerExtension/PostRunSubscriber.php create mode 100644 tests/PHPUnit/Extensions/ServerExtension/PreRunSubscriber.php create mode 100644 tests/PHPUnit/Extensions/ServerExtension/ServerExtension.php create mode 100644 tests/PHPUnit/TestCases/HttpResponseTestCase.php create mode 100644 tests/ServerImplementationTest.php (limited to 'tests') diff --git a/tests/PHPUnit/Extensions/ServerExtension/PostRunSubscriber.php b/tests/PHPUnit/Extensions/ServerExtension/PostRunSubscriber.php new file mode 100644 index 0000000..308394e --- /dev/null +++ b/tests/PHPUnit/Extensions/ServerExtension/PostRunSubscriber.php @@ -0,0 +1,19 @@ +dataObject->process_id > 0) { + exec("kill {$this->dataObject->process_id}"); + } + } +} diff --git a/tests/PHPUnit/Extensions/ServerExtension/PreRunSubscriber.php b/tests/PHPUnit/Extensions/ServerExtension/PreRunSubscriber.php new file mode 100644 index 0000000..ba35ee7 --- /dev/null +++ b/tests/PHPUnit/Extensions/ServerExtension/PreRunSubscriber.php @@ -0,0 +1,18 @@ +dataObject->process_id = (int)shell_exec("php -S localhost:8080 -t public > /dev/null 2>&1 & echo $!"); + sleep(1); + } +} diff --git a/tests/PHPUnit/Extensions/ServerExtension/ServerExtension.php b/tests/PHPUnit/Extensions/ServerExtension/ServerExtension.php new file mode 100644 index 0000000..a98f593 --- /dev/null +++ b/tests/PHPUnit/Extensions/ServerExtension/ServerExtension.php @@ -0,0 +1,19 @@ +registerSubscriber(new PreRunSubscriber($dataObject)); + $facade->registerSubscriber(new PostRunSubscriber($dataObject)); + } +} diff --git a/tests/PHPUnit/TestCases/HttpResponseTestCase.php b/tests/PHPUnit/TestCases/HttpResponseTestCase.php new file mode 100644 index 0000000..855e594 --- /dev/null +++ b/tests/PHPUnit/TestCases/HttpResponseTestCase.php @@ -0,0 +1,37 @@ +client = new Client([ + "base_uri" => "http://localhost:8080", + ]); + } + + /** + * @param array $options + */ + public function request(string $method, string $path, array $options = []): Response + { + return $this->client->request( + $method, + $path, + ["http_errors" => false] + $options + ); + } + + public function hasJsonBody(Response $response): bool + { + json_decode((string)$response->getBody()); + return json_last_error() === JSON_ERROR_NONE; + } +} diff --git a/tests/ServerImplementationTest.php b/tests/ServerImplementationTest.php new file mode 100644 index 0000000..88be7c4 --- /dev/null +++ b/tests/ServerImplementationTest.php @@ -0,0 +1,36 @@ +request("GET", "/_matrix/federation/v1/version"); + + $this->assertEquals(Response::HTTP_OK, $response->getStatusCode()); + $this->assertTrue($this->hasJsonBody($response)); + + $body = json_decode((string)$response->getBody(), true); + + $this->assertArrayHasKey("server", $body); + $this->assertArrayHasKey("name", $body["server"]); + $this->assertArrayHasKey("version", $body["server"]); + } + + public function testVersions(): void + { + $response = $this->request("GET", "/_matrix/client/versions"); + + $this->assertEquals(Response::HTTP_OK, $response->getStatusCode()); + $this->assertTrue($this->hasJsonBody($response)); + + $body = json_decode((string)$response->getBody(), true); + + $this->assertIsArray($body["versions"]); + $this->assertTrue(count($body["versions"]) > 0); + } +} -- cgit v1.2.3