closure = $closure instanceof Closure ? $closure : NullClosure::create(); $this->testCallProxies = new HigherOrderMessageCollection(); $this->testCaseProxies = new HigherOrderMessageCollection(); } /** * Creates the Call. */ public function __destruct() { PendingCalls::beforeEach($this, function (string $describing = null) { $testCaseProxies = $this->testCaseProxies; $beforeEachTestCall = function (TestCall $testCall) use ($describing): void { if (is_null($describing) || ($this->describing === $testCall->describing && $testCall->describing === $describing)) { $this->testCallProxies->chain($testCall); } }; $beforeEachTestCase = ChainableClosure::when( fn () => is_null($describing) || $this->__describeDescription === $describing, // @phpstan-ignore-line ChainableClosure::from(fn () => $testCaseProxies->chain($this), $this->closure)->bindTo($this, self::class), // @phpstan-ignore-line )->bindTo($this, self::class); assert($beforeEachTestCase instanceof Closure); $this->testSuite->beforeEach->set( $this->filename, $this, $beforeEachTestCall, $beforeEachTestCase, ); }); } /** * Saves the calls to be used on the target. * * @param array $arguments */ public function __call(string $name, array $arguments): self { if (method_exists(TestCall::class, $name)) { $this->testCallProxies->add(Backtrace::file(), Backtrace::line(), $name, $arguments); return $this; } $this->testCaseProxies ->add(Backtrace::file(), Backtrace::line(), $name, $arguments); return $this; } }