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 28#[CoversClass(CensusColumnAgeFemale5Years::class)] 29#[CoversClass(AbstractCensusColumn::class)] 30class CensusColumnAgeFemale5YearsTest extends TestCase 31{ 32 public function testMale(): void 33 { 34 $individual = $this->createMock(Individual::class); 35 $individual->method('sex')->willReturn('M'); 36 37 $census = $this->createMock(CensusInterface::class); 38 39 $column = new CensusColumnAgeFemale5Years($census, '', ''); 40 41 self::assertSame('', $column->generate($individual, $individual)); 42 } 43 44 public function testFemale(): void 45 { 46 $individual = $this->createMock(Individual::class); 47 $individual->method('sex')->willReturn('F'); 48 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 49 50 $census = $this->createMock(CensusInterface::class); 51 $census->method('censusDate')->willReturn('30 JUN 1830'); 52 53 $column = new CensusColumnAgeFemale5Years($census, '', ''); 54 55 self::assertSame('30', $column->generate($individual, $individual)); 56 } 57 58 public function testUnknownSex(): void 59 { 60 $individual = $this->createMock(Individual::class); 61 $individual->method('sex')->willReturn('U'); 62 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 63 64 $census = $this->createMock(CensusInterface::class); 65 $census->method('censusDate')->willReturn('30 JUN 1830'); 66 67 $column = new CensusColumnAgeFemale5Years($census, '', ''); 68 69 self::assertSame('30', $column->generate($individual, $individual)); 70 } 71 72 public function testLessThanOneYear(): void 73 { 74 $individual = $this->createMock(Individual::class); 75 $individual->method('sex')->willReturn('F'); 76 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 77 78 $census = $this->createMock(CensusInterface::class); 79 $census->method('censusDate')->willReturn('30 JUN 1800'); 80 81 $column = new CensusColumnAgeFemale5Years($census, '', ''); 82 83 self::assertSame('0', $column->generate($individual, $individual)); 84 } 85 86 public function testLessThanFifteenYears(): void 87 { 88 $individual = $this->createMock(Individual::class); 89 $individual->method('sex')->willReturn('F'); 90 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 91 92 $census = $this->createMock(CensusInterface::class); 93 $census->method('censusDate')->willReturn('30 JUN 1814'); 94 95 $column = new CensusColumnAgeFemale5Years($census, '', ''); 96 97 self::assertSame('14', $column->generate($individual, $individual)); 98 } 99 100 public function testRoundedDownToFiveYears(): void 101 { 102 $individual = $this->createMock(Individual::class); 103 $individual->method('sex')->willReturn('F'); 104 $individual->method('getEstimatedBirthDate')->willReturn(new Date('01 JAN 1800')); 105 106 $census = $this->createMock(CensusInterface::class); 107 $census->method('censusDate')->willReturn('30 JUN 1844'); 108 109 $column = new CensusColumnAgeFemale5Years($census, '', ''); 110 111 self::assertSame('40', $column->generate($individual, $individual)); 112 } 113} 114