From 24452ec4c0a236b3d6866404a7421017b3ae0b20 Mon Sep 17 00:00:00 2001 From: Caen De Silva Date: Tue, 13 Feb 2024 20:41:20 +0100 Subject: [PATCH] Refactor unit test to replace complex mock with inlined build loop We don't need a complex service mock when all we want to do is to run the build loop --- ...veLinksAcrossPagesRetainsIntegrityTest.php | 35 ++++--------------- 1 file changed, 6 insertions(+), 29 deletions(-) diff --git a/packages/framework/tests/Unit/RelativeLinksAcrossPagesRetainsIntegrityTest.php b/packages/framework/tests/Unit/RelativeLinksAcrossPagesRetainsIntegrityTest.php index 2c3562e142b..587857d2a8b 100644 --- a/packages/framework/tests/Unit/RelativeLinksAcrossPagesRetainsIntegrityTest.php +++ b/packages/framework/tests/Unit/RelativeLinksAcrossPagesRetainsIntegrityTest.php @@ -5,12 +5,10 @@ namespace Hyde\Framework\Testing\Unit; use Hyde\Facades\Filesystem; +use Hyde\Support\Models\Route; +use Hyde\Foundation\Facades\Routes; +use Hyde\Framework\Actions\StaticPageBuilder; use Hyde\Framework\Actions\CreatesNewMarkdownPostFile; -use Hyde\Framework\Services\BuildService; -use Illuminate\Console\OutputStyle; -use Mockery; -use Symfony\Component\Console\Formatter\OutputFormatterInterface; -use Symfony\Component\Console\Helper\ProgressBar; use function config; @@ -70,30 +68,9 @@ protected function assertSee(string $page, string|array $text): void public function testRelativeLinksAcrossPagesRetainsIntegrity() { - $service = new BuildService(Mockery::mock(OutputStyle::class, [ - 'getFormatter' => Mockery::mock(OutputFormatterInterface::class, [ - 'hasStyle' => false, - 'setStyle' => null, - ]), - 'createProgressBar' => new ProgressBar(Mockery::mock(OutputStyle::class, [ - 'isDecorated' => false, - 'getVerbosity' => 0, - 'write' => null, - 'getFormatter' => Mockery::mock(OutputFormatterInterface::class, [ - 'hasStyle' => false, - 'setStyle' => null, - 'isDecorated' => false, - 'setDecorated' => null, - 'format' => null, - ]), - ])), - 'writeln' => null, - 'newLine' => null, - 'write' => null, - ])); - - $service->transferMediaAssets(); - $service->compileStaticPages(); + Routes::getRoutes()->each(function (Route $route): void { + StaticPageBuilder::handle($route->getPage()); + }); $this->assertSee('root', [ '',