Skip to content

Commit

Permalink
FEATURE: Add todo warnings for all NodeTemplate::* methods
Browse files Browse the repository at this point in the history
  • Loading branch information
dlubitz committed Dec 19, 2024
1 parent 25d62b6 commit 3cf9eab
Show file tree
Hide file tree
Showing 9 changed files with 300 additions and 0 deletions.
24 changes: 24 additions & 0 deletions config/set/contentrepository-90.php
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@
use Neos\Rector\Generic\Rules\FusionReplacePrototypeNameRector;
use Neos\Rector\Generic\Rules\InjectServiceIfNeededRector;
use Neos\Rector\Generic\Rules\MethodCallToWarningCommentRector;
use Neos\Rector\Generic\Rules\ObjectInstantiationToWarningCommentRector;
use Neos\Rector\Generic\Rules\RemoveInjectionsRector;
use Neos\Rector\Generic\Rules\SignalSlotToWarningCommentRector;
use Neos\Rector\Generic\Rules\ToStringToMethodCallOrPropertyFetchRector;
Expand All @@ -79,6 +80,7 @@
use Neos\Rector\Generic\ValueObject\FusionPrototypeNameAddComment;
use Neos\Rector\Generic\ValueObject\FusionPrototypeNameReplacement;
use Neos\Rector\Generic\ValueObject\MethodCallToWarningComment;
use Neos\Rector\Generic\ValueObject\ObjectInstantiationToWarningComment;
use Neos\Rector\Generic\ValueObject\RemoveInjection;
use Neos\Rector\Generic\ValueObject\RemoveParentClass;
use Neos\Rector\Generic\ValueObject\SignalSlotToWarningComment;
Expand Down Expand Up @@ -435,6 +437,28 @@
*/
$rectorConfig->rule(WorkspaceGetNameRector::class);

/**
* NodeTemplate
*/
$nodeTemplateWarningMessage = '!! NodeTemplate::%2$s is removed in Neos 9.0. Use the "CreateNodeAggregateWithNode" command to create new nodes or "CreateNodeVariant" command to create variants of an existing node in other dimensions.';
// getIdentifier(): string
$methodCallToWarningComments[] = new MethodCallToWarningComment(\Neos\ContentRepository\Domain\Model\NodeTemplate::class, 'getIdentifier', $nodeTemplateWarningMessage);
// getName(): string
$methodCallToWarningComments[] = new MethodCallToWarningComment(\Neos\ContentRepository\Domain\Model\NodeTemplate::class, 'getName', $nodeTemplateWarningMessage);
// getWorkspace(): void
$methodCallToWarningComments[] = new MethodCallToWarningComment(\Neos\ContentRepository\Domain\Model\NodeTemplate::class, 'getWorkspace', $nodeTemplateWarningMessage);
// setIdentifier(identifier: string): void
$methodCallToWarningComments[] = new MethodCallToWarningComment(\Neos\ContentRepository\Domain\Model\NodeTemplate::class, 'setIdentifier', $nodeTemplateWarningMessage);
// setName(newName: string): void
$methodCallToWarningComments[] = new MethodCallToWarningComment(\Neos\ContentRepository\Domain\Model\NodeTemplate::class, 'setName', $nodeTemplateWarningMessage);

/**
* ObjectInstantiationToWarningComment
*/
$rectorConfig->ruleWithConfiguration(ObjectInstantiationToWarningCommentRector::class, [
new ObjectInstantiationToWarningComment(\Neos\ContentRepository\Domain\Model\NodeTemplate::class, '!! NodeTemplate is removed in Neos 9.0. Use the "CreateNodeAggregateWithNode" command to create new nodes or "CreateNodeVariant" command to create variants of an existing node in other dimensions.')]
);

