closure = $closure instanceof Closure ? $closure : NullClosure::create(); $this->testCallProxies = new HigherOrderMessageCollection(); $this->testCaseProxies = new HigherOrderMessageCollection(); $this->describing = DescribeCall::describing(); } /** * Creates the Call. */ public function __destruct() { $describing = $this->describing; $testCaseProxies = $this->testCaseProxies; $beforeEachTestCall = function (TestCall $testCall) use ($describing): void { if ($describing !== $this->describing) { return; } if ($describing !== $testCall->describing) { return; } $this->testCallProxies->chain($testCall); }; $beforeEachTestCase = ChainableClosure::boundWhen( fn (): bool => is_null($describing) || $this->__describing === $describing, // @phpstan-ignore-line ChainableClosure::bound(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; } }