. */ declare(strict_types=1); namespace Fisharebest\Webtrees\SurnameTradition; use Fisharebest\Webtrees\TestCase; /** * Test harness for the class DefaultSurnameTradition */ class DefaultSurnameTraditionTest extends TestCase { /** @var SurnameTraditionInterface */ private $surname_tradition; /** * Prepare the environment for these tests * * @return void */ protected function setUp(): void { parent::setUp(); $this->surname_tradition = new DefaultSurnameTradition(); } /** * Test whether married surnames are used * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testMarriedSurnames(): void { $this->assertFalse($this->surname_tradition->hasMarriedNames()); } /** * Test whether surnames are used * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testSurnames(): void { $this->assertTrue($this->surname_tradition->hasSurnames()); } /** * Test new son names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewSonNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newChildNames('John /White/', 'Mary /Black/', 'M') ); } /** * Test new daughter names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewDaughterNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newChildNames('John /White/', 'Mary /Black/', 'F') ); } /** * Test new child names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewChildNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newChildNames('John /White/', 'Mary /Black/', 'U') ); } /** * Test new father names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewFatherNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newParentNames('John /White/', 'M') ); } /** * Test new mother names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewMotherNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newParentNames('John /White/', 'F') ); } /** * Test new parent names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewParentNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newParentNames('John /White/', 'U') ); } /** * Test new husband names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewHusbandNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newSpouseNames('Mary /Black/', 'M') ); } /** * Test new wife names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewWifeNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newSpouseNames('John /White/', 'F') ); } /** * Test new spouse names * * @covers \Fisharebest\Webtrees\SurnameTradition\DefaultSurnameTradition * * @return void */ public function testNewSpouseNames(): void { $this->assertSame( ['NAME' => '//'], $this->surname_tradition->newSpouseNames('Chris /Green/', 'U') ); } }