/**
* Signals and Slots
* https://docs.neos.io/api/upgrade-instructions/9/signals-and-slots
Expand Down
83 changes: 83 additions & 0 deletions src/Generic/Rules/ObjectInstantiationToWarningCommentRector.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
<?php

declare (strict_types=1);

namespace Neos\Rector\Generic\Rules;

use Neos\Rector\Generic\ValueObject\ObjectInstantiationToWarningComment;
use Neos\Rector\Utility\CodeSampleLoader;
use PhpParser\Node;
use PhpParser\Node\Name;
use PHPStan\Type\ObjectType;
use Rector\Core\Contract\Rector\ConfigurableRectorInterface;
use Rector\Core\Rector\AbstractRector;
use Rector\NodeTypeResolver\Node\AttributeKey;
use Rector\PostRector\Collector\NodesToAddCollector;
use Symplify\RuleDocGenerator\ValueObject\RuleDefinition;
use Webmozart\Assert\Assert;

final class ObjectInstantiationToWarningCommentRector extends AbstractRector implements ConfigurableRectorInterface
{
use AllTraits;

/**
* @var ObjectInstantiationToWarningComment[]
*/
private array $objectInstantiationToWarningComments = [];

public function __construct(
private readonly NodesToAddCollector $nodesToAddCollector,
) {
}

public function getRuleDefinition(): RuleDefinition
{
return CodeSampleLoader::fromFile('"Warning comments for various non-supported signals', __CLASS__, [
new ObjectInstantiationToWarningComment(Node::class, '!! This signal "beforeMove" on Node doesn\'t exist anymore')
]);
}

/**
* @return array<class-string<Node>>
*/
public function getNodeTypes(): array
{
return [Name::class];
}

/**
* @param \PhpParser\Node\Name $node
*/
public function refactor(Node $node): ?Node
{
assert($node instanceof Name);

if ($node->getAttribute(AttributeKey::PARENT_NODE) instanceof Node\Stmt\UseUse) {
return null;
}

foreach ($this->objectInstantiationToWarningComments as $objectInstantiationToWarningComment) {
if (!$this->isObjectType($node, new ObjectType($objectInstantiationToWarningComment->className))) {
continue;
}

$this->nodesToAddCollector->addNodesBeforeNode(
[
self::todoComment(sprintf($objectInstantiationToWarningComment->warningMessage, $objectInstantiationToWarningComment->className))
],
$node
);
}
return $node;
}


/**
* @param mixed[] $configuration
*/
public function configure(array $configuration): void
{
Assert::allIsAOf($configuration, ObjectInstantiationToWarningComment::class);
$this->objectInstantiationToWarningComments = $configuration;
}
}
13 changes: 13 additions & 0 deletions src/Generic/ValueObject/ObjectInstantiationToWarningComment.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<?php
declare(strict_types=1);

namespace Neos\Rector\Generic\ValueObject;

