mirror of
https://github.com/pestphp/pest.git
synced 2026-03-07 00:07:22 +01:00
195 lines
4.8 KiB
PHP
195 lines
4.8 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Pest\PendingObjects;
|
|
|
|
use Closure;
|
|
use Pest\Factories\TestCaseFactory;
|
|
use Pest\Support\Backtrace;
|
|
use Pest\Support\NullClosure;
|
|
use Pest\TestSuite;
|
|
use PHPUnit\Framework\ExecutionOrderDependency;
|
|
use SebastianBergmann\Exporter\Exporter;
|
|
|
|
/**
|
|
* @method \Pest\Expectation expect(mixed $value)
|
|
*
|
|
* @internal
|
|
*/
|
|
final class TestCall
|
|
{
|
|
/**
|
|
* Holds the test suite.
|
|
*
|
|
* @readonly
|
|
*
|
|
* @var TestSuite
|
|
*/
|
|
private $testSuite;
|
|
|
|
/**
|
|
* Holds the test case factory.
|
|
*
|
|
* @readonly
|
|
*
|
|
* @var TestCaseFactory
|
|
*/
|
|
private $testCaseFactory;
|
|
|
|
/**
|
|
* If test call is descriptionLess.
|
|
*
|
|
* @readonly
|
|
*
|
|
* @var bool
|
|
*/
|
|
private $descriptionLess = false;
|
|
|
|
/**
|
|
* Creates a new instance of a pending test call.
|
|
*/
|
|
public function __construct(TestSuite $testSuite, string $filename, string $description = null, Closure $closure = null)
|
|
{
|
|
$this->testCaseFactory = new TestCaseFactory($filename, $description, $closure);
|
|
$this->testSuite = $testSuite;
|
|
$this->descriptionLess = $description === null;
|
|
}
|
|
|
|
/**
|
|
* Asserts that the test throws the given `$exceptionClass` when called.
|
|
*/
|
|
public function throws(string $exceptionClass, string $exceptionMessage = null): TestCall
|
|
{
|
|
$this->testCaseFactory
|
|
->proxies
|
|
->add(Backtrace::file(), Backtrace::line(), 'expectException', [$exceptionClass]);
|
|
|
|
if (is_string($exceptionMessage)) {
|
|
$this->testCaseFactory
|
|
->proxies
|
|
->add(Backtrace::file(), Backtrace::line(), 'expectExceptionMessage', [$exceptionMessage]);
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Runs the current test multiple times with
|
|
* each item of the given `iterable`.
|
|
*
|
|
* @param \Closure|iterable<int, mixed>|string $data
|
|
*/
|
|
public function with($data): TestCall
|
|
{
|
|
$this->testCaseFactory->dataset = $data;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Sets the test depends.
|
|
*/
|
|
public function depends(string ...$tests): TestCall
|
|
{
|
|
$className = $this->testCaseFactory->getClassName();
|
|
|
|
$tests = array_map(function (string $test) use ($className): ExecutionOrderDependency {
|
|
if (strpos($test, '::') === false) {
|
|
$test = "{$className}::{$test}";
|
|
}
|
|
|
|
return new ExecutionOrderDependency($test, null, '');
|
|
}, $tests);
|
|
|
|
$this->testCaseFactory
|
|
->factoryProxies
|
|
->add(Backtrace::file(), Backtrace::line(), 'setDependencies', [$tests]);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Makes the test suite only this test case.
|
|
*/
|
|
public function only(): TestCall
|
|
{
|
|
$this->testCaseFactory->only = true;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Sets the test group(s).
|
|
*/
|
|
public function group(string ...$groups): TestCall
|
|
{
|
|
$this->testCaseFactory
|
|
->factoryProxies
|
|
->add(Backtrace::file(), Backtrace::line(), 'addGroups', [$groups]);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Skips the current test.
|
|
*
|
|
* @param Closure|bool|string $conditionOrMessage
|
|
*/
|
|
public function skip($conditionOrMessage = true, string $message = ''): TestCall
|
|
{
|
|
$condition = is_string($conditionOrMessage)
|
|
? NullClosure::create()
|
|
: $conditionOrMessage;
|
|
|
|
$condition = is_callable($condition)
|
|
? $condition
|
|
: function () use ($condition) { /* @phpstan-ignore-line */
|
|
return $condition;
|
|
};
|
|
|
|
$message = is_string($conditionOrMessage)
|
|
? $conditionOrMessage
|
|
: $message;
|
|
|
|
if ($condition() !== false) {
|
|
$this->testCaseFactory
|
|
->chains
|
|
->add(Backtrace::file(), Backtrace::line(), 'markTestSkipped', [$message]);
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Saves the calls to be used on the target.
|
|
*
|
|
* @param array<int, mixed> $arguments
|
|
*/
|
|
public function __call(string $name, array $arguments): self
|
|
{
|
|
$this->testCaseFactory
|
|
->chains
|
|
->add(Backtrace::file(), Backtrace::line(), $name, $arguments);
|
|
|
|
if ($this->descriptionLess) {
|
|
$exporter = new Exporter();
|
|
if ($this->testCaseFactory->description !== null) {
|
|
$this->testCaseFactory->description .= ' → ';
|
|
}
|
|
$this->testCaseFactory->description .= sprintf('%s %s', $name, $exporter->shortenedRecursiveExport($arguments));
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Adds the current test case factory
|
|
* to the tests repository.
|
|
*/
|
|
public function __destruct()
|
|
{
|
|
$this->testSuite->tests->set($this->testCaseFactory);
|
|
}
|
|
}
|