mirror of
https://github.com/pestphp/pest.git
synced 2026-03-06 07:47:22 +01:00
fix: properties and methods documented
This commit is contained in:
@ -30,6 +30,7 @@ use Pest\Expectations\HigherOrderExpectation;
|
||||
use Pest\Expectations\OppositeExpectation;
|
||||
use Pest\Matchers\Any;
|
||||
use Pest\Support\ExpectationPipeline;
|
||||
use Pest\Support\Reflection;
|
||||
use PHPUnit\Architecture\Elements\ObjectDescription;
|
||||
use PHPUnit\Framework\ExpectationFailedException;
|
||||
use ReflectionEnum;
|
||||
@ -471,7 +472,7 @@ final class Expectation
|
||||
$this,
|
||||
fn (ObjectDescription $object): bool => isset($object->reflectionClass) === false
|
||||
|| array_filter(
|
||||
$object->reflectionClass->getMethods(),
|
||||
Reflection::getMethodsFromReflectionClass($object->reflectionClass),
|
||||
fn (ReflectionMethod $method): bool => (enum_exists($object->name) === false || in_array($method->name, ['from', 'tryFrom', 'cases'], true) === false)
|
||||
&& realpath($method->getFileName() ?: '/') === realpath($object->path) // @phpstan-ignore-line
|
||||
&& $method->getDocComment() === false,
|
||||
@ -490,7 +491,7 @@ final class Expectation
|
||||
$this,
|
||||
fn (ObjectDescription $object): bool => isset($object->reflectionClass) === false
|
||||
|| array_filter(
|
||||
$object->reflectionClass->getProperties(),
|
||||
Reflection::getPropertiesFromReflectionClass($object->reflectionClass),
|
||||
fn (ReflectionProperty $property): bool => (enum_exists($object->name) === false || in_array($property->name, ['value', 'name'], true) === false)
|
||||
&& realpath($property->getDeclaringClass()->getFileName() ?: '/') === realpath($object->path) // @phpstan-ignore-line
|
||||
&& $property->isPromoted() === false
|
||||
|
||||
@ -18,6 +18,7 @@ use Pest\Exceptions\InvalidExpectation;
|
||||
use Pest\Expectation;
|
||||
use Pest\Support\Arr;
|
||||
use Pest\Support\Exporter;
|
||||
use Pest\Support\Reflection;
|
||||
use PHPUnit\Architecture\Elements\ObjectDescription;
|
||||
use PHPUnit\Framework\AssertionFailedError;
|
||||
use PHPUnit\Framework\ExpectationFailedException;
|
||||
@ -107,7 +108,7 @@ final class OppositeExpectation
|
||||
$this->original,
|
||||
fn (ObjectDescription $object): bool => isset($object->reflectionClass) === false
|
||||
|| array_filter(
|
||||
$object->reflectionClass->getMethods(),
|
||||
Reflection::getMethodsFromReflectionClass($object->reflectionClass),
|
||||
fn (ReflectionMethod $method): bool => (enum_exists($object->name) === false || in_array($method->name, ['from', 'tryFrom', 'cases'], true) === false)
|
||||
&& realpath($method->getFileName() ?: '/') === realpath($object->path) // @phpstan-ignore-line
|
||||
&& $method->getDocComment() !== false,
|
||||
@ -126,7 +127,7 @@ final class OppositeExpectation
|
||||
$this->original,
|
||||
fn (ObjectDescription $object): bool => isset($object->reflectionClass) === false
|
||||
|| array_filter(
|
||||
$object->reflectionClass->getProperties(),
|
||||
Reflection::getPropertiesFromReflectionClass($object->reflectionClass),
|
||||
fn (ReflectionProperty $property): bool => (enum_exists($object->name) === false || in_array($property->name, ['value', 'name'], true) === false)
|
||||
&& realpath($property->getDeclaringClass()->getFileName() ?: '/') === realpath($object->path) // @phpstan-ignore-line
|
||||
&& $property->isPromoted() === false
|
||||
|
||||
@ -11,6 +11,7 @@ use Pest\TestSuite;
|
||||
use ReflectionClass;
|
||||
use ReflectionException;
|
||||
use ReflectionFunction;
|
||||
use ReflectionMethod;
|
||||
use ReflectionNamedType;
|
||||
use ReflectionParameter;
|
||||
use ReflectionProperty;
|
||||
@ -213,4 +214,74 @@ final class Reflection
|
||||
{
|
||||
return (new ReflectionFunction($function))->getStaticVariables()[$key] ?? null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the properties from the given reflection class.
|
||||
*
|
||||
* Used by `expect()->toHavePropertiesDocumented()`.
|
||||
*
|
||||
* @param ReflectionClass<object> $reflectionClass
|
||||
* @return array<int, ReflectionProperty>
|
||||
*/
|
||||
public static function getPropertiesFromReflectionClass(ReflectionClass $reflectionClass): array
|
||||
{
|
||||
$getProperties = fn (ReflectionClass $reflectionClass): array => array_filter(
|
||||
array_map(
|
||||
fn (ReflectionProperty $property): \ReflectionProperty => $property,
|
||||
$reflectionClass->getProperties(),
|
||||
), fn (ReflectionProperty $property): bool => $property->getDeclaringClass()->getName() === $reflectionClass->getName(),
|
||||
);
|
||||
|
||||
$propertiesFromTraits = [];
|
||||
foreach ($reflectionClass->getTraits() as $trait) {
|
||||
$propertiesFromTraits = array_merge($propertiesFromTraits, $getProperties($trait));
|
||||
}
|
||||
|
||||
$propertiesFromTraits = array_map(
|
||||
fn (ReflectionProperty $property): string => $property->getName(),
|
||||
$propertiesFromTraits,
|
||||
);
|
||||
|
||||
return array_values(
|
||||
array_filter(
|
||||
$getProperties($reflectionClass),
|
||||
fn (ReflectionProperty $property): bool => ! in_array($property->getName(), $propertiesFromTraits, true),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the methods from the given reflection class.
|
||||
*
|
||||
* Used by `expect()->toHaveMethodsDocumented()`.
|
||||
*
|
||||
* @param ReflectionClass<object> $reflectionClass
|
||||
* @return array<int, ReflectionMethod>
|
||||
*/
|
||||
public static function getMethodsFromReflectionClass(ReflectionClass $reflectionClass): array
|
||||
{
|
||||
$getMethods = fn (ReflectionClass $reflectionClass): array => array_filter(
|
||||
array_map(
|
||||
fn (ReflectionMethod $method): \ReflectionMethod => $method,
|
||||
$reflectionClass->getMethods(),
|
||||
), fn (ReflectionMethod $method): bool => $method->getDeclaringClass()->getName() === $reflectionClass->getName(),
|
||||
);
|
||||
|
||||
$methodsFromTraits = [];
|
||||
foreach ($reflectionClass->getTraits() as $trait) {
|
||||
$methodsFromTraits = array_merge($methodsFromTraits, $getMethods($trait));
|
||||
}
|
||||
|
||||
$methodsFromTraits = array_map(
|
||||
fn (ReflectionMethod $method): string => $method->getName(),
|
||||
$methodsFromTraits,
|
||||
);
|
||||
|
||||
return array_values(
|
||||
array_filter(
|
||||
$getMethods($reflectionClass),
|
||||
fn (ReflectionMethod $method): bool => ! in_array($method->getName(), $methodsFromTraits, true),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user