From b2332c0deedd12a64ac3af3516cc4252929b303c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tomasz=20Wolda=C5=84ski?= Date: Wed, 16 Oct 2024 13:37:21 +0200 Subject: [PATCH] [TASK] Improve tests for v13 LTS & PHPUnit v11 --- .../{BaseTest.php => BaseHeadlessTesting.php} | 4 +- ...ypeTest.php => BaseContentTypeTesting.php} | 12 +- .../ContentTypes/BasicListElementTest.php | 2 +- .../ContentTypes/BulletsElementTest.php | 2 +- .../ContentTypes/DefaultContentsTest.php | 2 +- .../ContentTypes/DivElementTest.php | 2 +- .../ContentTypes/HeaderElementTest.php | 2 +- .../ContentTypes/HtmlElementTest.php | 2 +- .../ContentTypes/ImageElementTest.php | 2 +- .../MenuAbstractPagesElementTest.php | 2 +- .../MenuCategorizedContentElementTest.php | 2 +- .../MenuCategorizedPagesElementTest.php | 2 +- .../ContentTypes/MenuPagesElementTest.php | 2 +- .../MenuRecentlyUpdatedPagesElementTest.php | 16 +- .../MenuRelatedPagesElementTest.php | 2 +- .../ContentTypes/MenuSectionElementTest.php | 2 +- .../ContentTypes/MenuSitemapElementTest.php | 2 +- .../MenuSitemapSelectedPagesElementTest.php | 2 +- .../ContentTypes/MenuSubpagesElementTest.php | 2 +- .../ContentTypes/ShortcutElementTest.php | 2 +- .../ContentTypes/TableElementTest.php | 2 +- .../ContentTypes/TextElementTest.php | 2 +- .../ContentTypes/TextMediaElementTest.php | 2 +- .../ContentTypes/TextpicElementTest.php | 2 +- Tests/Functional/Fixtures/content.csv | 55 +++ Tests/Functional/Fixtures/content.xml | 455 ------------------ Tests/Functional/Fixtures/pages.csv | 12 + Tests/Functional/Fixtures/pages.xml | 89 ---- ...t.php => BasePageTypesHeadlessTesting.php} | 4 +- .../PageTypes/SchemaPageTypesTest.php | 12 +- .../PageTypes/StructurePageTypesTest.php | 7 +- Tests/Functional/phpunit.xml | 37 +- .../BooleanContentObjectTest.php | 13 +- .../ContentObject/FloatContentObjectTest.php | 15 +- .../IntegerContentObjectTest.php | 15 +- .../ContentObject/JsonContentObjectTest.php | 13 +- .../DataProcessingTraitTest.php | 13 +- .../DatabaseQueryProcessorTest.php | 20 +- .../RootSiteProcessing/DomainSchemaTest.php | 14 +- .../DataProcessing/RootSitesProcessorTest.php | 20 +- .../AfterLinkIsGeneratedListenerTest.php | 22 +- ...terPagePreviewUriGeneratedListenerTest.php | 22 +- ...edirectUrlAdditionalParamsListenerTest.php | 16 +- Tests/Unit/Event/RedirectUrlEventTest.php | 5 +- .../AbstractFormDefinitionDecoratorTest.php | 20 +- Tests/Unit/Hooks/HeadlessUserIntTest.php | 40 +- Tests/Unit/Json/JsonDecoderTest.php | 15 +- Tests/Unit/Json/JsonEncoderTest.php | 12 +- .../Middleware/CookieDomainPerSiteTest.php | 29 +- .../ElementBodyResponseMiddlewareTest.php | 5 +- .../SiteBaseRedirectResolverTest.php | 12 +- .../Unit/Middleware/UserIntMiddlewareTest.php | 7 +- Tests/Unit/Utility/UrlUtilityTest.php | 76 +-- Tests/Unit/XClass/TemplateViewTest.php | 2 + Tests/Unit/phpunit.xml | 27 +- composer.json | 4 +- 56 files changed, 305 insertions(+), 877 deletions(-) rename Tests/Functional/{BaseTest.php => BaseHeadlessTesting.php} (97%) rename Tests/Functional/ContentTypes/{BaseContentTypeTest.php => BaseContentTypeTesting.php} (93%) create mode 100644 Tests/Functional/Fixtures/content.csv delete mode 100644 Tests/Functional/Fixtures/content.xml create mode 100644 Tests/Functional/Fixtures/pages.csv delete mode 100644 Tests/Functional/Fixtures/pages.xml rename Tests/Functional/PageTypes/{BasePageTypesTest.php => BasePageTypesHeadlessTesting.php} (92%) diff --git a/Tests/Functional/BaseTest.php b/Tests/Functional/BaseHeadlessTesting.php similarity index 97% rename from Tests/Functional/BaseTest.php rename to Tests/Functional/BaseHeadlessTesting.php index b8b1f163..08e49125 100644 --- a/Tests/Functional/BaseTest.php +++ b/Tests/Functional/BaseHeadlessTesting.php @@ -18,7 +18,7 @@ use TYPO3\CMS\Core\Utility\ExtensionManagementUtility; use TYPO3\TestingFramework\Core\Functional\FunctionalTestCase; -abstract class BaseTest extends FunctionalTestCase +abstract class BaseHeadlessTesting extends FunctionalTestCase { protected array $coreExtensionsToLoad = [ 'install', @@ -34,7 +34,7 @@ public function setUp(): void { parent::setUp(); - $this->importDataSet(__DIR__ . '/Fixtures/pages.xml'); + $this->importCSVDataSet(__DIR__ . '/Fixtures/pages.csv'); $this->setUpFrontendRootPage( 1, diff --git a/Tests/Functional/ContentTypes/BaseContentTypeTest.php b/Tests/Functional/ContentTypes/BaseContentTypeTesting.php similarity index 93% rename from Tests/Functional/ContentTypes/BaseContentTypeTest.php rename to Tests/Functional/ContentTypes/BaseContentTypeTesting.php index c5652b29..fc7025f4 100644 --- a/Tests/Functional/ContentTypes/BaseContentTypeTest.php +++ b/Tests/Functional/ContentTypes/BaseContentTypeTesting.php @@ -11,9 +11,9 @@ namespace FriendsOfTYPO3\Headless\Tests\Functional\ContentTypes; -use FriendsOfTYPO3\Headless\Tests\Functional\BaseTest; +use FriendsOfTYPO3\Headless\Tests\Functional\BaseHeadlessTesting; -class BaseContentTypeTest extends BaseTest +abstract class BaseContentTypeTesting extends BaseHeadlessTesting { /** * set up objects @@ -22,7 +22,7 @@ public function setUp(): void { parent::setUp(); - $this->importDataSet(__DIR__ . '/../Fixtures/content.xml'); + $this->importCSVDataSet(__DIR__ . '/../Fixtures/content.csv'); } protected function checkDefaultContentFields($contentElement, $id, $pid, $type, $colPos = 0, $categories = '') @@ -54,12 +54,12 @@ protected function checkHeaderFields($contentElement, $header = '', $subheader = self::assertTrue(isset($contentElementContent['headerLink']), 'headerLink not set'); } - protected function checkHeaderFieldsLink($contentElement, $linkText, $urlPrefix, $target) + protected function checkHeaderFieldsLink($contentElement, $link, $urlPrefix, $target) { $contentElementHeaderFieldsLink = $contentElement['content']['headerLink']; self::assertIsArray($contentElementHeaderFieldsLink, 'headerLink not an array'); - self::assertEquals($linkText, $contentElementHeaderFieldsLink['linkText'], 'linkText mismatch'); + self::assertEquals($link, $contentElementHeaderFieldsLink['linkText'], 'linkText mismatch'); self::assertStringStartsWith($urlPrefix, $contentElementHeaderFieldsLink['href'], 'url mismatch'); self::assertEquals($target, $contentElementHeaderFieldsLink['target'], 'target mismatch'); } @@ -90,7 +90,7 @@ protected function checkGalleryContentFields($contentElement) self::assertIsArray($contentElement['content']['gallery']['rows'][1]['columns'], 'rows.columns not set'); self::assertCount(1, $contentElement['content']['gallery']['rows'][1]['columns'], 'rows.columns count mismatch'); - $this->checkGalleryFile($contentElement['content']['gallery']['rows'][1]['columns'][1], '/typo3conf/ext/headless/ext_icon.gif', 'image/gif', 'MetadataTitle', 18, 16, null); + $this->checkGalleryFile($contentElement['content']['gallery']['rows'][1]['columns'][1], 'typo3conf/ext/headless/ext_icon.gif', 'image/gif', 'MetadataTitle', 18, 16, null); } protected function checkGalleryFile($fileElement, $originalUrl, $mimeType, $title, $width, $height, $autoplay) diff --git a/Tests/Functional/ContentTypes/BasicListElementTest.php b/Tests/Functional/ContentTypes/BasicListElementTest.php index 985170ba..535ddfe1 100644 --- a/Tests/Functional/ContentTypes/BasicListElementTest.php +++ b/Tests/Functional/ContentTypes/BasicListElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class BasicListElementTest extends BaseContentTypeTest +class BasicListElementTest extends BaseContentTypeTesting { public function testBasicListContentElement() { diff --git a/Tests/Functional/ContentTypes/BulletsElementTest.php b/Tests/Functional/ContentTypes/BulletsElementTest.php index 3684bc85..ed3af242 100644 --- a/Tests/Functional/ContentTypes/BulletsElementTest.php +++ b/Tests/Functional/ContentTypes/BulletsElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class BulletsElementTest extends BaseContentTypeTest +class BulletsElementTest extends BaseContentTypeTesting { public function testBulletsContentElement() { diff --git a/Tests/Functional/ContentTypes/DefaultContentsTest.php b/Tests/Functional/ContentTypes/DefaultContentsTest.php index 68fbca8e..c10a281e 100644 --- a/Tests/Functional/ContentTypes/DefaultContentsTest.php +++ b/Tests/Functional/ContentTypes/DefaultContentsTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class DefaultContentsTest extends BaseContentTypeTest +class DefaultContentsTest extends BaseContentTypeTesting { public function testContentStructure() { diff --git a/Tests/Functional/ContentTypes/DivElementTest.php b/Tests/Functional/ContentTypes/DivElementTest.php index 011774a5..124355a5 100644 --- a/Tests/Functional/ContentTypes/DivElementTest.php +++ b/Tests/Functional/ContentTypes/DivElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class DivElementTest extends BaseContentTypeTest +class DivElementTest extends BaseContentTypeTesting { public function testDivContentElement() { diff --git a/Tests/Functional/ContentTypes/HeaderElementTest.php b/Tests/Functional/ContentTypes/HeaderElementTest.php index 73eb00f6..97ad857b 100644 --- a/Tests/Functional/ContentTypes/HeaderElementTest.php +++ b/Tests/Functional/ContentTypes/HeaderElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class HeaderElementTest extends BaseContentTypeTest +class HeaderElementTest extends BaseContentTypeTesting { public function testHeaderContentElement() { diff --git a/Tests/Functional/ContentTypes/HtmlElementTest.php b/Tests/Functional/ContentTypes/HtmlElementTest.php index f94111dd..a6ca5be8 100644 --- a/Tests/Functional/ContentTypes/HtmlElementTest.php +++ b/Tests/Functional/ContentTypes/HtmlElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class HtmlElementTest extends BaseContentTypeTest +class HtmlElementTest extends BaseContentTypeTesting { public function testHtmlContentElement() { diff --git a/Tests/Functional/ContentTypes/ImageElementTest.php b/Tests/Functional/ContentTypes/ImageElementTest.php index b4021565..a799ac1a 100644 --- a/Tests/Functional/ContentTypes/ImageElementTest.php +++ b/Tests/Functional/ContentTypes/ImageElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class ImageElementTest extends BaseContentTypeTest +class ImageElementTest extends BaseContentTypeTesting { public function testImageContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuAbstractPagesElementTest.php b/Tests/Functional/ContentTypes/MenuAbstractPagesElementTest.php index 6bdc6658..797dfd4e 100644 --- a/Tests/Functional/ContentTypes/MenuAbstractPagesElementTest.php +++ b/Tests/Functional/ContentTypes/MenuAbstractPagesElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuAbstractPagesElementTest extends BaseContentTypeTest +class MenuAbstractPagesElementTest extends BaseContentTypeTesting { public function testMenuContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuCategorizedContentElementTest.php b/Tests/Functional/ContentTypes/MenuCategorizedContentElementTest.php index 9b28180c..1aac8129 100644 --- a/Tests/Functional/ContentTypes/MenuCategorizedContentElementTest.php +++ b/Tests/Functional/ContentTypes/MenuCategorizedContentElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuCategorizedContentElementTest extends BaseContentTypeTest +class MenuCategorizedContentElementTest extends BaseContentTypeTesting { public function testMenuContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuCategorizedPagesElementTest.php b/Tests/Functional/ContentTypes/MenuCategorizedPagesElementTest.php index 1ffa48dd..22c3c7d6 100644 --- a/Tests/Functional/ContentTypes/MenuCategorizedPagesElementTest.php +++ b/Tests/Functional/ContentTypes/MenuCategorizedPagesElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuCategorizedPagesElementTest extends BaseContentTypeTest +class MenuCategorizedPagesElementTest extends BaseContentTypeTesting { public function testMenuContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuPagesElementTest.php b/Tests/Functional/ContentTypes/MenuPagesElementTest.php index f45682ad..5fcb33a0 100644 --- a/Tests/Functional/ContentTypes/MenuPagesElementTest.php +++ b/Tests/Functional/ContentTypes/MenuPagesElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuPagesElementTest extends BaseContentTypeTest +class MenuPagesElementTest extends BaseContentTypeTesting { public function testMenuContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuRecentlyUpdatedPagesElementTest.php b/Tests/Functional/ContentTypes/MenuRecentlyUpdatedPagesElementTest.php index 0d39c1ee..dad36e9b 100644 --- a/Tests/Functional/ContentTypes/MenuRecentlyUpdatedPagesElementTest.php +++ b/Tests/Functional/ContentTypes/MenuRecentlyUpdatedPagesElementTest.php @@ -16,7 +16,7 @@ use TYPO3\CMS\Core\Utility\GeneralUtility; use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuRecentlyUpdatedPagesElementTest extends BaseContentTypeTest +class MenuRecentlyUpdatedPagesElementTest extends BaseContentTypeTesting { public function setUp(): void { @@ -26,9 +26,17 @@ public function setUp(): void $modifiedSevenDayAgo = (clone $currentDate)->modify('-7 day'); $modifiedEightDayAgo = (clone $currentDate)->modify('-8 day'); $connection = GeneralUtility::makeInstance(ConnectionPool::class)->getConnectionForTable('pages'); - $connection->prepare('update pages set SYS_LASTCHANGED = ? WHERE uid = 2')->execute([$modifiedOneDayAgo->getTimestamp()]); - $connection->prepare('update pages set SYS_LASTCHANGED = ? WHERE uid = 3')->execute([$modifiedSevenDayAgo->getTimestamp()]); - $connection->prepare('update pages set SYS_LASTCHANGED = ? WHERE uid = 4')->execute([$modifiedEightDayAgo->getTimestamp()]); + $sql = $connection->prepare('update pages set SYS_LASTCHANGED = :change WHERE uid = 2'); + $sql->bindValue(':change', $modifiedOneDayAgo->getTimestamp()); + $sql->executeStatement(); + + $sql = $connection->prepare('update pages set SYS_LASTCHANGED = :change WHERE uid = 3'); + $sql->bindValue(':change', $modifiedSevenDayAgo->getTimestamp()); + $sql->executeStatement(); + + $sql = $connection->prepare('update pages set SYS_LASTCHANGED = :change WHERE uid = 4'); + $sql->bindValue(':change', $modifiedEightDayAgo->getTimestamp()); + $sql->executeStatement(); } public function testMenuContentElement() diff --git a/Tests/Functional/ContentTypes/MenuRelatedPagesElementTest.php b/Tests/Functional/ContentTypes/MenuRelatedPagesElementTest.php index 69720c43..1b07c95d 100644 --- a/Tests/Functional/ContentTypes/MenuRelatedPagesElementTest.php +++ b/Tests/Functional/ContentTypes/MenuRelatedPagesElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuRelatedPagesElementTest extends BaseContentTypeTest +class MenuRelatedPagesElementTest extends BaseContentTypeTesting { public function testMenuContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuSectionElementTest.php b/Tests/Functional/ContentTypes/MenuSectionElementTest.php index 86f1574e..569d1aec 100644 --- a/Tests/Functional/ContentTypes/MenuSectionElementTest.php +++ b/Tests/Functional/ContentTypes/MenuSectionElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuSectionElementTest extends BaseContentTypeTest +class MenuSectionElementTest extends BaseContentTypeTesting { public function testMenuContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuSitemapElementTest.php b/Tests/Functional/ContentTypes/MenuSitemapElementTest.php index d3f82498..54fe8d34 100644 --- a/Tests/Functional/ContentTypes/MenuSitemapElementTest.php +++ b/Tests/Functional/ContentTypes/MenuSitemapElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuSitemapElementTest extends BaseContentTypeTest +class MenuSitemapElementTest extends BaseContentTypeTesting { public function testMenuContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuSitemapSelectedPagesElementTest.php b/Tests/Functional/ContentTypes/MenuSitemapSelectedPagesElementTest.php index c0a967f1..96800b47 100644 --- a/Tests/Functional/ContentTypes/MenuSitemapSelectedPagesElementTest.php +++ b/Tests/Functional/ContentTypes/MenuSitemapSelectedPagesElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuSitemapSelectedPagesElementTest extends BaseContentTypeTest +class MenuSitemapSelectedPagesElementTest extends BaseContentTypeTesting { public function testMenuContentElement() { diff --git a/Tests/Functional/ContentTypes/MenuSubpagesElementTest.php b/Tests/Functional/ContentTypes/MenuSubpagesElementTest.php index a3273314..a0b2205e 100644 --- a/Tests/Functional/ContentTypes/MenuSubpagesElementTest.php +++ b/Tests/Functional/ContentTypes/MenuSubpagesElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class MenuSubpagesElementTest extends BaseContentTypeTest +class MenuSubpagesElementTest extends BaseContentTypeTesting { public function testMenuSubpagesContentElement() { diff --git a/Tests/Functional/ContentTypes/ShortcutElementTest.php b/Tests/Functional/ContentTypes/ShortcutElementTest.php index 159df9cc..5331c14e 100644 --- a/Tests/Functional/ContentTypes/ShortcutElementTest.php +++ b/Tests/Functional/ContentTypes/ShortcutElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class ShortcutElementTest extends BaseContentTypeTest +class ShortcutElementTest extends BaseContentTypeTesting { public function testShortcutContentElement() { diff --git a/Tests/Functional/ContentTypes/TableElementTest.php b/Tests/Functional/ContentTypes/TableElementTest.php index ef641261..bc839dfb 100644 --- a/Tests/Functional/ContentTypes/TableElementTest.php +++ b/Tests/Functional/ContentTypes/TableElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class TableElementTest extends BaseContentTypeTest +class TableElementTest extends BaseContentTypeTesting { public function testTableContentElement() { diff --git a/Tests/Functional/ContentTypes/TextElementTest.php b/Tests/Functional/ContentTypes/TextElementTest.php index 685fbebc..9cfa3c34 100644 --- a/Tests/Functional/ContentTypes/TextElementTest.php +++ b/Tests/Functional/ContentTypes/TextElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class TextElementTest extends BaseContentTypeTest +class TextElementTest extends BaseContentTypeTesting { public function testTextContentElement() { diff --git a/Tests/Functional/ContentTypes/TextMediaElementTest.php b/Tests/Functional/ContentTypes/TextMediaElementTest.php index e3941843..3ebdc69d 100644 --- a/Tests/Functional/ContentTypes/TextMediaElementTest.php +++ b/Tests/Functional/ContentTypes/TextMediaElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class TextMediaElementTest extends BaseContentTypeTest +class TextMediaElementTest extends BaseContentTypeTesting { public function testTextMediaContentElement() { diff --git a/Tests/Functional/ContentTypes/TextpicElementTest.php b/Tests/Functional/ContentTypes/TextpicElementTest.php index ef42108c..2d807660 100644 --- a/Tests/Functional/ContentTypes/TextpicElementTest.php +++ b/Tests/Functional/ContentTypes/TextpicElementTest.php @@ -13,7 +13,7 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class TextpicElementTest extends BaseContentTypeTest +class TextpicElementTest extends BaseContentTypeTesting { public function testTextpicContentElement() { diff --git a/Tests/Functional/Fixtures/content.csv b/Tests/Functional/Fixtures/content.csv new file mode 100644 index 00000000..3013b371 --- /dev/null +++ b/Tests/Functional/Fixtures/content.csv @@ -0,0 +1,55 @@ +tt_content,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, +,uid,pid,sorting,colPos,CType,space_before_class,space_after_class,frame_class,layout,categories,header,subheader,header_layout,header_position,header_link,bodytext,list_type,table_caption,table_delimiter,table_enclosure,table_class,table_tfoot,table_header_position,cols,bullets_type,records,image,assets,pages,selected_categories,category_field +,1,1,1,0,text,SpaceBefore,SpaceAfter,Frame,1,1,Header,SubHeader,1,2,"t3://page?uid=2 _blank LinkClass LinkTitle parameter=999"," +

Link

+ ",,,,,,,,,,,,,,, +,3,1,2,0,header,SpaceBefore,SpaceAfter,Frame,1,1,Header,SubHeader,1,2,"t3://page?uid=2 _blank LinkClass LinkTitle parameter=999",,,,,,,,,,,,,,,, +,4,1,3,0,html,SpaceBefore,SpaceAfter,Frame,1,1,Header,SubHeader,1,2,"t3://page?uid=2 _blank LinkClass LinkTitle parameter=999","Link",,,,,,,,,,,,,,, +,5,1,4,0,div,SpaceBefore,SpaceAfter,Frame,1,1,Header,SubHeader,1,2,"t3://page?uid=2 _blank LinkClass LinkTitle parameter=999","Link",,,,,,,,,,,,,,, +,6,1,5,0,list,SpaceBefore,SpaceAfter,Frame,1,1,Header,SubHeader,1,2,"t3://page?uid=2 _blank LinkClass LinkTitle parameter=999","Link",BasicList,,,,,,,,,,,,,, +,7,1,6,0,table,SpaceBefore,SpaceAfter,Frame,1,1,Header,SubHeader,1,2,"t3://page?uid=2 _blank LinkClass LinkTitle parameter=999","""Cell1.1"";""Cell1.2"";""Cell1.3"";""Cell1.4"" +""Cell2.1"";"""";"""";"""" +""Cell3.1"";"""";"""";"""" +"""""""";"""";"""";""""",,TableCaption,59,34,striped,1,1,6,,,,,,, +,8,1,7,0,bullets,SpaceBefore,SpaceAfter,Frame,1,1,Header,SubHeader,1,2,"t3://page?uid=2 _blank LinkClass LinkTitle parameter=999","Top1 +Top2 +Top3",,,,,,,,,1,,,,,, +,9,1,8,0,shortcut,SpaceBefore,SpaceAfter,Frame,1,1,Header,SubHeader,1,2,"t3://page?uid=2 _blank LinkClass LinkTitle parameter=999",,,,,,,,,,,"pages_1,tt_content_2,tt_content_1",,,,, +,2,1,1,1,textmedia,,,default,,,,,,,,"Link",,,,,,,,,,,1,,,, +,10,1,1,1,image,,,default,,,,,,,,,,,,,,,,,,,,1,,, +,11,1,1,1,textpic,,,default,,,,,,,,"Link",,,,,,,,,,,1,,,, +,12,1,1,1,menu_subpages,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,,, +,13,1,1,1,menu_sitemap,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,"1,2,3",, +,14,1,1,1,menu_pages,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,"1,2,3,4",, +,15,1,1,1,menu_section,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,"1,4",, +,16,1,1,1,menu_recently_updated,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,1,, +,17,1,1,1,header,,,default,,3,,,,,,,,,,,,,,,,,,,,, +,18,1,1,1,textpic,,,default,,3,,,,,,,,,,,,,,,,,,,,, +,19,1,1,1,menu_categorized_content,SpaceBefore,SpaceAfter,default,,3,Header,SubHeader,0,2,,,,,,,,,,,,,,,,3,categories +,20,2,1,1,menu_categorized_pages,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,,3,categories +,21,5,1,1,menu_sitemap_pages,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,5,, +,22,1,1,1,menu_related_pages,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,,, +,23,1,1,1,menu_abstract,SpaceBefore,SpaceAfter,default,,1,Header,SubHeader,0,2,,,,,,,,,,,,,,,5,, +sys_category,,, +,uid,pid,title +,1,0,SysCategory1Title +,2,0,SysCategory2Title +,3,0,SysCategory3Title +sys_category_record_mm,,,,,, +,tablenames,uid_foreign,uid_local,fieldname,sorting,sorting_foreign +,tt_content,1,1,categories,, +,tt_content,1,2,categories,, +,pages,5,3,categories,, +,tt_content,17,3,categories,1,0 +,tt_content,18,3,categories,1,0 +sys_file,,,,,,,,,,,,,, +,uid,pid,storage,type,identifier,identifier_hash,folder_hash,extension,mime_type,name,sha1,size,creation_date,modification_date +,1,0,0,1,/typo3conf/ext/headless/ext_icon.gif,ae03df120da87352822f4aae6d476086cb8c0cf8,85051482e1ba204348a9b9f6c1a37069e77de027,gif,image/gif,ext_icon.gif,4a53ba5b5a156b82e3efd443f9a402f8c6e6dd08,177,1400176659,1400176659 +sys_file_metadata,,,,,, +,uid,pid,file,title,width,height +,1,0,1,MetadataTitle,18,16 +sys_file_reference,,,,,,, +,uid,pid,uid_local,uid_foreign,tablenames,fieldname,autoplay +,1,1,1,2,tt_content,assets,1 +,2,1,1,10,tt_content,image,1 +,3,1,1,11,tt_content,image,1 diff --git a/Tests/Functional/Fixtures/content.xml b/Tests/Functional/Fixtures/content.xml deleted file mode 100644 index 3ada8520..00000000 --- a/Tests/Functional/Fixtures/content.xml +++ /dev/null @@ -1,455 +0,0 @@ - - - - 1 - 1 - 1 - 0 - text - SpaceBefore - SpaceAfter - Frame - 1 - 1 -
Header
- SubHeader - 1 - 2 - t3://page?uid=2 _blank LinkClass LinkTitle parameter=999 - Link

- ]]>
-
- - 3 - 1 - 2 - 0 - header - SpaceBefore - SpaceAfter - Frame - 1 - 1 -
Header
- SubHeader - 1 - 2 - t3://page?uid=2 _blank LinkClass LinkTitle parameter=999 -
- - 4 - 1 - 3 - 0 - html - SpaceBefore - SpaceAfter - Frame - 1 - 1 -
Header
- SubHeader - 1 - 2 - t3://page?uid=2 _blank LinkClass LinkTitle parameter=999 - Link]]> -
- - 5 - 1 - 4 - 0 - div - SpaceBefore - SpaceAfter - Frame - 1 - 1 -
Header
- SubHeader - 1 - 2 - t3://page?uid=2 _blank LinkClass LinkTitle parameter=999 - Link]]> -
- - 6 - 1 - 5 - 0 - list - BasicList - SpaceBefore - SpaceAfter - Frame - 1 - 1 -
Header
- SubHeader - 1 - 2 - t3://page?uid=2 _blank LinkClass LinkTitle parameter=999 - Link]]> -
- - 7 - 1 - 6 - 0 - table - SpaceBefore - SpaceAfter - Frame - 1 - 1 -
Header
- SubHeader - 1 - 2 - t3://page?uid=2 _blank LinkClass LinkTitle parameter=999 - TableCaption - 59 - 34 - striped - 1 - 1 - 6 - -
- - 8 - 1 - 7 - 0 - bullets - SpaceBefore - SpaceAfter - Frame - 1 - 1 -
Header
- SubHeader - 1 - 2 - t3://page?uid=2 _blank LinkClass LinkTitle parameter=999 - 1 - -
- - 9 - 1 - 8 - 0 - shortcut - SpaceBefore - SpaceAfter - Frame - 1 - 1 -
Header
- SubHeader - 1 - 2 - t3://page?uid=2 _blank LinkClass LinkTitle parameter=999 - pages_1,tt_content_2,tt_content_1 -
- - 2 - 1 - 1 - 1 - textmedia - 1 - Link]]> - - - 10 - 1 - 1 - 1 - image - 1 - - - 11 - 1 - 1 - 1 - textpic - 1 - Link]]> - - - 12 - 1 - 1 - 1 - menu_subpages - SpaceBefore - SpaceAfter - 1 -
Header
- SubHeader - 0 - 2 -
- - 13 - 1 - 1 - 1 - menu_sitemap - SpaceBefore - SpaceAfter - 1 -
Header
- SubHeader - 0 - 2 - 1,2,3 -
- - 14 - 1 - 1 - 1 - menu_pages - SpaceBefore - SpaceAfter - 1 -
Header
- SubHeader - 0 - 2 - 1,2,3,4 -
- - 15 - 1 - 1 - 1 - menu_section - SpaceBefore - SpaceAfter - 1 -
Header
- SubHeader - 0 - 2 - 1,4 -
- - 16 - 1 - 1 - 1 - menu_recently_updated - SpaceBefore - SpaceAfter - 1 -
Header
- SubHeader - 0 - 2 - 1 -
- - 17 - 1 - 1 - 1 - header - 3 - - - 18 - 1 - 1 - 1 - textpic - 3 - - - 19 - 1 - 1 - 1 - menu_categorized_content - 3 - 3 - categories - SpaceBefore - SpaceAfter -
Header
- SubHeader - 0 - 2 -
- - 20 - 2 - 1 - 1 - menu_categorized_pages - SpaceBefore - SpaceAfter - 1 - 3 - categories -
Header
- SubHeader - 0 - 2 -
- - 21 - 5 - 1 - 1 - menu_sitemap_pages - SpaceBefore - SpaceAfter - 1 -
Header
- SubHeader - 0 - 2 - 5 -
- - 22 - 1 - 1 - 1 - menu_related_pages - SpaceBefore - SpaceAfter - 1 -
Header
- SubHeader - 0 - 2 -
- - 23 - 1 - 1 - 1 - menu_abstract - SpaceBefore - SpaceAfter - 1 -
Header
- SubHeader - 0 - 2 - 5 -
- - 1 - 0 - SysCategory1Title - - - 2 - 0 - SysCategory2Title - - - 3 - 0 - SysCategory3Title - - - tt_content - 1 - 1 - categories - - - tt_content - 1 - 2 - categories - - - pages - 5 - 3 - categories - - - tt_content - 17 - 3 - categories - 1 - 0 - - - tt_content - 18 - 3 - categories - 1 - 0 - - - 1 - 0 - 0 - 1 - /typo3conf/ext/headless/ext_icon.gif - ae03df120da87352822f4aae6d476086cb8c0cf8 - 85051482e1ba204348a9b9f6c1a37069e77de027 - gif - image/gif - ext_icon.gif - 4a53ba5b5a156b82e3efd443f9a402f8c6e6dd08 - 177 - 1400176659 - 1400176659 - - - 1 - 0 - 1 - MetadataTitle - 18 - 16 - - - 1 - 1 - 1 - 2 - tt_content - assets - 1 - - - 2 - 1 - 1 - 10 - tt_content - image - 1 - - - 3 - 1 - 1 - 11 - tt_content - image - 1 - - -
\ No newline at end of file diff --git a/Tests/Functional/Fixtures/pages.csv b/Tests/Functional/Fixtures/pages.csv new file mode 100644 index 00000000..3eaa70e2 --- /dev/null +++ b/Tests/Functional/Fixtures/pages.csv @@ -0,0 +1,12 @@ +"pages",,,,,,,, +,uid,pid,title,slug,deleted,perms_everybody,keywords,abstract +,1,0,"Root","/",0,15,"test", +,2,1,"Page 1","/page1",0,15,, +,3,2,"Page 1.1","/page1/page1_1",0,15,, +,4,1,"Page 2","/page2",0,15,, +,5,1,"Page 3","/page3",0,15,,"Test" +,6,5,"Page 4","/page4",0,15,,"Test" +,7,6,"Page 5","/page5",0,15,,, +,8,1,"Page 8","/page8",0,15,"test",, +,9,1,"Page 9","/page9",0,15,"test",, +,10,9,"Page 10","/page10",0,15,"test",, diff --git a/Tests/Functional/Fixtures/pages.xml b/Tests/Functional/Fixtures/pages.xml deleted file mode 100644 index 92d914b3..00000000 --- a/Tests/Functional/Fixtures/pages.xml +++ /dev/null @@ -1,89 +0,0 @@ - - - - 1 - 0 - Root - / - 0 - 15 - test - - - 2 - 1 - Page 1 - /page1 - 0 - 15 - - - 3 - 2 - Page 1.1 - /page1/page1_1 - 0 - 15 - - - 4 - 1 - Page 2 - /page2 - 0 - 15 - - - 5 - 1 - Page 3 - /page3 - 0 - Test - 15 - - - 6 - 5 - Page 4 - /page4 - 0 - Test - 15 - - - 7 - 6 - Page 5 - /page5 - 0 - 15 - - - 8 - 1 - Page 8 - /page8 - 0 - 15 - test - - - 9 - 1 - Page 9 - /page9 - 0 - 15 - test - - - 10 - 9 - Page 10 - /page10 - 0 - 15 - test - - \ No newline at end of file diff --git a/Tests/Functional/PageTypes/BasePageTypesTest.php b/Tests/Functional/PageTypes/BasePageTypesHeadlessTesting.php similarity index 92% rename from Tests/Functional/PageTypes/BasePageTypesTest.php rename to Tests/Functional/PageTypes/BasePageTypesHeadlessTesting.php index e485aebf..21a0608a 100644 --- a/Tests/Functional/PageTypes/BasePageTypesTest.php +++ b/Tests/Functional/PageTypes/BasePageTypesHeadlessTesting.php @@ -11,13 +11,13 @@ namespace FriendsOfTYPO3\Headless\Tests\Functional\PageTypes; -use FriendsOfTYPO3\Headless\Tests\Functional\BaseTest; +use FriendsOfTYPO3\Headless\Tests\Functional\BaseHeadlessTesting; use JsonSchema\SchemaStorage; use JsonSchema\Uri\UriRetriever; use JsonSchema\Validator; use TYPO3\CMS\Core\Utility\ExtensionManagementUtility; -class BasePageTypesTest extends BaseTest +abstract class BasePageTypesHeadlessTesting extends BaseHeadlessTesting { /** * @param string $jsonString diff --git a/Tests/Functional/PageTypes/SchemaPageTypesTest.php b/Tests/Functional/PageTypes/SchemaPageTypesTest.php index 621adf9d..ddb003db 100644 --- a/Tests/Functional/PageTypes/SchemaPageTypesTest.php +++ b/Tests/Functional/PageTypes/SchemaPageTypesTest.php @@ -13,12 +13,9 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class SchemaPageTypesTest extends BasePageTypesTest +class SchemaPageTypesTest extends BasePageTypesHeadlessTesting { - /** - * @test - */ - public function getMenu() + public function testGetMenu() { $response = $this->executeFrontendSubRequest( new InternalRequest('https://website.local/?type=834') @@ -27,10 +24,7 @@ public function getMenu() self::assertEquals(200, $response->getStatusCode()); } - /** - * @test - */ - public function getPage() + public function testGetPage() { $response = $this->executeFrontendSubRequest( new InternalRequest('https://website.local/') diff --git a/Tests/Functional/PageTypes/StructurePageTypesTest.php b/Tests/Functional/PageTypes/StructurePageTypesTest.php index bfa7993e..c33eeb8f 100644 --- a/Tests/Functional/PageTypes/StructurePageTypesTest.php +++ b/Tests/Functional/PageTypes/StructurePageTypesTest.php @@ -13,12 +13,9 @@ use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest; -class StructurePageTypesTest extends BasePageTypesTest +class StructurePageTypesTest extends BasePageTypesHeadlessTesting { - /** - * @test - */ - public function getMenuStructure() + public function testGetMenuStructure() { $response = $this->executeFrontendSubRequest( new InternalRequest('https://website.local/?type=834') diff --git a/Tests/Functional/phpunit.xml b/Tests/Functional/phpunit.xml index 71c525ec..5502063c 100644 --- a/Tests/Functional/phpunit.xml +++ b/Tests/Functional/phpunit.xml @@ -1,24 +1,18 @@ - - - - ../../Classes - - ./ @@ -29,4 +23,9 @@ + + + ../../Classes + + diff --git a/Tests/Unit/ContentObject/BooleanContentObjectTest.php b/Tests/Unit/ContentObject/BooleanContentObjectTest.php index e5d1c3b1..5bd49414 100644 --- a/Tests/Unit/ContentObject/BooleanContentObjectTest.php +++ b/Tests/Unit/ContentObject/BooleanContentObjectTest.php @@ -12,6 +12,7 @@ namespace FriendsOfTYPO3\Headless\Tests\Unit\ContentObject; use FriendsOfTYPO3\Headless\ContentObject\BooleanContentObject; +use PHPUnit\Framework\Attributes\DataProvider; use Prophecy\PhpUnit\ProphecyTrait; use TYPO3\CMS\Core\Http\ServerRequest; use TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer; @@ -21,10 +22,7 @@ class BooleanContentObjectTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ - public function renderTest() + public function testRender() { $cObj = $this->createMock(ContentObjectRenderer::class); $cObj->setRequest(new ServerRequest()); @@ -36,11 +34,8 @@ public function renderTest() self::assertFalse($contentObject->render()); } - /** - * @test - * @dataProvider dataProvider - */ - public function renderWithProviderTest($argument, bool $result) + #[DataProvider('dataProvider')] + public function testRenderWithProvider($argument, bool $result): void { $cObj = $this->createMock(ContentObjectRenderer::class); $cObj->setRequest(new ServerRequest()); diff --git a/Tests/Unit/ContentObject/FloatContentObjectTest.php b/Tests/Unit/ContentObject/FloatContentObjectTest.php index 5ea09d01..52b30af2 100644 --- a/Tests/Unit/ContentObject/FloatContentObjectTest.php +++ b/Tests/Unit/ContentObject/FloatContentObjectTest.php @@ -12,16 +12,16 @@ namespace FriendsOfTYPO3\Headless\Tests\Unit\ContentObject; use FriendsOfTYPO3\Headless\ContentObject\FloatContentObject; +use PHPUnit\Framework\Attributes\DataProvider; +use PHPUnit\Framework\Attributes\Test; use TYPO3\CMS\Core\Http\ServerRequest; use TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer; use TYPO3\TestingFramework\Core\Unit\UnitTestCase; class FloatContentObjectTest extends UnitTestCase { - /** - * @test - */ - public function renderTest() + #[Test] + public function render(): void { $cObj = $this->createMock(ContentObjectRenderer::class); $cObj->setRequest(new ServerRequest()); @@ -32,11 +32,8 @@ public function renderTest() self::assertEquals(0.0, $contentObject->render()); } - /** - * @test - * @dataProvider dataProvider - */ - public function renderWithProviderTest($argument, float $result) + #[Test,DataProvider('dataProvider')] + public function renderWithProvider($argument, float $result): void { $cObj = $this->createMock(ContentObjectRenderer::class); $cObj->setRequest(new ServerRequest()); diff --git a/Tests/Unit/ContentObject/IntegerContentObjectTest.php b/Tests/Unit/ContentObject/IntegerContentObjectTest.php index 662b6c33..f84e2d5e 100644 --- a/Tests/Unit/ContentObject/IntegerContentObjectTest.php +++ b/Tests/Unit/ContentObject/IntegerContentObjectTest.php @@ -12,6 +12,8 @@ namespace FriendsOfTYPO3\Headless\Tests\Unit\ContentObject; use FriendsOfTYPO3\Headless\ContentObject\IntegerContentObject; +use PHPUnit\Framework\Attributes\DataProvider; +use PHPUnit\Framework\Attributes\Test; use Prophecy\PhpUnit\ProphecyTrait; use TYPO3\CMS\Core\Http\ServerRequest; use TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer; @@ -21,10 +23,8 @@ class IntegerContentObjectTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ - public function renderTest() + #[Test] + public function render(): void { $cObj = $this->createMock(ContentObjectRenderer::class); $cObj->setRequest(new ServerRequest()); @@ -35,11 +35,8 @@ public function renderTest() self::assertEquals(0, $contentObject->render()); } - /** - * @test - * @dataProvider dataProvider - */ - public function renderWithProviderTest($argument, int $result) + #[Test, DataProvider('dataProvider')] + public function renderWithProvider($argument, int $result): void { $cObj = $this->createMock(ContentObjectRenderer::class); $cObj->setRequest(new ServerRequest()); diff --git a/Tests/Unit/ContentObject/JsonContentObjectTest.php b/Tests/Unit/ContentObject/JsonContentObjectTest.php index 4cef81e7..dd041fc7 100644 --- a/Tests/Unit/ContentObject/JsonContentObjectTest.php +++ b/Tests/Unit/ContentObject/JsonContentObjectTest.php @@ -16,6 +16,7 @@ use FriendsOfTYPO3\Headless\ContentObject\IntegerContentObject; use FriendsOfTYPO3\Headless\ContentObject\JsonContentContentObject; use FriendsOfTYPO3\Headless\ContentObject\JsonContentObject; +use PHPUnit\Framework\Attributes\DataProvider; use Prophecy\Argument; use Prophecy\PhpUnit\ProphecyTrait; use Psr\EventDispatcher\EventDispatcherInterface; @@ -140,19 +141,13 @@ protected function setUp(): void $this->contentObject->setContentObjectRenderer($contentObjectRenderer); } - /** - * @test - */ - public function renderTest() + public function testRender() { self::assertEquals('[]', $this->contentObject->render()); } - /** - * @test - * @dataProvider dataProvider - */ - public function renderWithProviderTest($argument, $result) + #[DataProvider('dataProvider')] + public function testRenderWithProvider($argument, $result) { self::assertEquals($result, $this->contentObject->render($argument)); } diff --git a/Tests/Unit/DataProcessing/DataProcessingTraitTest.php b/Tests/Unit/DataProcessing/DataProcessingTraitTest.php index 8019b4f2..e703f63a 100644 --- a/Tests/Unit/DataProcessing/DataProcessingTraitTest.php +++ b/Tests/Unit/DataProcessing/DataProcessingTraitTest.php @@ -12,15 +12,13 @@ namespace FriendsOfTYPO3\Headless\Tests\Unit\DataProcessing; use FriendsOfTYPO3\Headless\DataProcessing\DataProcessingTrait; +use PHPUnit\Framework\Attributes\DataProvider; use PHPUnit\Framework\TestCase; class DataProcessingTraitTest extends TestCase { - /** - * @test - * @dataProvider dataProvider - */ - public function removeDataIfnotAppendInConfigurationTest( + #[DataProvider('dataProvider')] + public function testRemoveDataIfnotAppendInConfiguration( $expected, array $processorConfiguration, array $processedData @@ -37,10 +35,7 @@ public function removeDataIfnotAppendInConfigurationTest( ); } - /** - * @test - */ - public function removeDataIfnotAppendInConfigurationAsMenuProcessorTest() + public function testRemoveDataIfnotAppendInConfigurationAsMenuProcessor() { $trait = new class () { use DataProcessingTrait { diff --git a/Tests/Unit/DataProcessing/DatabaseQueryProcessorTest.php b/Tests/Unit/DataProcessing/DatabaseQueryProcessorTest.php index ef93d28e..65d1a8bb 100644 --- a/Tests/Unit/DataProcessing/DatabaseQueryProcessorTest.php +++ b/Tests/Unit/DataProcessing/DatabaseQueryProcessorTest.php @@ -61,10 +61,7 @@ protected function setUp(): void parent::setUp(); } - /** - * @test - */ - public function returnEarlyDueToIfStatementReturnsFalse(): void + public function testReturnEarlyDueToIfStatementReturnsFalse(): void { $processorConfiguration = [ 'if.' => [ @@ -77,10 +74,7 @@ public function returnEarlyDueToIfStatementReturnsFalse(): void self::assertEquals($processedData, $this->subject->process($this->contentObjectRenderer->reveal(), [], $processorConfiguration, $processedData)); } - /** - * @test - */ - public function returnEarlyNoTableIsGiven(): void + public function testReturnEarlyNoTableIsGiven(): void { $processorConfiguration = [ 'if.' => [ @@ -93,10 +87,7 @@ public function returnEarlyNoTableIsGiven(): void self::assertEquals($processedData, $this->subject->process($this->contentObjectRenderer->reveal(), [], $processorConfiguration, $processedData)); } - /** - * @test - */ - public function processWithoutAdditionalFields(): void + public function testProcessWithoutAdditionalFields(): void { $processorConfiguration = [ 'table' => 'tt_content', @@ -131,10 +122,7 @@ public function processWithoutAdditionalFields(): void self::assertEquals($processedData, $this->subject->process($this->contentObjectRenderer->reveal(), [], $processorConfiguration, $processedData)); } - /** - * @test - */ - public function processWithAdditionalFields(): void + public function testProcessWithAdditionalFields(): void { $processorConfiguration = [ 'table' => 'tt_content', diff --git a/Tests/Unit/DataProcessing/RootSiteProcessing/DomainSchemaTest.php b/Tests/Unit/DataProcessing/RootSiteProcessing/DomainSchemaTest.php index c9cd1751..f7db61da 100644 --- a/Tests/Unit/DataProcessing/RootSiteProcessing/DomainSchemaTest.php +++ b/Tests/Unit/DataProcessing/RootSiteProcessing/DomainSchemaTest.php @@ -33,10 +33,7 @@ class DomainSchemaTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ - public function processTest() + public function testProcess(): void { $testUri = new Uri('https://test.domain.tld'); $cObj = $this->prophesize(ContentObjectRenderer::class); @@ -133,17 +130,20 @@ protected function getUrlUtility($site = null): UrlUtility $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $mock = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $mock->method('getSiteByPageId')->willReturn($site); if ($site === null) { $site = $this->getSiteWithBase($uri); } - $siteFinder->getSiteByPageId(Argument::is(1))->willReturn($site); + $mock->method('getSiteByPageId')->willReturn($site); + + //$siteFinder->getSiteByPageId(Argument::is(1))->willReturn($site); $dummyRequest = (new ServerRequest())->withAttribute('site', $site); $dummyRequest = $dummyRequest->withAttribute('headless', new Headless()); - return new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), $dummyRequest, (new HeadlessMode())->withRequest($dummyRequest)); + return new UrlUtility(null, $resolver->reveal(), $mock, $dummyRequest, (new HeadlessMode())->withRequest($dummyRequest)); } protected function getSiteWithBase(UriInterface $uri, $withLanguage = null) diff --git a/Tests/Unit/DataProcessing/RootSitesProcessorTest.php b/Tests/Unit/DataProcessing/RootSitesProcessorTest.php index 8e488dd1..dd657c33 100644 --- a/Tests/Unit/DataProcessing/RootSitesProcessorTest.php +++ b/Tests/Unit/DataProcessing/RootSitesProcessorTest.php @@ -33,10 +33,7 @@ protected function setUp(): void parent::setUp(); } - /** - * @test - */ - public function customImplementation(): void + public function testCustomImplementation(): void { $processor = new RootSitesProcessor(); @@ -72,10 +69,7 @@ public function customImplementation(): void ], $processor->process($contentObjectRenderer, [], $conf, [])); } - /** - * @test - */ - public function objectNotSet() + public function testObjectNotSet() { $processor = new RootSitesProcessor(); @@ -87,10 +81,7 @@ public function objectNotSet() self::assertEquals([], $processor->process($contentObjectRenderer, [], $conf, [])); } - /** - * @test - */ - public function featureEnabledButWrongSiteProvider(): void + public function testFeatureEnabledButWrongSiteProvider(): void { $processor = new RootSitesProcessor(); @@ -104,10 +95,7 @@ public function featureEnabledButWrongSiteProvider(): void self::assertEquals([], $processor->process($contentObjectRenderer, [], $conf, [])); } - /** - * @test - */ - public function featureEnabledButWrongSiteSchema(): void + public function testFeatureEnabledButWrongSiteSchema(): void { $processor = new RootSitesProcessor(); diff --git a/Tests/Unit/Event/Listener/AfterLinkIsGeneratedListenerTest.php b/Tests/Unit/Event/Listener/AfterLinkIsGeneratedListenerTest.php index 318741da..5f7b4d51 100644 --- a/Tests/Unit/Event/Listener/AfterLinkIsGeneratedListenerTest.php +++ b/Tests/Unit/Event/Listener/AfterLinkIsGeneratedListenerTest.php @@ -34,14 +34,14 @@ public function test__construct() { $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createPartialMock(SiteFinder::class, []); $listener = new AfterLinkIsGeneratedListener( $this->prophesize(Logger::class)->reveal(), - new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal()), + new UrlUtility(null, $resolver->reveal(), $siteFinder), $this->prophesize(LinkService::class)->reveal(), new TypoLinkCodecService($this->prophesize(EventDispatcherInterface::class)->reveal()), - $this->prophesize(SiteFinder::class)->reveal() + $siteFinder ); self::assertInstanceOf(AfterLinkIsGeneratedListener::class, $listener); @@ -51,14 +51,14 @@ public function test__invokeNotModifingAnything() { $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); $listener = new AfterLinkIsGeneratedListener( $this->prophesize(Logger::class)->reveal(), - new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal()), + new UrlUtility(null, $resolver->reveal(), $siteFinder), $this->prophesize(LinkService::class)->reveal(), new TypoLinkCodecService($this->prophesize(EventDispatcherInterface::class)->reveal()), - $this->prophesize(SiteFinder::class)->reveal() + $siteFinder ); $site = new Site('test', 1, []); @@ -111,7 +111,7 @@ public function test__invokeModifingFromPageUid() $urlUtility->reveal(), $this->prophesize(LinkService::class)->reveal(), new TypoLinkCodecService($this->prophesize(EventDispatcherInterface::class)->reveal()), - $this->prophesize(SiteFinder::class)->reveal() + $this->createMock(SiteFinder::class) ); $linkResult = new LinkResult('page', '/'); @@ -148,7 +148,7 @@ public function test__invokeModifingExternalSite() $urlUtility->reveal(), $linkService->reveal(), new TypoLinkCodecService($this->prophesize(EventDispatcherInterface::class)->reveal()), - $this->prophesize(SiteFinder::class)->reveal() + $this->createMock(SiteFinder::class) ); $linkResult = new LinkResult('page', '/'); $linkResult = $linkResult->withLinkConfiguration(['parameter.' => ['data' => 'parameters:href']]); @@ -182,8 +182,8 @@ public function test__SitemapLink() $request = (new ServerRequest())->withAttribute('site', $site); $cObj->getRequest()->willReturn($request); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(Argument::any())->willReturn($site); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site); $urlUtility->withRequest($request)->willReturn($urlUtility->reveal()); @@ -195,7 +195,7 @@ public function test__SitemapLink() $urlUtility->reveal(), $linkService->reveal(), new TypoLinkCodecService($eventDispatcher->reveal()), - $siteFinder->reveal() + $siteFinder ); $linkResult = new LinkResult('page', 'https://typo3.tld/sitemap-type/pages/sitemap.xml'); diff --git a/Tests/Unit/Event/Listener/AfterPagePreviewUriGeneratedListenerTest.php b/Tests/Unit/Event/Listener/AfterPagePreviewUriGeneratedListenerTest.php index a32090a3..a78bd93c 100644 --- a/Tests/Unit/Event/Listener/AfterPagePreviewUriGeneratedListenerTest.php +++ b/Tests/Unit/Event/Listener/AfterPagePreviewUriGeneratedListenerTest.php @@ -33,13 +33,13 @@ public function test__construct() { $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); $listener = new AfterPagePreviewUriGeneratedListener(new UrlUtility( null, $resolver->reveal(), - $siteFinder->reveal() - ), $siteFinder->reveal()); + $siteFinder + ), $siteFinder); self::assertInstanceOf(AfterPagePreviewUriGeneratedListener::class, $listener); } @@ -48,14 +48,14 @@ public function testLink() { $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(Argument::any())->willReturn($site = new Site('test', 1, ['headless' => HeadlessMode::MIXED, 'frontendBase' => 'https://front.test.tld', 'base' => 'https://test.tld'])); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site = new Site('test', 1, ['headless' => HeadlessMode::MIXED, 'frontendBase' => 'https://front.test.tld', 'base' => 'https://test.tld'])); $listener = new AfterPagePreviewUriGeneratedListener(new UrlUtility( null, $resolver->reveal(), - $siteFinder->reveal() - ), $siteFinder->reveal()); + $siteFinder + ), $siteFinder); $event = new AfterPagePreviewUriGeneratedEvent( new Uri('https://test.tld/page'), @@ -82,14 +82,14 @@ public function testSiteNotFound() { $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(Argument::any())->willThrow(new SiteNotFoundException()); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willThrowException(new SiteNotFoundException()); $listener = new AfterPagePreviewUriGeneratedListener(new UrlUtility( null, $resolver->reveal(), - $siteFinder->reveal() - ), $siteFinder->reveal()); + $siteFinder + ), $siteFinder); $event = new AfterPagePreviewUriGeneratedEvent( new Uri('https://test.tld/page'), diff --git a/Tests/Unit/Event/Listener/RedirectUrlAdditionalParamsListenerTest.php b/Tests/Unit/Event/Listener/RedirectUrlAdditionalParamsListenerTest.php index d3fe7e6a..33b320a8 100644 --- a/Tests/Unit/Event/Listener/RedirectUrlAdditionalParamsListenerTest.php +++ b/Tests/Unit/Event/Listener/RedirectUrlAdditionalParamsListenerTest.php @@ -36,10 +36,7 @@ class RedirectUrlAdditionalParamsListenerTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ - public function invokeTest() + public function testInvoke(): void { $eventDispatcher = $this->prophesize(EventDispatcherInterface::class); $eventDispatcher->dispatch(Argument::any())->willReturnArgument(); @@ -132,10 +129,7 @@ public function invokeTest() self::assertSame((string)$expectedUri, $newRedirectEvent->getTargetUrl()); } - /** - * @test - */ - public function invokeWithLanguageTest() + public function testInvokeWithLanguaget(): void { $eventDispatcher = $this->prophesize(EventDispatcherInterface::class); $eventDispatcher->dispatch(Argument::any())->willReturnArgument(); @@ -246,14 +240,14 @@ protected function getUrlUtility($site = null): UrlUtility $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); if ($site === null) { $site = $this->getSiteWithBase($uri); } - $siteFinder->getSiteByPageId(Argument::is(1))->willReturn($site); + $siteFinder->method('getSiteByPageId')->willReturn($site); - return new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, (new HeadlessMode())->withRequest((new ServerRequest())->withAttribute('headless', new Headless()))); + return new UrlUtility(null, $resolver->reveal(), $siteFinder, null, (new HeadlessMode())->withRequest((new ServerRequest())->withAttribute('headless', new Headless()))); } } diff --git a/Tests/Unit/Event/RedirectUrlEventTest.php b/Tests/Unit/Event/RedirectUrlEventTest.php index ca44a2f1..d89e47a1 100644 --- a/Tests/Unit/Event/RedirectUrlEventTest.php +++ b/Tests/Unit/Event/RedirectUrlEventTest.php @@ -12,6 +12,7 @@ namespace FriendsOfTYPO3\Headless\Tests\Unit\Event; use FriendsOfTYPO3\Headless\Event\RedirectUrlEvent; +use PHPUnit\Framework\Attributes\Test; use Prophecy\PhpUnit\ProphecyTrait; use TYPO3\CMS\Core\Http\ServerRequest; use TYPO3\CMS\Core\Http\Uri; @@ -21,9 +22,7 @@ class RedirectUrlEventTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ + #[Test] public function eventTest() { $request = (new ServerRequest())->withAttribute('test', 1); diff --git a/Tests/Unit/Form/Decorator/AbstractFormDefinitionDecoratorTest.php b/Tests/Unit/Form/Decorator/AbstractFormDefinitionDecoratorTest.php index ff874cbf..68d9ecd1 100644 --- a/Tests/Unit/Form/Decorator/AbstractFormDefinitionDecoratorTest.php +++ b/Tests/Unit/Form/Decorator/AbstractFormDefinitionDecoratorTest.php @@ -16,28 +16,24 @@ class AbstractFormDefinitionDecoratorTest extends UnitTestCase { - /** - * @test - */ - public function basicOutput(): void + public function testBasicOutput(): void { - $stub = $this->getMockForAbstractClass(AbstractFormDefinitionDecorator::class, [['api' => 'test']]); + $class = new class () extends AbstractFormDefinitionDecorator {}; + $classUnderTest = new $class(['api' => 'test']); $definition = [ 'identifier' => 'test-123', 'renderables' => [0 => ['renderables' => []]], 'i18n' => ['properties' => []], ]; - $test = $stub($definition, 1); + $test = $classUnderTest($definition, 1); self::assertSame(['id' => 'test-123', 'api' => ['api' => 'test'], 'i18n' => [], 'elements' => []], $test); } - /** - * @test - */ - public function renderElements(): void + public function testRenderElements(): void { - $stub = $this->getMockForAbstractClass(AbstractFormDefinitionDecorator::class, [['api' => 'test']]); + $class = new class () extends AbstractFormDefinitionDecorator {}; + $classUnderTest = new $class(['api' => 'test']); $definition = [ 'identifier' => 'test-123', @@ -91,7 +87,7 @@ public function renderElements(): void ], 'i18n' => ['properties' => []], ]; - $test = $stub($definition, 0); + $test = $classUnderTest($definition, 0); self::assertSame([ 'id' => 'test-123', diff --git a/Tests/Unit/Hooks/HeadlessUserIntTest.php b/Tests/Unit/Hooks/HeadlessUserIntTest.php index 2a7165ca..2b1fa47a 100644 --- a/Tests/Unit/Hooks/HeadlessUserIntTest.php +++ b/Tests/Unit/Hooks/HeadlessUserIntTest.php @@ -22,10 +22,7 @@ class HeadlessUserIntTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ - public function processingOnPlainTextWithNewline() + public function testProcessingOnPlainTextWithNewline() { $testProcessed = 'PlainText' . PHP_EOL . 'NextLine'; $testContent = 'HEADLESS_INT_START<<' . $testProcessed . '>>HEADLESS_INT_END'; @@ -40,10 +37,7 @@ public function processingOnPlainTextWithNewline() self::assertEquals(json_encode($testProcessed), '"' . $tsfe->content . '"'); } - /** - * @test - */ - public function processingOnQuotedText() + public function testProcessingOnQuotedText() { $testProcessed = '"PlainText' . PHP_EOL . 'NextLine"'; $testContent = 'HEADLESS_INT_START<<' . $testProcessed . '>>HEADLESS_INT_END'; @@ -58,10 +52,7 @@ public function processingOnQuotedText() self::assertEquals(json_encode($testProcessed), '"' . $tsfe->content . '"'); } - /** - * @test - */ - public function processingOnQuotedContent() + public function testProcessingOnQuotedContent() { $testProcessed = '"PlainText' . PHP_EOL . 'NextLine"'; $testContent = '"HEADLESS_INT_START<<' . $testProcessed . '>>HEADLESS_INT_END"'; @@ -78,10 +69,7 @@ public function processingOnQuotedContent() self::assertEquals(json_encode($testProcessed), $tsfe->content); } - /** - * @test - */ - public function processingOnQuotedJsonContent() + public function testProcessingOnQuotedJsonContent() { $testProcessed = json_encode( [ @@ -100,10 +88,7 @@ public function processingOnQuotedJsonContent() self::assertEquals($testProcessed, $tsfe->content); } - /** - * @test - */ - public function processingEmptyPluginResponse() + public function testProcessingEmptyPluginResponse() { $testProcessed = json_encode( '' @@ -134,10 +119,7 @@ public function processingEmptyPluginResponse() self::assertEquals(json_encode(null), $tsfe->content); } - /** - * @test - */ - public function processingOnNestedJsonContent() + public function testProcessingOnNestedJsonContent() { $nestedProcessed = json_encode( [ @@ -180,10 +162,7 @@ public function processingOnNestedJsonContent() self::assertEquals($finalOutput, $tsfe->content); } - /** - * @test - */ - public function processingOnMultipleUserIntOnPageJsonContent() + public function testProcessingOnMultipleUserIntOnPageJsonContent() { $nestedProcessed = json_encode( [ @@ -234,10 +213,7 @@ public function processingOnMultipleUserIntOnPageJsonContent() self::assertEquals($finalOutput, $tsfe->content); } - /** - * @test - */ - public function wrapTest() + public function testWrapTest() { $headlessUserInt = new HeadlessUserInt(); diff --git a/Tests/Unit/Json/JsonDecoderTest.php b/Tests/Unit/Json/JsonDecoderTest.php index 3203bb98..1d297f7b 100644 --- a/Tests/Unit/Json/JsonDecoderTest.php +++ b/Tests/Unit/Json/JsonDecoderTest.php @@ -9,9 +9,11 @@ declare(strict_types=1); -namespace FriendsOfTYPO3\Headless\Tests\Unit\ContentObject; +namespace FriendsOfTYPO3\Headless\Tests\Unit\Json; use FriendsOfTYPO3\Headless\Json\JsonDecoder; +use PHPUnit\Framework\Attributes\DataProvider; +use PHPUnit\Framework\Attributes\Test; use stdClass; use TYPO3\CMS\Core\Utility\GeneralUtility; @@ -29,13 +31,7 @@ protected function setUp(): void parent::setUp(); } - /** - * @param $testValue - * @param $expectedValue - * - * @test - * @dataProvider possibleJsonProvider - */ + #[Test, DataProvider('possibleJsonProvider')] public function possibleFalsePositives($testValue, $expectedValue): void { $jsonDecoder = GeneralUtility::makeInstance(JsonDecoder::class); @@ -43,7 +39,8 @@ public function possibleFalsePositives($testValue, $expectedValue): void self::assertSame($expectedValue, $jsonDecoder->isJson($testValue)); } - public function testDecoding(): void + #[Test] + public function decoding(): void { $jsonDecoder = GeneralUtility::makeInstance(JsonDecoder::class); diff --git a/Tests/Unit/Json/JsonEncoderTest.php b/Tests/Unit/Json/JsonEncoderTest.php index 3515f917..d9fd1cf3 100644 --- a/Tests/Unit/Json/JsonEncoderTest.php +++ b/Tests/Unit/Json/JsonEncoderTest.php @@ -12,6 +12,8 @@ namespace FriendsOfTYPO3\Headless\Tests\Unit\ContentObject; use FriendsOfTYPO3\Headless\Json\JsonEncoder; +use PHPUnit\Framework\Attributes\DataProvider; +use PHPUnit\Framework\Attributes\Test; use stdClass; use TYPO3\CMS\Core\Utility\GeneralUtility; @@ -27,12 +29,7 @@ protected function setUp(): void parent::setUp(); } - /** - * @param $testValue - * @param $expectedValue - * - * @dataProvider jsonProvider - */ + #[Test, DataProvider('jsonProvider')] public function testEncoding($testValue, $expectedValue): void { $encoder = GeneralUtility::makeInstance(JsonEncoder::class); @@ -40,7 +37,8 @@ public function testEncoding($testValue, $expectedValue): void self::assertSame($expectedValue, $encoder->encode($testValue)); } - public function testPrettyEncoding(): void + #[Test] + public function prettyEncoding(): void { $GLOBALS['TYPO3_CONF_VARS']['SYS']['features']['headless.prettyPrint'] = true; $encoder = GeneralUtility::makeInstance(JsonEncoder::class); diff --git a/Tests/Unit/Middleware/CookieDomainPerSiteTest.php b/Tests/Unit/Middleware/CookieDomainPerSiteTest.php index 816e0896..19c73df2 100644 --- a/Tests/Unit/Middleware/CookieDomainPerSiteTest.php +++ b/Tests/Unit/Middleware/CookieDomainPerSiteTest.php @@ -13,6 +13,7 @@ use FriendsOfTYPO3\Headless\Middleware\CookieDomainPerSite; use FriendsOfTYPO3\Headless\Utility\UrlUtility; +use PHPUnit\Framework\Attributes\Test; use Prophecy\Argument; use Prophecy\PhpUnit\ProphecyTrait; use Psr\Log\LoggerInterface; @@ -29,9 +30,7 @@ class CookieDomainPerSiteTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ + #[Test] public function emptyCookieDomain() { $site = $this->prophesize(Site::class); @@ -61,16 +60,16 @@ public function emptyCookieDomain() $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::containingString('Development'))->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getAllSites']); - $siteFinder->getAllSites()->willReturn([ - $site, + $siteFinder->method('getAllSites')->willReturn([ + $site->reveal(), ]); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal()); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder); $urlUtility = $urlUtility->withSite($site->reveal()); - $middleware = new CookieDomainPerSite($urlUtility, $siteFinder->reveal(), $this->prophesize(LoggerInterface::class)->reveal()); + $middleware = new CookieDomainPerSite($urlUtility, $siteFinder, $this->prophesize(LoggerInterface::class)->reveal()); $request = new ServerRequest('https://test-backend-api.tld'); $request = $request->withAttribute('normalizedParams', NormalizedParams::createFromRequest($request)); @@ -88,9 +87,7 @@ public function emptyCookieDomain() ); } - /** - * @test - */ + #[Test] public function cookieDomainIsSet() { $site = $this->prophesize(Site::class); @@ -121,16 +118,16 @@ public function cookieDomainIsSet() $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::containingString('Development'))->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getAllSites']); - $siteFinder->getAllSites()->willReturn([ - $site, + $siteFinder->method('getAllSites')->willReturn([ + $site->reveal(), ]); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal()); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder); $urlUtility = $urlUtility->withSite($site->reveal()); - $middleware = new CookieDomainPerSite($urlUtility, $siteFinder->reveal(), $this->prophesize(LoggerInterface::class)->reveal()); + $middleware = new CookieDomainPerSite($urlUtility, $siteFinder, $this->prophesize(LoggerInterface::class)->reveal()); $request = new ServerRequest('https://test-backend-api.tld'); $request = $request->withAttribute('normalizedParams', NormalizedParams::createFromRequest($request)); diff --git a/Tests/Unit/Middleware/ElementBodyResponseMiddlewareTest.php b/Tests/Unit/Middleware/ElementBodyResponseMiddlewareTest.php index bd763c8d..2f89de98 100644 --- a/Tests/Unit/Middleware/ElementBodyResponseMiddlewareTest.php +++ b/Tests/Unit/Middleware/ElementBodyResponseMiddlewareTest.php @@ -26,10 +26,7 @@ class ElementBodyResponseMiddlewareTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ - public function processTest() + public function testProcess(): void { $middleware = new ElementBodyResponseMiddleware(new JsonEncoder(), new HeadlessMode()); diff --git a/Tests/Unit/Middleware/SiteBaseRedirectResolverTest.php b/Tests/Unit/Middleware/SiteBaseRedirectResolverTest.php index 4353a0f2..0013fae7 100644 --- a/Tests/Unit/Middleware/SiteBaseRedirectResolverTest.php +++ b/Tests/Unit/Middleware/SiteBaseRedirectResolverTest.php @@ -60,11 +60,11 @@ public function testJsonRedirect() ], ]]); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(1)->willReturn($site); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site); $container = new Container(); - $urlUtility = GeneralUtility::makeInstance(UrlUtility::class, null, $this->prophesize(Resolver::class)->reveal(), $siteFinder->reveal()); + $urlUtility = GeneralUtility::makeInstance(UrlUtility::class, null, $this->prophesize(Resolver::class)->reveal(), $siteFinder); $container->set(UrlUtility::class, $urlUtility); GeneralUtility::setContainer($container); @@ -131,11 +131,11 @@ public function testJsonRedirect() ], ]]); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(1)->willReturn($site); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site); $container = new Container(); - $urlUtility = GeneralUtility::makeInstance(UrlUtility::class, null, $this->prophesize(Resolver::class)->reveal(), $siteFinder->reveal()); + $urlUtility = GeneralUtility::makeInstance(UrlUtility::class, null, $this->prophesize(Resolver::class)->reveal(), $siteFinder); $container->set(UrlUtility::class, $urlUtility); $errorController = $this->prophesize(ErrorController::class); $errorController->pageNotFoundAction(Argument::any(), Argument::any(), Argument::any())->willReturn(new JsonResponse(['ErrorController' => true])); diff --git a/Tests/Unit/Middleware/UserIntMiddlewareTest.php b/Tests/Unit/Middleware/UserIntMiddlewareTest.php index 6ba384d8..5caac21d 100644 --- a/Tests/Unit/Middleware/UserIntMiddlewareTest.php +++ b/Tests/Unit/Middleware/UserIntMiddlewareTest.php @@ -16,6 +16,7 @@ use FriendsOfTYPO3\Headless\Utility\Headless; use FriendsOfTYPO3\Headless\Utility\HeadlessMode; use FriendsOfTYPO3\Headless\Utility\HeadlessUserInt; +use PHPUnit\Framework\Attributes\Test; use Prophecy\PhpUnit\ProphecyTrait; use TYPO3\CMS\Core\Http\HtmlResponse; use TYPO3\CMS\Core\Http\ServerRequest; @@ -29,10 +30,8 @@ class UserIntMiddlewareTest extends UnitTestCase { use ProphecyTrait; - /** - * @test - */ - public function processTest() + #[Test] + public function process(): void { $middleware = new UserIntMiddleware(new HeadlessUserInt(), new HeadlessMode(), $this->createMock(MetaHandler::class)); diff --git a/Tests/Unit/Utility/UrlUtilityTest.php b/Tests/Unit/Utility/UrlUtilityTest.php index 8c8d185b..a49dcd76 100644 --- a/Tests/Unit/Utility/UrlUtilityTest.php +++ b/Tests/Unit/Utility/UrlUtilityTest.php @@ -70,9 +70,9 @@ public function testFrontendUrls(): void $resolver->evaluate(Argument::containingString('Development'))->willReturn(true); $resolver->evaluate(Argument::containingString('Testing'))->willReturn(false); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame('https://test-frontend.tld', $urlUtility->getFrontendUrl()); @@ -84,9 +84,9 @@ public function testFrontendUrls(): void $resolver->evaluate(Argument::containingString('Development'))->willReturn(false); $resolver->evaluate(Argument::containingString('Testing'))->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame('https://test-frontend2.tld', $urlUtility->getFrontendUrl()); @@ -99,11 +99,11 @@ public function testFrontendUrls(): void $resolver->evaluate(Argument::containingString('Testing'))->willReturn(false); $resolver->evaluate(Argument::containingString('Misconfigured'))->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); $site->getBase()->shouldBeCalled(2)->willReturn(new Uri('https://test-backend3-api.tld/')); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame('https://test-frontend3.tld', $urlUtility->getFrontendUrl()); @@ -135,9 +135,9 @@ public function testFrontendUrlsWithDifferentPaths(): void $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::containingString('Development'))->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame('https://test-frontend.tld/frontend/content-page', $urlUtility->getFrontendUrlWithSite('https://test-backend-api.tld/dev-path/content-page', $site->reveal())); @@ -165,7 +165,7 @@ public function testFrontendUrlsWithBaseProductionAndLocalOverride(): void ], ]); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); // local override $resolver = $this->prophesize(Resolver::class); @@ -173,7 +173,7 @@ public function testFrontendUrlsWithBaseProductionAndLocalOverride(): void $headlessMode = $this->createHeadlessMode(); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame('https://test-frontend.tld', $urlUtility->getFrontendUrl()); @@ -185,7 +185,7 @@ public function testFrontendUrlsWithBaseProductionAndLocalOverride(): void $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::containingString('Development'))->willReturn(false); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame('https://www.typo3.org', $urlUtility->getFrontendUrl()); @@ -224,9 +224,9 @@ public function testOptimizedUrlsForFrontendApp(): void $resolver->evaluate(Argument::containingString('Development'))->willReturn(true); $resolver->evaluate(Argument::containingString('Testing'))->willReturn(false); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); // same page, so we make it relative @@ -253,9 +253,9 @@ public function testOptimizedUrlsForFrontendApp(): void $resolver->evaluate(Argument::containingString('Development'))->willReturn(false); $resolver->evaluate(Argument::containingString('Testing'))->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); // same page, so we make it relative @@ -320,9 +320,9 @@ public function testLanguageResolver(): void $resolver->evaluate(Argument::containingString('Development'))->willReturn(true); $resolver->evaluate(Argument::containingString('Testing'))->willReturn(false); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); $urlUtility = $urlUtility->withLanguage(new SiteLanguage(0, 'en', new Uri('/'), [ 'title' => 'English', @@ -371,7 +371,7 @@ public function testLanguageResolver(): void self::assertSame('https://test-frontend-from-lang.tld/headless/fileadmin', $urlUtility->getStorageProxyUrl()); // not overlay site variants if language has not defined variants - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal()); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder); $urlUtility = $urlUtility->withSite($site->reveal()); $urlUtility = $urlUtility->withLanguage(new SiteLanguage(0, 'en', new Uri('/'), [ 'title' => 'English', @@ -394,9 +394,9 @@ public function testLanguageResolver(): void $resolver->evaluate(Argument::containingString('Development'))->willReturn(false); $resolver->evaluate(Argument::containingString('Testing'))->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); + $siteFinder = $this->createMock(SiteFinder::class); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); $urlUtility = $urlUtility->withLanguage(new SiteLanguage(0, 'en', new Uri('/'), [ 'title' => 'English', @@ -453,11 +453,11 @@ public function testFrontendUrlForPage(): void $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(Argument::is(1))->shouldBeCalled(2)->willReturn($site->reveal()); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site->reveal()); $headlessMode = $this->createHeadlessMode(HeadlessMode::NONE); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); // flag is not existing/disabled @@ -468,7 +468,7 @@ public function testFrontendUrlForPage(): void $headlessMode = $this->createHeadlessMode(HeadlessMode::FULL); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame( 'https://test-frontend.tld/test-page', @@ -499,12 +499,12 @@ public function testFrontendUrlForPageWithAlreadyFrontendUrlResolved(): void $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(Argument::is(1))->shouldBeCalledOnce()->willReturn($site->reveal()); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site->reveal()); $headlessMode = $this->createHeadlessMode(); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame( @@ -535,11 +535,11 @@ public function testFrontendUrlForPageWithPortsOnFrontendSide(): void $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(Argument::is(1))->shouldBeCalled(2)->willReturn($site->reveal()); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site->reveal()); $headlessMode = $this->createHeadlessMode(HeadlessMode::NONE); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); // flag is not existing/disabled @@ -550,7 +550,7 @@ public function testFrontendUrlForPageWithPortsOnFrontendSide(): void // flag is enabled $headlessMode = $this->createHeadlessMode(); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame( 'https://test-frontend.tld:3000/test-page', @@ -581,10 +581,10 @@ public function testFrontendUrlForPageWithPortsOnBothSides(): void $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(Argument::is(1))->shouldBeCalled(2)->willReturn($site->reveal()); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site->reveal()); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); // flag is not existing/disabled @@ -595,7 +595,7 @@ public function testFrontendUrlForPageWithPortsOnBothSides(): void // flag is enabled $headlessMode = $this->createHeadlessMode(); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), null, $headlessMode); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, null, $headlessMode); $urlUtility = $urlUtility->withSite($site->reveal()); self::assertSame( 'https://test-frontend.tld:3000/test-page', @@ -617,9 +617,9 @@ public function testEdgeCases() $resolver = $this->prophesize(Resolver::class); $resolver->evaluate(Argument::any())->willReturn(true); - $siteFinder = $this->prophesize(SiteFinder::class); - $siteFinder->getSiteByPageId(Argument::is(1))->shouldBeCalledOnce()->willReturn($site); - $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder->reveal(), $request->reveal(), null, $headlessMode); + $siteFinder = $this->createPartialMock(SiteFinder::class, ['getSiteByPageId']); + $siteFinder->method('getSiteByPageId')->willReturn($site); + $urlUtility = new UrlUtility(null, $resolver->reveal(), $siteFinder, $request->reveal(), null, $headlessMode); self::assertSame( 'https://test-backend-api.tld:8000/test-page', diff --git a/Tests/Unit/XClass/TemplateViewTest.php b/Tests/Unit/XClass/TemplateViewTest.php index a3197b49..e8a94c76 100644 --- a/Tests/Unit/XClass/TemplateViewTest.php +++ b/Tests/Unit/XClass/TemplateViewTest.php @@ -14,6 +14,7 @@ use FriendsOfTYPO3\Headless\Utility\Headless; use FriendsOfTYPO3\Headless\Utility\HeadlessMode; use FriendsOfTYPO3\Headless\XClass\TemplateView; +use PHPUnit\Framework\Attributes\IgnoreDeprecations; use RuntimeException; use TYPO3\CMS\Core\Http\ServerRequest; use TYPO3\CMS\Fluid\Core\Rendering\RenderingContext; @@ -27,6 +28,7 @@ use function json_encode; +#[IgnoreDeprecations] class TemplateViewTest extends UnitTestCase { public function testTemplateNotFoundRender(): void diff --git a/Tests/Unit/phpunit.xml b/Tests/Unit/phpunit.xml index 71bf1ca2..b66cdc5c 100644 --- a/Tests/Unit/phpunit.xml +++ b/Tests/Unit/phpunit.xml @@ -1,27 +1,19 @@ - - - ../../Classes - - ./ @@ -29,7 +21,12 @@ - - + + + + + ../../Classes + + diff --git a/composer.json b/composer.json index 52e8ce0e..74c503c7 100644 --- a/composer.json +++ b/composer.json @@ -28,8 +28,8 @@ ], "require": { "ext-json": "*", - "typo3/cms-core": "^12.4 || ^13.3", - "typo3/cms-install": "^12.4 || ^13.3" + "typo3/cms-core": "^12.4 || ^13.4", + "typo3/cms-install": "^12.4 || ^13.4" }, "require-dev": { "ergebnis/composer-normalize": "^2.43",