Skip to content

Commit

Permalink
Merge pull request #49 from svera/add-enum
Browse files Browse the repository at this point in the history
Add enum to visitor
  • Loading branch information
andimov authored Nov 21, 2023
2 parents 3b85c72 + 0579a55 commit 7f240cf
Show file tree
Hide file tree
Showing 5 changed files with 98 additions and 4 deletions.
54 changes: 54 additions & 0 deletions dev/tests/Unit/ClassHierarchy/EntityTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -479,6 +479,21 @@ public function testIsTrait(string $type, bool $expected)
);
}

/**
* @dataProvider dataProviderIsEnum
* @param string $type
* @param bool $expected
*/
public function testIsEnum(string $type, bool $expected)
{
$entity = new Entity('myName', $type);

$this->assertEquals(
$expected,
$entity->isEnum()
);
}

/*
* Data providers
*/
Expand All @@ -503,6 +518,10 @@ public function dataProviderIsClass()
Entity::TYPE_TRAIT,
false,
],
'entity-is-enum-returns-false' => [
Entity::TYPE_ENUM,
false,
],
];
}

Expand All @@ -526,6 +545,10 @@ public function dataProviderIsInterface()
Entity::TYPE_TRAIT,
false,
],
'entity-is-enum-returns-false' => [
Entity::TYPE_ENUM,
false,
],
];
}

Expand All @@ -549,6 +572,37 @@ public function dataProviderIsTrait()
Entity::TYPE_TRAIT,
true,
],
'entity-is-enum-returns-false' => [
Entity::TYPE_ENUM,
false,
],
];
}

/**
* Provides test data for {@link EntityTest::testIsEnum()}
*
* @return array
*/
public function dataProviderIsEnum()
{
return [
'entity-is-class-returns-false' => [
Entity::TYPE_CLASS,
false,
],
'entity-is-interface-returns-false' => [
Entity::TYPE_INTERFACE,
false,
],
'entity-is-trait-returns-false' => [
Entity::TYPE_TRAIT,
false,
],
'entity-is-enum-returns-true' => [
Entity::TYPE_ENUM,
true,
],
];
}

Expand Down
16 changes: 16 additions & 0 deletions src/ClassHierarchy/DependencyGraph.php
Original file line number Diff line number Diff line change
Expand Up @@ -103,4 +103,20 @@ public function findOrCreateTrait(string $fullyQualifiedName): Entity

return $trait;
}

/**
* @param string $fullyQualifiedName
* @return Entity
*/
public function findOrCreateEnum(string $fullyQualifiedName): Entity
{
$enum = $this->findEntityByName($fullyQualifiedName);

if (!$enum) {
$enum = $this->entityFactory->createEnum($fullyQualifiedName);
$this->addEntity($enum);
}

return $enum;
}
}
10 changes: 7 additions & 3 deletions src/ClassHierarchy/DependencyInspectionVisitor.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@

use Magento\SemanticVersionChecker\Helper\Node as NodeHelper;
use PhpParser\Node;
use PhpParser\Node\Stmt\Enum_ as EnumNode;
use PhpParser\Node\Stmt\Class_ as ClassNode;
use PhpParser\Node\Stmt\ClassLike;
use PhpParser\Node\Stmt\ClassMethod;
Expand All @@ -22,7 +23,7 @@
use PhpParser\NodeVisitorAbstract;

/**
* Implements a visitor for `class`, `interface` and `trait` nodes that generates a dependency graph.
* Implements a visitor for `class`, `interface`, `trait` and `enum` nodes that generates a dependency graph.
*/
class DependencyInspectionVisitor extends NodeVisitorAbstract
{
Expand Down Expand Up @@ -94,8 +95,8 @@ public function enterNode(Node $node)
}

/**
* Handles Class, Interface, and Traits nodes. Sets currentClassLike entity and will populate extends, implements,
* and API information
* Handles Class, Interface, Traits and Enum nodes. Sets currentClassLike entity and will populate extends,
* implements, and API information
*
* @param ClassLike $node
* @return int|null
Expand Down Expand Up @@ -135,6 +136,9 @@ private function handleClassLike(ClassLike $node)
case $node instanceof TraitNode:
$this->currentClassLike = $this->dependencyGraph->findOrCreateTrait((string)$namespacedName);
break;
case $node instanceof EnumNode:
$this->currentClassLike = $this->dependencyGraph->findOrCreateEnum((string)$namespacedName);
break;
}
$this->currentClassLike->setIsApi($this->nodeHelper->isApiNode($node));
return null;
Expand Down
13 changes: 12 additions & 1 deletion src/ClassHierarchy/Entity.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
use PhpParser\Node\Stmt\PropertyProperty;

/**
* Implements an entity that reflects a `class`, `interface` or `trait` and its dependencies.
* Implements an entity that reflects a `class`, `interface`, `enum` or `trait` and its dependencies.
*/
class Entity
{
Expand All @@ -24,6 +24,7 @@ class Entity
public const TYPE_CLASS = 'class';
public const TYPE_INTERFACE = 'interface';
public const TYPE_TRAIT = 'trait';
public const TYPE_ENUM = 'enum';
/**#@-*/

/**
Expand Down Expand Up @@ -327,6 +328,16 @@ public function isTrait(): bool
return $this->type === self::TYPE_TRAIT;
}

/**
* Reflects whether current entity reflects an `enum`.
*
* @return bool
*/
public function isEnum(): bool
{
return $this->type === self::TYPE_ENUM;
}

/*
* Private methods
*/
Expand Down
9 changes: 9 additions & 0 deletions src/ClassHierarchy/EntityFactory.php
Original file line number Diff line number Diff line change
Expand Up @@ -40,4 +40,13 @@ public function createTrait(string $name): Entity
{
return new Entity($name, Entity::TYPE_TRAIT);
}

/**
* @param string $name
* @return Entity
*/
public function createEnum(string $name): Entity
{
return new Entity($name, Entity::TYPE_ENUM);
}
}

0 comments on commit 7f240cf

Please sign in to comment.