more fixes

This commit is contained in:
Nuno Maduro
2024-09-05 01:19:17 +01:00
parent 68785986a0
commit 98e947e0cc
3 changed files with 24 additions and 15 deletions

View File

@ -215,8 +215,10 @@ if (! function_exists('afterAll')) {
if (! function_exists('covers')) {
/**
* Specifies which classes, or functions, a test method covers.
*
* @param array<int, string>|string $classesOrFunctions
*/
function covers(string ...$classesOrFunctions): void
function covers(array|string ...$classesOrFunctions): void
{
$filename = Backtrace::file();

View File

@ -514,14 +514,19 @@ final class TestCall
/**
* Sets the covered classes or methods.
*
* @param array<int, string>|string $classesOrFunctions
*/
public function covers(string ...$classesOrFunctions): self
public function covers(array|string ...$classesOrFunctions): self
{
foreach ($classesOrFunctions as $classOrFunction) {
$isClass = class_exists($classOrFunction) || trait_exists($classOrFunction);
$isMethod = function_exists($classOrFunction);
/** @var array<int, string> $classesOrFunctions */
$classesOrFunctions = array_reduce($classesOrFunctions, fn ($carry, $item): array => is_array($item) ? array_merge($carry, $item) : array_merge($carry, [$item]), []);
if (! $isClass && ! $isMethod) {
foreach ($classesOrFunctions as $classOrFunction) {
$isClass = class_exists($classOrFunction) || trait_exists($classOrFunction) || interface_exists($classOrFunction) || enum_exists($classOrFunction);
$isFunction = function_exists($classOrFunction);
if (! $isClass && ! $isFunction) {
throw new InvalidArgumentException(sprintf('No class or method named "%s" has been found.', $classOrFunction));
}