class ObjectInstantiationToWarningComment
{
public function __construct(
public readonly string $className,
public readonly string $warningMessage,
) {
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
<?php

use Neos\Flow\Package\Package as BasePackage;

class Package extends BasePackage
{
public function boot()
{
$myComment = new \My\Class\To\Comment();
}
}

?>
-----
<?php

use Neos\Flow\Package\Package as BasePackage;

class Package extends BasePackage
{
public function boot()
{
// TODO 9.0 migration: This is a comment

$myComment = new \My\Class\To\Comment();
}
}

?>
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<?php

use My\Class\To\Comment;
use Neos\Flow\Package\Package as BasePackage;

class Package extends BasePackage
{
public function boot()
{
$author = (new Comment(['author']))->getAutor();
}
}

?>
-----
<?php

use My\Class\To\Comment;
use Neos\Flow\Package\Package as BasePackage;

class Package extends BasePackage
{
public function boot()
{
// TODO 9.0 migration: This is a comment

$author = (new Comment(['author']))->getAutor();
}
}

?>
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<?php

use My\Class\To\Comment;
use Neos\Flow\Package\Package as BasePackage;

class Package extends BasePackage
{
public function boot()
{
$myComment = new Comment();
}
}

?>
-----
<?php

use My\Class\To\Comment;
use Neos\Flow\Package\Package as BasePackage;

class Package extends BasePackage
{
public function boot()
{
// TODO 9.0 migration: This is a comment

$myComment = new Comment();
}
}

?>
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<?php

declare(strict_types=1);

namespace Neos\Rector\Tests\Generic\Rules\ToStringToPropertyFetchRector;

use Rector\Testing\PHPUnit\AbstractRectorTestCase;

final class ObjectInstantiationToWarningCommentRectorTest extends AbstractRectorTestCase
{
/**
* @dataProvider provideData()
*/
public function test(string $fileInfo): void
{
$this->doTestFile($fileInfo);
}

/**
* @return \Iterator<string>
*/
public function provideData(): \Iterator
{
return $this->yieldFilesFromDirectory(__DIR__ . '/Fixture');
}

public function provideConfigFilePath(): string
{
return __DIR__ . '/config/configured_rule.php';
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<?php

declare (strict_types=1);

use Neos\Rector\Generic\Rules\ObjectInstantiationToWarningCommentRector;
use Neos\Rector\Generic\ValueObject\ObjectInstantiationToWarningComment;
use Rector\Config\RectorConfig;

return static function (RectorConfig $rectorConfig): void {
$rectorConfig->ruleWithConfiguration(ObjectInstantiationToWarningCommentRector::class, [
new ObjectInstantiationToWarningComment(\My\Class\To\Comment::class, 'This is a comment'),
]);
};
45 changes: 45 additions & 0 deletions tests/Sets/ContentRepository90/Fixture/node-template.php.inc
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
<?php

use Neos\ContentRepository\Domain\Model\NodeTemplate;

class SomeClass {

public function foo()
{
$nodeTemplate = new NodeTemplate();
$nodeTemplate->getIdentifier();
$nodeTemplate->getName();
$nodeTemplate->getWorkspace();
$nodeTemplate->setIdentifier();
$nodeTemplate->setName();
}
}
-----
<?php

use Neos\ContentRepository\Domain\Model\NodeTemplate;

class SomeClass {

public function foo()
{
// TODO 9.0 migration: !! NodeTemplate is removed in Neos 9.0. Use the "CreateNodeAggregateWithNode" command to create new nodes or "CreateNodeVariant" command to create variants of an existing node in other dimensions.

$nodeTemplate = new NodeTemplate();
// TODO 9.0 migration: !! NodeTemplate::getIdentifier is removed in Neos 9.0. Use the "CreateNodeAggregateWithNode" command to create new nodes or "CreateNodeVariant" command to create variants of an existing node in other dimensions.

$nodeTemplate->getIdentifier();
// TODO 9.0 migration: !! NodeTemplate::getName is removed in Neos 9.0. Use the "CreateNodeAggregateWithNode" command to create new nodes or "CreateNodeVariant" command to create variants of an existing node in other dimensions.

$nodeTemplate->getName();
// TODO 9.0 migration: !! NodeTemplate::getWorkspace is removed in Neos 9.0. Use the "CreateNodeAggregateWithNode" command to create new nodes or "CreateNodeVariant" command to create variants of an existing node in other dimensions.

$nodeTemplate->getWorkspace();
// TODO 9.0 migration: !! NodeTemplate::setIdentifier is removed in Neos 9.0. Use the "CreateNodeAggregateWithNode" command to create new nodes or "CreateNodeVariant" command to create variants of an existing node in other dimensions.

$nodeTemplate->setIdentifier();
// TODO 9.0 migration: !! NodeTemplate::setName is removed in Neos 9.0. Use the "CreateNodeAggregateWithNode" command to create new nodes or "CreateNodeVariant" command to create variants of an existing node in other dimensions.

$nodeTemplate->setName();
}
}

0 comments on commit 3cf9eab

Please sign in to comment.