mirror of
https://github.com/pestphp/pest.git
synced 2026-03-07 08:17:22 +01:00
176 lines
3.9 KiB
PHP
176 lines
3.9 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Pest\Concerns;
|
|
|
|
use Closure;
|
|
use Pest\Expectation;
|
|
use Pest\Support\ExceptionTrace;
|
|
use Pest\TestSuite;
|
|
use PHPUnit\Util\Test;
|
|
use Throwable;
|
|
|
|
/**
|
|
* To avoid inheritance conflicts, all the fields related
|
|
* to Pest only will be prefixed by double underscore.
|
|
*
|
|
* @internal
|
|
*/
|
|
trait TestCase
|
|
{
|
|
/**
|
|
* The test case description. Contains the first
|
|
* argument of global functions like `it` and `test`.
|
|
*
|
|
* @var string
|
|
*/
|
|
private $__description;
|
|
|
|
/**
|
|
* Holds the test closure function.
|
|
*
|
|
* @var Closure
|
|
*/
|
|
private $__test;
|
|
|
|
/**
|
|
* Creates a new instance of the test case.
|
|
*/
|
|
public function __construct(Closure $test, string $description, array $data)
|
|
{
|
|
$this->__test = $test;
|
|
$this->__description = $description;
|
|
|
|
parent::__construct('__test', $data);
|
|
}
|
|
|
|
/**
|
|
* Adds the groups to the current test case.
|
|
*/
|
|
public function addGroups(array $groups): void
|
|
{
|
|
$groups = array_unique(array_merge($this->getGroups(), $groups));
|
|
|
|
$this->setGroups($groups);
|
|
}
|
|
|
|
/**
|
|
* Returns the test case name. Note that, in Pest
|
|
* we ignore withDataset argument as the description
|
|
* already contains the dataset description.
|
|
*/
|
|
public function getName(bool $withDataSet = true): string
|
|
{
|
|
return $this->__description;
|
|
}
|
|
|
|
public static function __getFileName(): string
|
|
{
|
|
return self::$__filename;
|
|
}
|
|
|
|
/**
|
|
* This method is called before the first test of this test class is run.
|
|
*/
|
|
public static function setUpBeforeClass(): void
|
|
{
|
|
parent::setUpBeforeClass();
|
|
|
|
$beforeAll = TestSuite::getInstance()->beforeAll->get(self::$__filename);
|
|
|
|
call_user_func(Closure::bind($beforeAll, null, self::class));
|
|
}
|
|
|
|
/**
|
|
* This method is called after the last test of this test class is run.
|
|
*/
|
|
public static function tearDownAfterClass(): void
|
|
{
|
|
$afterAll = TestSuite::getInstance()->afterAll->get(self::$__filename);
|
|
|
|
call_user_func(Closure::bind($afterAll, null, self::class));
|
|
|
|
parent::tearDownAfterClass();
|
|
}
|
|
|
|
/**
|
|
* Creates a new expectation.
|
|
*
|
|
* @param mixed $value
|
|
*/
|
|
public function expect($value): Expectation
|
|
{
|
|
return new Expectation($value);
|
|
}
|
|
|
|
/**
|
|
* Gets executed before the test.
|
|
*/
|
|
protected function setUp(): void
|
|
{
|
|
TestSuite::getInstance()->test = $this;
|
|
|
|
parent::setUp();
|
|
|
|
$beforeEach = TestSuite::getInstance()->beforeEach->get(self::$__filename);
|
|
|
|
$this->__callClosure($beforeEach, func_get_args());
|
|
}
|
|
|
|
/**
|
|
* Gets executed after the test.
|
|
*/
|
|
protected function tearDown(): void
|
|
{
|
|
$afterEach = TestSuite::getInstance()->afterEach->get(self::$__filename);
|
|
|
|
$this->__callClosure($afterEach, func_get_args());
|
|
|
|
parent::tearDown();
|
|
|
|
TestSuite::getInstance()->test = null;
|
|
}
|
|
|
|
/**
|
|
* Returns the test case as string.
|
|
*/
|
|
public function toString(): string
|
|
{
|
|
return \sprintf(
|
|
'%s::%s',
|
|
self::$__filename,
|
|
$this->__description
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Runs the test.
|
|
*
|
|
* @return mixed
|
|
*
|
|
* @throws Throwable
|
|
*/
|
|
public function __test()
|
|
{
|
|
return $this->__callClosure($this->__test, func_get_args());
|
|
}
|
|
|
|
/**
|
|
* @return mixed
|
|
*
|
|
* @throws Throwable
|
|
*/
|
|
private function __callClosure(Closure $closure, array $arguments)
|
|
{
|
|
return ExceptionTrace::ensure(function () use ($closure, $arguments) {
|
|
return call_user_func_array(Closure::bind($closure, $this, get_class($this)), $arguments);
|
|
});
|
|
}
|
|
|
|
public function getPrintableTestCaseName(): string
|
|
{
|
|
return ltrim(self::class, 'P\\');
|
|
}
|
|
}
|