1<?php 2 3/** 4 * webtrees: online genealogy 5 * Copyright (C) 2023 webtrees development team 6 * This program is free software: you can redistribute it and/or modify 7 * it under the terms of the GNU General Public License as published by 8 * the Free Software Foundation, either version 3 of the License, or 9 * (at your option) any later version. 10 * This program is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU General Public License for more details. 14 * You should have received a copy of the GNU General Public License 15 * along with this program. If not, see <https://www.gnu.org/licenses/>. 16 */ 17 18declare(strict_types=1); 19 20namespace Fisharebest\Webtrees\Census; 21 22use Fisharebest\Webtrees\Date; 23use Fisharebest\Webtrees\Individual; 24use Fisharebest\Webtrees\TestCase; 25use PHPUnit\Framework\Attributes\CoversClass; 26 27#[CoversClass(CensusColumnAgeFemale5Years::class)] 28#[CoversClass(AbstractCensusColumn::class)] 29class CensusColumnAgeFemale5YearsTest extends TestCase 30{ 31 public function testMale(): void 32 { 33 $individual = $this->createMock(Individual::class); 34 $individual->method('sex')->willReturn('M'); 35 36 $census = $this->createMock(CensusInterface::class); 37 38 $column = new CensusColumnAgeFemale5Years($census, '', ''); 39 40 self::assertSame('', $column->generate($individual, $individual)); 41 } 42 43 public function testFemale(): void 44 { 45 $individual = $this->createMock(Individual::class); 46 $individual->method('sex')->willReturn('F'); 47 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 48 49 $census = $this->createMock(CensusInterface::class); 50 $census->method('censusDate')->willReturn('30 JUN 1830'); 51 52 $column = new CensusColumnAgeFemale5Years($census, '', ''); 53 54 self::assertSame('30', $column->generate($individual, $individual)); 55 } 56 57 public function testUnknownSex(): void 58 { 59 $individual = $this->createMock(Individual::class); 60 $individual->method('sex')->willReturn('U'); 61 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 62 63 $census = $this->createMock(CensusInterface::class); 64 $census->method('censusDate')->willReturn('30 JUN 1830'); 65 66 $column = new CensusColumnAgeFemale5Years($census, '', ''); 67 68 self::assertSame('30', $column->generate($individual, $individual)); 69 } 70 71 public function testLessThanOneYear(): void 72 { 73 $individual = $this->createMock(Individual::class); 74 $individual->method('sex')->willReturn('F'); 75 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 76 77 $census = $this->createMock(CensusInterface::class); 78 $census->method('censusDate')->willReturn('30 JUN 1800'); 79 80 $column = new CensusColumnAgeFemale5Years($census, '', ''); 81 82 self::assertSame('0', $column->generate($individual, $individual)); 83 } 84 85 public function testLessThanFifteenYears(): void 86 { 87 $individual = $this->createMock(Individual::class); 88 $individual->method('sex')->willReturn('F'); 89 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 90 91 $census = $this->createMock(CensusInterface::class); 92 $census->method('censusDate')->willReturn('30 JUN 1814'); 93 94 $column = new CensusColumnAgeFemale5Years($census, '', ''); 95 96 self::assertSame('14', $column->generate($individual, $individual)); 97 } 98 99 public function testRoundedDownToFiveYears(): void 100 { 101 $individual = $this->createMock(Individual::class); 102 $individual->method('sex')->willReturn('F'); 103 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 104 105 $census = $this->createMock(CensusInterface::class); 106 $census->method('censusDate')->willReturn('30 JUN 1844'); 107 108 $column = new CensusColumnAgeFemale5Years($census, '', ''); 109 110 self::assertSame('40', $column->generate($individual, $individual)); 111 } 112} 113