From cb1ab0ed181e528bdc6726a92b5ea78afdb54ef4 Mon Sep 17 00:00:00 2001 From: lubiana Date: Thu, 19 Dec 2024 00:35:23 +0100 Subject: [PATCH 1/2] improve unit tests --- tests/Controller/FoodOrderControllerTest.php | 39 ++++++++++++-------- 1 file changed, 23 insertions(+), 16 deletions(-) diff --git a/tests/Controller/FoodOrderControllerTest.php b/tests/Controller/FoodOrderControllerTest.php index a7c222e..1e46b47 100644 --- a/tests/Controller/FoodOrderControllerTest.php +++ b/tests/Controller/FoodOrderControllerTest.php @@ -137,10 +137,10 @@ final class FoodOrderControllerTest extends DbWebTest } /** - * @testWith [1, 0, 1] - * [2, 1, 1] - * [3, 1, 1] - * [4, 1, 0, 5] + * @testWith [1, 0, 2] + * [2, 1, 3] + * [3, 2, 4] + * [4, 3, 0, 5] */ public function testPaginatedFirstPage(int $page, int $prevPage, int $nextPage, int $items = 10): void { @@ -154,22 +154,27 @@ final class FoodOrderControllerTest extends DbWebTest $items, 'nobody' ); - $this->assertElementContainsCount( - $crawler, - 'a', - $nextPage, - 'next page' - ); - $this->assertElementContainsCount( - $crawler, - 'a', - $prevPage, - 'previous page' - ); + if ($prevPage > 0) { + if ($prevPage === 1) { + $prevPage = ''; + } else { + $prevPage = "/{$prevPage}"; + } + + $node = $crawler->filter('a')->reduce(fn(Crawler $node, $i): bool => $node->text() === 'previous page')->first(); + $target = $node->attr('href'); + $this->assertTrue(str_ends_with($target, $prevPage)); + } + if ($prevPage > 3) { + $node = $crawler->filter('a')->reduce(fn(Crawler $node, $i): bool => $node->text() === 'next page')->first(); + $target = $node->attr('href'); + $this->assertTrue(str_ends_with($target, "/{$nextPage}")); + } } public function testNew(): void { + $this->client->getCookieJar()->set(new \Symfony\Component\BrowserKit\Cookie('username', 'Testing-1')); $this->client->request('GET', sprintf('%snew', $this->path)); self::assertResponseStatusCodeSame(200); @@ -180,6 +185,8 @@ final class FoodOrderControllerTest extends DbWebTest self::assertResponseRedirects("{$this->path}list"); self::assertSame(1, $this->repository->count([])); + $order = $this->repository->findOneBy(['createdBy' => 'Testing-1']); + assert($order instanceof FoodOrder); } public function testOpen(): void -- 2.39.5 From 2d3100b5c944b865d54ad3563cf3b21ab553b39f Mon Sep 17 00:00:00 2001 From: Continuous Integration Date: Wed, 18 Dec 2024 23:38:27 +0000 Subject: [PATCH 2/2] Continuous Integration Fixes --- tests/Controller/FoodOrderControllerTest.php | 29 ++++++++++++-------- 1 file changed, 17 insertions(+), 12 deletions(-) diff --git a/tests/Controller/FoodOrderControllerTest.php b/tests/Controller/FoodOrderControllerTest.php index 1e46b47..3abd8a2 100644 --- a/tests/Controller/FoodOrderControllerTest.php +++ b/tests/Controller/FoodOrderControllerTest.php @@ -8,10 +8,13 @@ use App\Entity\MenuItem; use App\Entity\OrderItem; use App\Tests\DbWebTest; use Override; +use Symfony\Component\BrowserKit\Cookie; use Symfony\Component\DomCrawler\Crawler; +use function assert; use function range; use function sprintf; +use function str_ends_with; final class FoodOrderControllerTest extends DbWebTest { @@ -155,26 +158,26 @@ final class FoodOrderControllerTest extends DbWebTest 'nobody' ); if ($prevPage > 0) { - if ($prevPage === 1) { - $prevPage = ''; - } else { - $prevPage = "/{$prevPage}"; - } - - $node = $crawler->filter('a')->reduce(fn(Crawler $node, $i): bool => $node->text() === 'previous page')->first(); + $prevPage = $prevPage === 1 ? '' : "/{$prevPage}"; + $node = $crawler->filter('a') + ->reduce(static fn(Crawler $node, $i): bool => $node->text() === 'previous page') + ->first(); $target = $node->attr('href'); - $this->assertTrue(str_ends_with($target, $prevPage)); + $this->assertTrue(str_ends_with((string) $target, $prevPage)); } if ($prevPage > 3) { - $node = $crawler->filter('a')->reduce(fn(Crawler $node, $i): bool => $node->text() === 'next page')->first(); + $node = $crawler->filter('a') + ->reduce(static fn(Crawler $node, $i): bool => $node->text() === 'next page') + ->first(); $target = $node->attr('href'); - $this->assertTrue(str_ends_with($target, "/{$nextPage}")); + $this->assertTrue(str_ends_with((string) $target, "/{$nextPage}")); } } public function testNew(): void { - $this->client->getCookieJar()->set(new \Symfony\Component\BrowserKit\Cookie('username', 'Testing-1')); + $this->client->getCookieJar() + ->set(new Cookie('username', 'Testing-1')); $this->client->request('GET', sprintf('%snew', $this->path)); self::assertResponseStatusCodeSame(200); @@ -185,7 +188,9 @@ final class FoodOrderControllerTest extends DbWebTest self::assertResponseRedirects("{$this->path}list"); self::assertSame(1, $this->repository->count([])); - $order = $this->repository->findOneBy(['createdBy' => 'Testing-1']); + $order = $this->repository->findOneBy([ + 'createdBy' => 'Testing-1', + ]); assert($order instanceof FoodOrder); } -- 2.39.5