|
| 1 | +<?php |
| 2 | + |
| 3 | +declare(strict_types=1); |
| 4 | + |
| 5 | +namespace PhpMyAdmin\Tests\Controllers; |
| 6 | + |
| 7 | +use PhpMyAdmin\Config; |
| 8 | +use PhpMyAdmin\Controllers\ChangeLogController; |
| 9 | +use PhpMyAdmin\Http\Factory\ServerRequestFactory; |
| 10 | +use PhpMyAdmin\Template; |
| 11 | +use PhpMyAdmin\Tests\AbstractTestCase; |
| 12 | +use PhpMyAdmin\Tests\Stubs\ResponseRenderer; |
| 13 | +use PHPUnit\Framework\Attributes\CoversClass; |
| 14 | +use PHPUnit\Framework\Attributes\RequiresPhpExtension; |
| 15 | + |
| 16 | +use const TEST_PATH; |
| 17 | + |
| 18 | +#[CoversClass(ChangeLogController::class)] |
| 19 | +final class ChangeLogControllerTest extends AbstractTestCase |
| 20 | +{ |
| 21 | + public function testWithValidFile(): void |
| 22 | + { |
| 23 | + $config = self::createStub(Config::class); |
| 24 | + $config->method('getChangeLogFilePath')->willReturn(TEST_PATH . 'tests/test_data/changelog/ChangeLog'); |
| 25 | + |
| 26 | + $request = ServerRequestFactory::create()->createServerRequest('GET', 'http://example.com/'); |
| 27 | + |
| 28 | + $responseRenderer = new ResponseRenderer(); |
| 29 | + $template = new Template(); |
| 30 | + $controller = new ChangeLogController($responseRenderer, $template, $config); |
| 31 | + $controller($request); |
| 32 | + |
| 33 | + self::assertTrue($responseRenderer->isDisabled()); |
| 34 | + $response = $responseRenderer->getResponse(); |
| 35 | + self::assertSame(['text/html; charset=utf-8'], $response->getHeader('Content-Type')); |
| 36 | + |
| 37 | + // phpcs:disable Generic.Files.LineLength.TooLong |
| 38 | + $changelog = <<<'HTML' |
| 39 | +phpMyAdmin - ChangeLog |
| 40 | +====================== |
| 41 | +
|
| 42 | +5.2.2 (not yet released) |
| 43 | +- <a target="_blank" rel="noopener noreferrer" href="index.php?route=/url&lang=en&url=https://github.com/phpmyadmin/phpmyadmin/issues/17522">issue #17522</a> Fix case where the routes cache file is invalid |
| 44 | +- issue Upgrade slim/psr7 to 1.4.1 for <a target="_blank" rel="noopener noreferrer" href="index.php?route=/url&lang=en&url=https://www.cve.org/CVERecord?id=CVE-2023-30536">CVE-2023-30536</a> - GHSA-q2qj-628g-vhfw |
| 45 | +
|
| 46 | +5.2.1 (2023-02-07) |
| 47 | +- <a target="_blank" rel="noopener noreferrer" href="index.php?route=/url&lang=en&url=https://github.com/phpmyadmin/phpmyadmin/issues/16418">issue #16418</a> Fix <a target="_blank" rel="noopener noreferrer" href="index.php?route=/url&lang=en&url=https://docs.phpmyadmin.net/en/latest/faq.html#faq1-44">FAQ 1.44</a> about manually removing vendor folders |
| 48 | +- issue [security] Fix an XSS attack through the drag-and-drop upload feature (<a target="_blank" rel="noopener noreferrer" href="index.php?route=/url&lang=en&url=https://www.phpmyadmin.net/security/PMASA-2023-01/">PMASA-2023-01</a>) |
| 49 | +
|
| 50 | + --- Older ChangeLogs can be found on our project website --- |
| 51 | + <a target="_blank" rel="noopener noreferrer" href="index.php?route=/url&lang=en&url=https://www.phpmyadmin.net/old-stuff/ChangeLogs/">https://www.phpmyadmin.net/old-stuff/ChangeLogs/</a> |
| 52 | + |
| 53 | +HTML; |
| 54 | + // phpcs:enable |
| 55 | + $expected = $template->render('changelog', ['changelog' => $changelog]); |
| 56 | + |
| 57 | + self::assertSame($expected, $responseRenderer->getHTMLResult()); |
| 58 | + } |
| 59 | + |
| 60 | + #[RequiresPhpExtension('zlib')] |
| 61 | + public function testWithCompressedFile(): void |
| 62 | + { |
| 63 | + $config = self::createStub(Config::class); |
| 64 | + $config->method('getChangeLogFilePath')->willReturn(TEST_PATH . 'tests/test_data/changelog/ChangeLog.gz'); |
| 65 | + |
| 66 | + $request = ServerRequestFactory::create()->createServerRequest('GET', 'http://example.com/'); |
| 67 | + |
| 68 | + $responseRenderer = new ResponseRenderer(); |
| 69 | + $controller = new ChangeLogController($responseRenderer, new Template(), $config); |
| 70 | + $controller($request); |
| 71 | + |
| 72 | + self::assertStringContainsString( |
| 73 | + '- <a target="_blank" rel="noopener noreferrer"' |
| 74 | + . ' href="index.php?route=/url&lang=en&url=https://github.com/phpmyadmin/phpmyadmin/issues/16418">' |
| 75 | + . 'issue #16418</a> Fix <a target="_blank" rel="noopener noreferrer"' |
| 76 | + . ' href="index.php?route=/url&lang=en&url=https://docs.phpmyadmin.net/en/latest/faq.html#faq1-44">' |
| 77 | + . 'FAQ 1.44</a> about manually removing vendor folders', |
| 78 | + $responseRenderer->getHTMLResult(), |
| 79 | + ); |
| 80 | + } |
| 81 | + |
| 82 | + public function testWithInvalidFile(): void |
| 83 | + { |
| 84 | + $config = self::createStub(Config::class); |
| 85 | + $config->method('getChangeLogFilePath')->willReturn(TEST_PATH . 'tests/test_data/changelog/InvalidChangeLog'); |
| 86 | + |
| 87 | + $request = ServerRequestFactory::create()->createServerRequest('GET', 'http://example.com/'); |
| 88 | + |
| 89 | + $responseRenderer = new ResponseRenderer(); |
| 90 | + $controller = new ChangeLogController($responseRenderer, new Template(), $config); |
| 91 | + $controller($request); |
| 92 | + |
| 93 | + self::assertSame('', $responseRenderer->getHTMLResult()); |
| 94 | + self::assertSame( |
| 95 | + 'The ' . TEST_PATH . 'tests/test_data/changelog/InvalidChangeLog file is not available on this system,' |
| 96 | + . ' please visit <a href="https://www.phpmyadmin.net/">phpmyadmin.net</a> for more information.', |
| 97 | + self::getActualOutputForAssertion(), |
| 98 | + ); |
| 99 | + } |
| 100 | +} |
0 commit comments