From 7d550fa9dab038a4e02d978f5e87486a70c37970 Mon Sep 17 00:00:00 2001 From: Marien Fressinaud Date: Wed, 2 Oct 2024 15:10:54 +0200 Subject: [PATCH] dev: Mock all the requests in LinksSyncTest --- tests/jobs/scheduled/LinksSyncTest.php | 70 ++++++++------------------ 1 file changed, 22 insertions(+), 48 deletions(-) diff --git a/tests/jobs/scheduled/LinksSyncTest.php b/tests/jobs/scheduled/LinksSyncTest.php index 5229f284..e27b9f8f 100644 --- a/tests/jobs/scheduled/LinksSyncTest.php +++ b/tests/jobs/scheduled/LinksSyncTest.php @@ -100,9 +100,11 @@ public function testPerform(): void public function testPerformLogsFetch(): void { + $url = 'https://flus.fr/carnet/'; + $this->mockHttpWithFixture($url, 'responses/flus.fr_carnet_index.html'); $link = LinkFactory::create([ - 'url' => 'https://github.com/flusio/Flus', - 'title' => 'https://github.com/flusio/Flus', + 'url' => $url, + 'title' => $url, 'to_be_fetched' => true, 'fetched_at' => null, ]); @@ -115,8 +117,8 @@ public function testPerformLogsFetch(): void $this->assertGreaterThanOrEqual(1, models\FetchLog::count()); $fetch_log = models\FetchLog::take(); $this->assertNotNull($fetch_log); - $this->assertSame('https://github.com/flusio/Flus', $fetch_log->url); - $this->assertSame('github.com', $fetch_log->host); + $this->assertSame($url, $fetch_log->url); + $this->assertSame('flus.fr', $fetch_log->host); } public function testPerformSavesResponseInCache(): void @@ -142,7 +144,8 @@ public function testPerformSavesResponseInCache(): void public function testPerformUsesCache(): void { - $url = 'https://github.com/flusio/Flus'; + $url = 'https://flus.fr/carnet/'; + $this->mockHttpWithFixture($url, 'responses/flus.fr_carnet_index.html'); $link = LinkFactory::create([ 'url' => $url, 'title' => $url, @@ -176,11 +179,12 @@ public function testPerformUsesCache(): void public function testPerformSkipsFetchIfReachedRateLimit(): void { + $url = 'https://flus.fr/carnet/'; + $this->mockHttpWithFixture($url, 'responses/flus.fr_carnet_index.html'); + $host = 'flus.fr'; /** @var \DateTimeImmutable */ $now = $this->fake('dateTime'); $this->freeze($now); - $url = 'https://github.com/flusio/Flus'; - $host = 'github.com'; foreach (range(1, 25) as $i) { /** @var int */ $seconds = $this->fake('numberBetween', 0, 60); @@ -209,6 +213,8 @@ public function testPerformSkipsFetchIfReachedRateLimit(): void public function testPerformDoesNotFetchLinksIfFetchedAtIsWithinIntervalToWait(): void { + $url = 'https://flus.fr/carnet/'; + $this->mockHttpWithFixture($url, 'responses/flus.fr_carnet_index.html'); /** @var \DateTimeImmutable */ $now = $this->fake('dateTime'); $this->freeze($now); @@ -221,8 +227,8 @@ public function testPerformDoesNotFetchLinksIfFetchedAtIsWithinIntervalToWait(): $seconds = $this->fake('numberBetween', 0, $interval_to_wait); $fetched_at = \Minz\Time::ago($seconds, 'seconds'); $link = LinkFactory::create([ - 'url' => 'https://github.com/flusio/Flus', - 'title' => 'https://github.com/flusio/Flus', + 'url' => $url, + 'title' => $url, 'to_be_fetched' => true, 'fetched_at' => $fetched_at, 'fetched_count' => $fetched_count, @@ -232,20 +238,21 @@ public function testPerformDoesNotFetchLinksIfFetchedAtIsWithinIntervalToWait(): $links_fetcher_job->perform(); $link = $link->reload(); - $this->assertSame('https://github.com/flusio/Flus', $link->title); + $this->assertSame($url, $link->title); $this->assertEquals($fetched_at, $link->fetched_at); $this->assertSame($fetched_count, $link->fetched_count); } public function testPerformDoesNotFetchLinkIfLockedDuringLastHour(): void { + $url = 'https://flus.fr/carnet/'; + $this->mockHttpWithFixture($url, 'responses/flus.fr_carnet_index.html'); /** @var \DateTimeImmutable */ $now = $this->fake('dateTime'); $this->freeze($now); /** @var int */ $minutes = $this->fake('numberBetween', 0, 59); $locked_at = \Minz\Time::ago($minutes, 'minutes'); - $url = 'https://github.com/flusio/Flus'; $link = LinkFactory::create([ 'url' => $url, 'title' => $url, @@ -254,28 +261,11 @@ public function testPerformDoesNotFetchLinkIfLockedDuringLastHour(): void 'locked_at' => $locked_at, ]); $links_fetcher_job = new LinksSync(); - /** @var string */ - $title = $this->fake('sentence'); - $hash = \SpiderBits\Cache::hash($url); - $raw_response = << - - {$title} - - - TEXT; - /** @var string */ - $cache_path = \Minz\Configuration::$application['cache_path']; - $cache = new \SpiderBits\Cache($cache_path); - $cache->save($hash, $raw_response); $links_fetcher_job->perform(); $link = $link->reload(); - $this->assertNotSame($title, $link->title); + $this->assertSame($url, $link->title); $this->assertNull($link->fetched_at); $this->assertSame(0, $link->fetched_code); $this->assertSame(0, $link->fetched_count); @@ -284,13 +274,14 @@ public function testPerformDoesNotFetchLinkIfLockedDuringLastHour(): void public function testPerformFetchesLinkIfLockedAfterAnHour(): void { + $url = 'https://flus.fr/carnet/'; + $this->mockHttpWithFixture($url, 'responses/flus.fr_carnet_index.html'); /** @var \DateTimeImmutable */ $now = $this->fake('dateTime'); $this->freeze($now); /** @var int */ $minutes = $this->fake('numberBetween', 60, 1000); $locked_at = \Minz\Time::ago($minutes, 'minutes'); - $url = 'https://github.com/flusio/Flus'; $link = LinkFactory::create([ 'url' => $url, 'title' => $url, @@ -299,28 +290,11 @@ public function testPerformFetchesLinkIfLockedAfterAnHour(): void 'locked_at' => $locked_at, ]); $links_fetcher_job = new LinksSync(); - /** @var string */ - $title = $this->fake('sentence'); - $hash = \SpiderBits\Cache::hash($url); - $raw_response = << - - {$title} - - - TEXT; - /** @var string */ - $cache_path = \Minz\Configuration::$application['cache_path']; - $cache = new \SpiderBits\Cache($cache_path); - $cache->save($hash, $raw_response); $links_fetcher_job->perform(); $link = $link->reload(); - $this->assertSame($title, $link->title); + $this->assertSame('Carnet de Flus', $link->title); $this->assertNotNull($link->fetched_at); $this->assertSame(200, $link->fetched_code); $this->assertSame(1, $link->fetched_count);