Merge pull request #975 from Katalam/repeat

[2.x] Sharing `repeat` iteration as `dataset` variable
This commit is contained in:
Nuno Maduro
2024-01-25 15:01:34 +00:00
committed by GitHub
3 changed files with 34 additions and 2 deletions

View File

@ -265,7 +265,12 @@ trait Testable
$method = TestSuite::getInstance()->tests->get(self::$__filename)->getMethod($this->name()); $method = TestSuite::getInstance()->tests->get(self::$__filename)->getMethod($this->name());
if ($method->repetitions > 1) { if ($method->repetitions > 1) {
array_shift($arguments); // If the test is repeated, the first argument is the iteration number
// we need to move it to the end of the arguments list
// so that the datasets are the first n arguments
// and the iteration number is the last argument
$firstArgument = array_shift($arguments);
$arguments[] = $firstArgument;
} }
$underlyingTest = Reflection::getFunctionVariable($this->__test, 'closure'); $underlyingTest = Reflection::getFunctionVariable($this->__test, 'closure');

View File

@ -117,7 +117,7 @@ final class TestCaseMethodFactory
*/ */
public function receivesArguments(): bool public function receivesArguments(): bool
{ {
return $this->datasets !== [] || $this->depends !== []; return $this->datasets !== [] || $this->depends !== [] || $this->repetitions > 1;
} }
/** /**

View File

@ -16,3 +16,30 @@ test('multiple times with multiple dataset', function (int $numberA, int $number
expect([1, 2, 3])->toContain($numberA) expect([1, 2, 3])->toContain($numberA)
->and([4, 5, 6])->toContain($numberB); ->and([4, 5, 6])->toContain($numberB);
})->repeat(times: 7)->with(['a' => 1, 'b' => 2, 'c' => 3], [4, 5, 6]); })->repeat(times: 7)->with(['a' => 1, 'b' => 2, 'c' => 3], [4, 5, 6]);
test('multiple times with iterator', function (int $iteration) {
expect($iteration)
->toBeNumeric()
->toBeGreaterThan(0);
})->repeat(times: 2);
test('multiple times with repeat iterator with single dataset', function (string $letter, int $iteration) {
expect($letter)
->toBeString()
->toBeIn(['a', 'b', 'c'])
->and($iteration)
->toBeNumeric()
->toBeGreaterThan(0);
})->repeat(times: 2)->with(['a', 'b', 'c']);
test('multiple times with repeat iterator with multiple dataset', function (string $letterA, string $letterB, int $iteration) {
expect($letterA)
->toBeString()
->toBeIn(['a', 'b', 'c'])
->and($letterB)
->toBeString()
->toBeIn(['d', 'e', 'f'])
->and($iteration)
->toBeNumeric()
->toBeGreaterThan(0);
})->repeat(times: 2)->with(['a', 'b', 'c'], ['d', 'e', 'f']);