. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Session; use Fisharebest\Webtrees\TestCase; use Fisharebest\Webtrees\Tree; use Fisharebest\Webtrees\Services\DataFixService; use Fisharebest\Webtrees\Services\TreeService; use Illuminate\Support\Collection; /** * Class FixDuplicateLinksTest. * * @covers \Fisharebest\Webtrees\Module\FixDuplicateLinks * @covers \Fisharebest\Webtrees\Module\ModuleDataFixTrait */ class FixDuplicateLinksTest extends TestCase { protected static $uses_database = true; /** * @var FixDuplicateLinks $fixDuplicateLinks */ protected $fixDuplicateLinks; /** * @var Tree $tree */ protected $tree; /** * @var bool $restore_session_user */ protected $restore_session_user = false; /** * {@inheritdoc} */ protected function setUp(): void { parent::setUp(); $tree_service = new TreeService(); $this->tree = $tree_service->create('name', 'title'); $this->fixDuplicateLinks = new FixDuplicateLinks(new DataFixService()); if (Auth::id() === null) { Session::put('wt_user', 0); $this->restore_session_user = true; } } /** * {@inheritdoc} */ protected function tearDown(): void { parent::tearDown(); if ($this->restore_session_user) { Session::forget('wt_user'); } unset($this->fixDuplicateLinks); unset($this->tree); } /** * Test the module returns a title and a description */ public function testModuleMetadata(): void { self::assertNotEmpty($this->fixDuplicateLinks->title()); self::assertNotEmpty($this->fixDuplicateLinks->description()); } /** * Test the trait's recordsToFix method */ public function testRecordsToFix(): void { $records = $this->fixDuplicateLinks->recordsToFix($this->tree, []); self::assertInstanceOf(Collection::class, $records); self::assertCount(1, $records); $records = $this->fixDuplicateLinks->recordsToFix($this->tree, ['start' => 'X1', 'end' => 'X9']); self::assertCount(1, $records); $records = $this->fixDuplicateLinks->recordsToFix($this->tree, ['start' => 'X2', 'end' => 'X9']); self::assertCount(0, $records); } /** * Test the doesRecordNeedUpdate method on a negative and positive test */ public function testDoesRecordNeedUpdate(): void { $family = $this->tree->createFamily("0 @@ FAM\n1 HUSB @X1@\n1 CHIL @X2@"); self::assertFalse($this->fixDuplicateLinks->doesRecordNeedUpdate($family, [])); $family->createFact("1 CHIL @X2@", true); self::assertTrue($this->fixDuplicateLinks->doesRecordNeedUpdate($family, [])); } /** * Test the preview of the update */ public function testPreviewUpdate(): void { $family = $this->tree->createFamily("0 @@ FAM\n1 HUSB @X1@\n1 CHIL @X2@\n1 CHIL @X2@"); self::assertStringContainsString( '1 CHIL @X2@', $this->fixDuplicateLinks->previewUpdate($family, []) ); } /** * Test the update of the record */ public function testUpdateRecord(): void { $family = $this->tree->createFamily("0 @@ FAM\n1 HUSB @X1@\n1 CHIL @X2@\n1 CHIL @X2@"); $this->fixDuplicateLinks->updateRecord($family, []); self::assertCount(1, $family->facts(['CHIL'])); } }