From 5217ac9dc68370b8f7630fe635812ac9ad262e1e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Michal=20=C5=A0pa=C4=8Dek?= Date: Sat, 23 Nov 2024 00:44:40 +0100 Subject: [PATCH 1/3] Test on PHP 8.4 except Psalm --- .github/workflows/php-tester-include-skipped.yml | 1 + .github/workflows/php.yml | 11 +++++++++++ .github/workflows/securitytxt.yml | 1 + .github/workflows/tls.yml | 1 + 4 files changed, 14 insertions(+) diff --git a/.github/workflows/php-tester-include-skipped.yml b/.github/workflows/php-tester-include-skipped.yml index c6d72e642..ed9dcfd55 100644 --- a/.github/workflows/php-tester-include-skipped.yml +++ b/.github/workflows/php-tester-include-skipped.yml @@ -15,6 +15,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2 diff --git a/.github/workflows/php.yml b/.github/workflows/php.yml index 534b1dd0d..1a6b41964 100644 --- a/.github/workflows/php.yml +++ b/.github/workflows/php.yml @@ -15,6 +15,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - name: OS info run: cat /etc/os-release @@ -33,6 +34,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Validate composer.json and composer.lock @@ -50,6 +52,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2 @@ -70,6 +73,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2 @@ -84,6 +88,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2 @@ -98,6 +103,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2 @@ -118,6 +124,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Get PHP_CodeSniffer cache file pattern @@ -139,6 +146,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Get PHPStan result cache directory @@ -160,6 +168,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Get PHPStan result cache directory @@ -181,6 +190,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2 @@ -223,6 +233,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2 diff --git a/.github/workflows/securitytxt.yml b/.github/workflows/securitytxt.yml index 7345687e5..d97fc9e09 100644 --- a/.github/workflows/securitytxt.yml +++ b/.github/workflows/securitytxt.yml @@ -16,6 +16,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" host: - www.michalspacek.cz - www.michalspacek.com diff --git a/.github/workflows/tls.yml b/.github/workflows/tls.yml index 1302d7a88..612984bfb 100644 --- a/.github/workflows/tls.yml +++ b/.github/workflows/tls.yml @@ -55,6 +55,7 @@ jobs: matrix: php-version: - "8.3" + - "8.4" steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2 From aa8169854c8faef3cac2c21fc7a14ebca516004c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Michal=20=C5=A0pa=C4=8Dek?= Date: Sat, 23 Nov 2024 01:02:42 +0100 Subject: [PATCH 2/3] Implicitly nullable parameter types are deprecated in PHP 8.4 --- app/src/Templating/TemplateFactory.php | 2 +- app/src/Test/Http/Request.php | 4 ++-- app/src/Test/Http/Response.php | 14 +++++++------- app/src/Www/Presenters/BasePresenter.php | 2 +- 4 files changed, 11 insertions(+), 11 deletions(-) diff --git a/app/src/Templating/TemplateFactory.php b/app/src/Templating/TemplateFactory.php index 88cb683c1..1b291dc78 100644 --- a/app/src/Templating/TemplateFactory.php +++ b/app/src/Templating/TemplateFactory.php @@ -25,7 +25,7 @@ public function __construct( #[Override] - public function createTemplate(Control $control = null, string $class = null): DefaultTemplate + public function createTemplate(?Control $control = null, ?string $class = null): DefaultTemplate { $template = $this->templateFactory->createTemplate($control, $class); if (!$template instanceof DefaultTemplate) { diff --git a/app/src/Test/Http/Request.php b/app/src/Test/Http/Request.php index 221ec3b6b..866b97777 100644 --- a/app/src/Test/Http/Request.php +++ b/app/src/Test/Http/Request.php @@ -57,14 +57,14 @@ public function setUrl(UrlScript $url): void #[Override] - public function getQuery(string $key = null) + public function getQuery(?string $key = null) { return $key === null ? $this->url->getQueryParameters() : $this->url->getQueryParameter($key); } #[Override] - public function getPost(string $key = null) + public function getPost(?string $key = null) { return func_num_args() === 0 ? $this->post : $this->post[$key] ?? null; } diff --git a/app/src/Test/Http/Response.php b/app/src/Test/Http/Response.php index c16a7671a..536fa6266 100644 --- a/app/src/Test/Http/Response.php +++ b/app/src/Test/Http/Response.php @@ -85,7 +85,7 @@ public function addHeader(string $name, string $value): self #[Override] - public function setContentType(string $type, string $charset = null): self + public function setContentType(string $type, ?string $charset = null): self { $this->contentType = $type; $this->contentCharset = $charset; @@ -147,11 +147,11 @@ public function setCookie( string $name, string $value, string|int|DateTimeInterface|null $expire, - string $path = null, - string $domain = null, - bool $secure = null, - bool $httpOnly = null, - string $sameSite = null, + ?string $path = null, + ?string $domain = null, + ?bool $secure = null, + ?bool $httpOnly = null, + ?string $sameSite = null, ): self { $this->cookies[$name][] = new Cookie( $name, @@ -166,7 +166,7 @@ public function setCookie( #[Override] - public function deleteCookie(string $name, string $path = null, string $domain = null, bool $secure = null): void + public function deleteCookie(string $name, ?string $path = null, ?string $domain = null, ?bool $secure = null): void { unset($this->cookies[$name]); } diff --git a/app/src/Www/Presenters/BasePresenter.php b/app/src/Www/Presenters/BasePresenter.php index 5a97a13a0..4c670686c 100644 --- a/app/src/Www/Presenters/BasePresenter.php +++ b/app/src/Www/Presenters/BasePresenter.php @@ -149,7 +149,7 @@ protected function getLocaleLinkParams(): array #[Override] - public function lastModified(string|int|DateTimeInterface|null $lastModified, string $etag = null, string $expire = null): void + public function lastModified(string|int|DateTimeInterface|null $lastModified, ?string $etag = null, ?string $expire = null): void { $compression = ini_get('zlib.output_compression'); ini_set('zlib.output_compression', false); From 09b75cfa13e59718fb14958a3d06b0188e715158 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Michal=20=C5=A0pa=C4=8Dek?= Date: Sat, 23 Nov 2024 02:10:10 +0100 Subject: [PATCH 3/3] Use a real .zip file in the test as that's the file type the class is using the most often The PHP source code started to be detected as application/javascript on PHP 8.4 either because bundled libmagic has been updated, or because the setup-php action uses its own or something. --- .../Training/Files/TrainingFilesDownloadTest.phpt | 4 ++-- app/tests/Training/Files/file.zip | Bin 0 -> 22 bytes 2 files changed, 2 insertions(+), 2 deletions(-) create mode 100644 app/tests/Training/Files/file.zip diff --git a/app/tests/Training/Files/TrainingFilesDownloadTest.phpt b/app/tests/Training/Files/TrainingFilesDownloadTest.phpt index 9838417a8..c7a73da40 100644 --- a/app/tests/Training/Files/TrainingFilesDownloadTest.phpt +++ b/app/tests/Training/Files/TrainingFilesDownloadTest.phpt @@ -113,7 +113,7 @@ class TrainingFilesDownloadTest extends TestCase $sessionSection = $this->session->getSection('training'); $sessionSection->set('applicationId', self::APPLICATION_ID); $sessionSection->set('token', self::TOKEN); - $filename = basename(__FILE__); + $filename = 'file.zip'; $filesDir = __DIR__ . '/'; $this->database->setFetchResult([ 'added' => new DateTime(), @@ -125,7 +125,7 @@ class TrainingFilesDownloadTest extends TestCase $response = $this->trainingFilesDownload->getFileResponse('foo'); Assert::same($filesDir . $filename, $response->getFile()); Assert::same($filename, $response->getName()); - Assert::same('text/x-php', $response->getContentType()); + Assert::same('application/zip', $response->getContentType()); } diff --git a/app/tests/Training/Files/file.zip b/app/tests/Training/Files/file.zip new file mode 100644 index 0000000000000000000000000000000000000000..15cb0ecb3e219d1701294bfdf0fe3f5cb5d208e7 GIT binary patch literal 22 NcmWIWW@Tf*000g10H*)| literal 0 HcmV?d00001