From cd8a756294bc087c5ea4ecde6e941fb4f91e2100 Mon Sep 17 00:00:00 2001 From: mk-mxp <55182845+mk-mxp@users.noreply.github.com> Date: Sun, 21 Apr 2024 15:13:50 +0200 Subject: [PATCH] Test timeout issues (#683) Co-authored-by: homersimpsons --- bin/test.sh | 13 +++++++++++- .../practice/robot-name/RobotNameTest.php | 20 +++++++++++++++++-- 2 files changed, 30 insertions(+), 3 deletions(-) diff --git a/bin/test.sh b/bin/test.sh index 16380de4..b54292c7 100755 --- a/bin/test.sh +++ b/bin/test.sh @@ -58,7 +58,18 @@ function test { cp "${exercise_dir}/.meta/${example_file}" "${outdir}/${exercise_file}.${file_ext}" fi - eval "${PHPUNIT_BIN}" --no-configuration "${outdir}/${test_file}" + # `54s` timeout is an approximation to ensure the tests will not timeont in Exercism Test Runner. + # + # 1. Exercism Test Runner is around 3 times faster than GitHub CI on Ubuntu. + # See: https://forum.exercism.org/t/test-tracks-for-the-20-seconds-limit-on-test-runners/10536/8 + # 2. Exercism Test Runner should complete in 20s and involves: + # - Starting Docker container (~1s) + # - Running the test suite + # - Processing the results (~1s) + # + # This gives 18s maximum for the test suite to run in the Exercism Test Runner. + # Hence the test suite should complete in less than 18s x 3 = 54s in GitHub CI on Ubuntu. + timeout 54s "${PHPUNIT_BIN}" --no-configuration "${outdir}/${test_file}" } function installed { diff --git a/exercises/practice/robot-name/RobotNameTest.php b/exercises/practice/robot-name/RobotNameTest.php index ae360996..c30071b9 100644 --- a/exercises/practice/robot-name/RobotNameTest.php +++ b/exercises/practice/robot-name/RobotNameTest.php @@ -73,18 +73,34 @@ public function testResetName(): void $this->assertMatchesRegularExpression('/\w{2}\d{3}/', $name2); } + /** + * PHPUnit ^10.5 has an issue with + * $this->assertArrayNotHasKey($name, $names, sprintf... + * that leads to test timeouts. This is fixed in PHPUnit ^11. + * Revert workaround + * $this->assertFalse(isset($names[$name]), sprintf... + * when upgrading. + */ public function testNameArentRecycled(): void { $names = []; for ($i = 0; $i < 10000; $i++) { $name = $this->robot->getName(); - $this->assertArrayNotHasKey($name, $names, sprintf('Name %s reissued after Reset.', $name)); + $this->assertFalse(isset($names[$name]), sprintf('Name %s reissued after Reset.', $name)); $names[$name] = true; $this->robot->reset(); } } + /** + * PHPUnit ^10.5 has an issue with + * $this->assertArrayNotHasKey($name, $names, sprintf... + * that leads to test timeouts. This is fixed in PHPUnit ^11. + * Revert workaround + * $this->assertFalse(isset($names[$name]), sprintf... + * when upgrading. + */ // This test is optional. public function testNameUniquenessManyRobots(): void { @@ -92,7 +108,7 @@ public function testNameUniquenessManyRobots(): void for ($i = 0; $i < 10000; $i++) { $name = (new Robot())->getName(); - $this->assertArrayNotHasKey($name, $names, sprintf('Name %s reissued after %d robots', $name, $i)); + $this->assertFalse(isset($names[$name]), sprintf('Name %s reissued after %d robots', $name, $i)); $names[$name] = true; } }