diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 0be6b49..106e898 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -63,7 +63,7 @@ jobs: name: CGL if: ${{ always() && steps.install.conclusion == 'success' }} run: | - php-cs-fixer fix --dry-run --verbose + php-cs-fixer fix --dry-run --verbose --config Build/.php-cs-fixer.dist.php - id: phpstan name: PHPStan @@ -72,6 +72,13 @@ jobs: run: | composer ci:test:php:phpstan -- --error-format=github + - id: rector + name: Rector + continue-on-error: true + if: ${{ always() && steps.install.conclusion == 'success' }} + run: | + composer ci:test:php:rector + - id: tests_unit name: Unit Tests if: ${{ always() && steps.install.conclusion == 'success' }} diff --git a/.gitignore b/.gitignore index 17670a0..77ec5a6 100644 --- a/.gitignore +++ b/.gitignore @@ -16,3 +16,4 @@ composer.lock # Cache .php-cs-fixer.cache .phplint.cache +.phpunit.result.cache diff --git a/Build/.php-cs-fixer.dist.php b/Build/.php-cs-fixer.dist.php index f9d3683..a3e000f 100644 --- a/Build/.php-cs-fixer.dist.php +++ b/Build/.php-cs-fixer.dist.php @@ -20,10 +20,8 @@ die('This script supports command line usage only. Please check your command.'); } -$repositoryName = basename(dirname(__DIR__)); - $header = <<hasTextDbEntry($placeholder)) { - return (string) $translationRequested; + return (string) $translationRequested; } try { diff --git a/Tests/Unit/Controller/TranslationControllerTest.php b/Tests/Unit/Controller/TranslationControllerTest.php index 860a250..31c07d8 100644 --- a/Tests/Unit/Controller/TranslationControllerTest.php +++ b/Tests/Unit/Controller/TranslationControllerTest.php @@ -1,136 +1,77 @@ */ -class TranslationControllerTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCase +class TranslationControllerTest extends UnitTestCase { /** - * @var \Netresearch\NrTextdb\Controller\TranslationController + * @var TranslationController */ - protected $subject = null; - - protected function setUp() - { - parent::setUp(); - $this->subject = $this->getMockBuilder(\Netresearch\NrTextdb\Controller\TranslationController::class) - ->setMethods(['redirect', 'forward', 'addFlashMessage']) - ->disableOriginalConstructor() - ->getMock(); - } - - protected function tearDown() - { - parent::tearDown(); - } + protected TranslationController $subject; /** - * @test + * @return void */ - public function listActionFetchesAllTranslationsFromRepositoryAndAssignsThemToView() + protected function setUp(): void { + parent::setUp(); - $allTranslations = $this->getMockBuilder(\TYPO3\CMS\Extbase\Persistence\ObjectStorage::class) - ->disableOriginalConstructor() - ->getMock(); - - $translationRepository = $this->getMockBuilder(\Netresearch\NrTextdb\Domain\Repository\TranslationRepository::class) - ->setMethods(['findAll']) + $this->subject = $this->getMockBuilder(TranslationController::class) ->disableOriginalConstructor() ->getMock(); - $translationRepository->expects(self::once())->method('findAll')->will(self::returnValue($allTranslations)); - $this->inject($this->subject, 'translationRepository', $translationRepository); - - $view = $this->getMockBuilder(\TYPO3\CMS\Extbase\Mvc\View\ViewInterface::class)->getMock(); - $view->expects(self::once())->method('assign')->with('translations', $allTranslations); - $this->inject($this->subject, 'view', $view); - - $this->subject->listAction(); - } - - /** - * @test - */ - public function showActionAssignsTheGivenTranslationToView() - { - $translation = new \Netresearch\NrTextdb\Domain\Model\Translation(); - - $view = $this->getMockBuilder(\TYPO3\CMS\Extbase\Mvc\View\ViewInterface::class)->getMock(); - $this->inject($this->subject, 'view', $view); - $view->expects(self::once())->method('assign')->with('translation', $translation); - - $this->subject->showAction($translation); } /** * @test */ - public function createActionAddsTheGivenTranslationToTranslationRepository() + public function listActionFetchesAllTranslationsFromRepositoryAndAssignsThemToView(): void { - $translation = new \Netresearch\NrTextdb\Domain\Model\Translation(); + self::markTestIncomplete('Rework'); - $translationRepository = $this->getMockBuilder(\Netresearch\NrTextdb\Domain\Repository\TranslationRepository::class) - ->setMethods(['add']) + $allTranslations = $this->getMockBuilder(QueryResultInterface::class) ->disableOriginalConstructor() ->getMock(); - $translationRepository->expects(self::once())->method('add')->with($translation); - $this->inject($this->subject, 'translationRepository', $translationRepository); - - $this->subject->createAction($translation); - } - - /** - * @test - */ - public function editActionAssignsTheGivenTranslationToView() - { - $translation = new \Netresearch\NrTextdb\Domain\Model\Translation(); - - $view = $this->getMockBuilder(\TYPO3\CMS\Extbase\Mvc\View\ViewInterface::class)->getMock(); - $this->inject($this->subject, 'view', $view); - $view->expects(self::once())->method('assign')->with('translation', $translation); - - $this->subject->editAction($translation); - } - - /** - * @test - */ - public function updateActionUpdatesTheGivenTranslationInTranslationRepository() - { - $translation = new \Netresearch\NrTextdb\Domain\Model\Translation(); - - $translationRepository = $this->getMockBuilder(\Netresearch\NrTextdb\Domain\Repository\TranslationRepository::class) - ->setMethods(['update']) + $translationRepository = $this->getMockBuilder(TranslationRepository::class) ->disableOriginalConstructor() ->getMock(); - $translationRepository->expects(self::once())->method('update')->with($translation); - $this->inject($this->subject, 'translationRepository', $translationRepository); + $translationRepository + ->expects(self::once()) + ->method('getAllRecordsByIdentifier') + ->willReturn($allTranslations); - $this->subject->updateAction($translation); - } + $this->inject($this->subject, 'translationRepository', $translationRepository); - /** - * @test - */ - public function deleteActionRemovesTheGivenTranslationFromTranslationRepository() - { - $translation = new \Netresearch\NrTextdb\Domain\Model\Translation(); + $view = $this->getMockBuilder(ViewInterface::class)->getMock(); - $translationRepository = $this->getMockBuilder(\Netresearch\NrTextdb\Domain\Repository\TranslationRepository::class) - ->setMethods(['remove']) - ->disableOriginalConstructor() - ->getMock(); + $view + ->expects(self::once()) + ->method('assign') + ->with('translations', $allTranslations); - $translationRepository->expects(self::once())->method('remove')->with($translation); - $this->inject($this->subject, 'translationRepository', $translationRepository); + $this->inject($this->subject, 'view', $view); - $this->subject->deleteAction($translation); + $this->subject->listAction(); } } diff --git a/Tests/Unit/Domain/Model/ComponentTest.php b/Tests/Unit/Domain/Model/ComponentTest.php index c45ccbd..e59627a 100644 --- a/Tests/Unit/Domain/Model/ComponentTest.php +++ b/Tests/Unit/Domain/Model/ComponentTest.php @@ -1,34 +1,48 @@ */ -class ComponentTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCase +class ComponentTest extends UnitTestCase { /** - * @var \Netresearch\NrTextdb\Domain\Model\Component + * @var Component */ - protected $subject = null; + protected Component $subject; - protected function setUp() + /** + * @return void + */ + /** + * @return void + */ + protected function setUp(): void { parent::setUp(); - $this->subject = new \Netresearch\NrTextdb\Domain\Model\Component(); - } - protected function tearDown() - { - parent::tearDown(); + $this->subject = new Component(); } /** * @test */ - public function getNameReturnsInitialValueForString() + public function getNameReturnsInitialValueForString(): void { self::assertSame( '', @@ -39,14 +53,13 @@ public function getNameReturnsInitialValueForString() /** * @test */ - public function setNameForStringSetsName() + public function setNameForStringSetsName(): void { $this->subject->setName('Conceived at T3CON10'); - self::assertAttributeEquals( + self::assertSame( 'Conceived at T3CON10', - 'name', - $this->subject + $this->subject->getName() ); } } diff --git a/Tests/Unit/Domain/Model/EnvironmentTest.php b/Tests/Unit/Domain/Model/EnvironmentTest.php index 8b54fb0..38d3a5a 100644 --- a/Tests/Unit/Domain/Model/EnvironmentTest.php +++ b/Tests/Unit/Domain/Model/EnvironmentTest.php @@ -1,34 +1,45 @@ */ -class EnvironmentTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCase +class EnvironmentTest extends UnitTestCase { /** - * @var \Netresearch\NrTextdb\Domain\Model\Environment + * @var Environment */ - protected $subject = null; + protected Environment $subject; - protected function setUp() + /** + * @return void + */ + protected function setUp(): void { parent::setUp(); - $this->subject = new \Netresearch\NrTextdb\Domain\Model\Environment(); - } - protected function tearDown() - { - parent::tearDown(); + $this->subject = new Environment(); } /** * @test */ - public function getNameReturnsInitialValueForString() + public function getNameReturnsInitialValueForString(): void { self::assertSame( '', @@ -39,14 +50,13 @@ public function getNameReturnsInitialValueForString() /** * @test */ - public function setNameForStringSetsName() + public function setNameForStringSetsName(): void { $this->subject->setName('Conceived at T3CON10'); - self::assertAttributeEquals( + self::assertSame( 'Conceived at T3CON10', - 'name', - $this->subject + $this->subject->getName() ); } } diff --git a/Tests/Unit/Domain/Model/TranslationTest.php b/Tests/Unit/Domain/Model/TranslationTest.php index 6133efe..b185b2f 100644 --- a/Tests/Unit/Domain/Model/TranslationTest.php +++ b/Tests/Unit/Domain/Model/TranslationTest.php @@ -1,34 +1,48 @@ */ -class TranslationTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCase +class TranslationTest extends UnitTestCase { /** - * @var \Netresearch\NrTextdb\Domain\Model\Translation + * @var Translation */ - protected $subject = null; + protected Translation $subject; - protected function setUp() + /** + * @return void + */ + protected function setUp(): void { parent::setUp(); - $this->subject = new \Netresearch\NrTextdb\Domain\Model\Translation(); - } - protected function tearDown() - { - parent::tearDown(); + $this->subject = new Translation(); } /** * @test */ - public function getValueReturnsInitialValueForString() + public function getValueReturnsInitialValueForString(): void { self::assertSame( '', @@ -39,21 +53,20 @@ public function getValueReturnsInitialValueForString() /** * @test */ - public function setValueForStringSetsValue() + public function setValueForStringSetsValue(): void { $this->subject->setValue('Conceived at T3CON10'); - self::assertAttributeEquals( + self::assertSame( 'Conceived at T3CON10', - 'value', - $this->subject + $this->subject->getValue() ); } /** * @test */ - public function getEnvironmentReturnsInitialValueForEnvironment() + public function getEnvironmentReturnsInitialValueForEnvironment(): void { self::assertEquals( null, @@ -64,22 +77,21 @@ public function getEnvironmentReturnsInitialValueForEnvironment() /** * @test */ - public function setEnvironmentForEnvironmentSetsEnvironment() + public function setEnvironmentForEnvironmentSetsEnvironment(): void { - $environmentFixture = new \Netresearch\NrTextdb\Domain\Model\Environment(); + $environmentFixture = new Environment(); $this->subject->setEnvironment($environmentFixture); - self::assertAttributeEquals( + self::assertSame( $environmentFixture, - 'environment', - $this->subject + $this->subject->getEnvironment() ); } /** * @test */ - public function getComponentReturnsInitialValueForComponent() + public function getComponentReturnsInitialValueForComponent(): void { self::assertEquals( null, @@ -90,22 +102,21 @@ public function getComponentReturnsInitialValueForComponent() /** * @test */ - public function setComponentForComponentSetsComponent() + public function setComponentForComponentSetsComponent(): void { - $componentFixture = new \Netresearch\NrTextdb\Domain\Model\Component(); + $componentFixture = new Component(); $this->subject->setComponent($componentFixture); - self::assertAttributeEquals( + self::assertSame( $componentFixture, - 'component', - $this->subject + $this->subject->getComponent() ); } /** * @test */ - public function getTypeReturnsInitialValueForType() + public function getTypeReturnsInitialValueForType(): void { self::assertEquals( null, @@ -116,15 +127,14 @@ public function getTypeReturnsInitialValueForType() /** * @test */ - public function setTypeForTypeSetsType() + public function setTypeForTypeSetsType(): void { - $typeFixture = new \Netresearch\NrTextdb\Domain\Model\Type(); + $typeFixture = new Type(); $this->subject->setType($typeFixture); - self::assertAttributeEquals( + self::assertSame( $typeFixture, - 'type', - $this->subject + $this->subject->getType() ); } } diff --git a/Tests/Unit/Domain/Model/TypeTest.php b/Tests/Unit/Domain/Model/TypeTest.php index af9adfd..906103e 100644 --- a/Tests/Unit/Domain/Model/TypeTest.php +++ b/Tests/Unit/Domain/Model/TypeTest.php @@ -1,34 +1,48 @@ */ -class TypeTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCase +class TypeTest extends UnitTestCase { /** - * @var \Netresearch\NrTextdb\Domain\Model\Type + * @var Type */ - protected $subject = null; + protected Type $subject; - protected function setUp() + /** + * @return void + */ + /** + * @return void + */ + protected function setUp(): void { parent::setUp(); - $this->subject = new \Netresearch\NrTextdb\Domain\Model\Type(); - } - protected function tearDown() - { - parent::tearDown(); + $this->subject = new Type(); } /** * @test */ - public function getNameReturnsInitialValueForString() + public function getNameReturnsInitialValueForString(): void { self::assertSame( '', @@ -39,14 +53,13 @@ public function getNameReturnsInitialValueForString() /** * @test */ - public function setNameForStringSetsName() + public function setNameForStringSetsName(): void { $this->subject->setName('Conceived at T3CON10'); - self::assertAttributeEquals( + self::assertSame( 'Conceived at T3CON10', - 'name', - $this->subject + $this->subject->getName() ); } }