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\TestCase; 23use PHPUnit\Framework\Attributes\CoversClass; 24 25 26#[CoversClass(CensusOfUnitedStates1840::class)] 27#[CoversClass(AbstractCensusColumn::class)] 28class CensusOfUnitedStates1840Test extends TestCase 29{ 30 /** 31 * Test the census place and date 32 */ 33 public function testPlaceAndDate(): void 34 { 35 $census = new CensusOfUnitedStates1840(); 36 37 self::assertSame('United States', $census->censusPlace()); 38 self::assertSame('01 JUN 1840', $census->censusDate()); 39 } 40 41 /** 42 * Test the census columns 43 */ 44 public function testColumns(): void 45 { 46 $census = new CensusOfUnitedStates1840(); 47 $columns = $census->columns(); 48 49 self::assertCount(39, $columns); 50 self::assertInstanceOf(CensusColumnFullName::class, $columns[0]); 51 self::assertInstanceOf(CensusColumnNull::class, $columns[1]); 52 self::assertInstanceOf(CensusColumnNull::class, $columns[2]); 53 self::assertInstanceOf(CensusColumnNull::class, $columns[3]); 54 self::assertInstanceOf(CensusColumnNull::class, $columns[4]); 55 self::assertInstanceOf(CensusColumnNull::class, $columns[5]); 56 self::assertInstanceOf(CensusColumnNull::class, $columns[6]); 57 self::assertInstanceOf(CensusColumnNull::class, $columns[7]); 58 self::assertInstanceOf(CensusColumnNull::class, $columns[8]); 59 self::assertInstanceOf(CensusColumnNull::class, $columns[9]); 60 self::assertInstanceOf(CensusColumnNull::class, $columns[10]); 61 self::assertInstanceOf(CensusColumnNull::class, $columns[11]); 62 self::assertInstanceOf(CensusColumnNull::class, $columns[12]); 63 self::assertInstanceOf(CensusColumnNull::class, $columns[13]); 64 self::assertInstanceOf(CensusColumnNull::class, $columns[14]); 65 self::assertInstanceOf(CensusColumnNull::class, $columns[15]); 66 self::assertInstanceOf(CensusColumnNull::class, $columns[16]); 67 self::assertInstanceOf(CensusColumnNull::class, $columns[17]); 68 self::assertInstanceOf(CensusColumnNull::class, $columns[18]); 69 self::assertInstanceOf(CensusColumnNull::class, $columns[19]); 70 self::assertInstanceOf(CensusColumnNull::class, $columns[20]); 71 self::assertInstanceOf(CensusColumnNull::class, $columns[21]); 72 self::assertInstanceOf(CensusColumnNull::class, $columns[22]); 73 self::assertInstanceOf(CensusColumnNull::class, $columns[23]); 74 self::assertInstanceOf(CensusColumnNull::class, $columns[24]); 75 self::assertInstanceOf(CensusColumnNull::class, $columns[25]); 76 self::assertInstanceOf(CensusColumnNull::class, $columns[26]); 77 self::assertInstanceOf(CensusColumnNull::class, $columns[27]); 78 self::assertInstanceOf(CensusColumnNull::class, $columns[28]); 79 self::assertInstanceOf(CensusColumnNull::class, $columns[29]); 80 self::assertInstanceOf(CensusColumnNull::class, $columns[30]); 81 self::assertInstanceOf(CensusColumnNull::class, $columns[31]); 82 self::assertInstanceOf(CensusColumnNull::class, $columns[32]); 83 self::assertInstanceOf(CensusColumnNull::class, $columns[33]); 84 self::assertInstanceOf(CensusColumnNull::class, $columns[34]); 85 self::assertInstanceOf(CensusColumnNull::class, $columns[35]); 86 self::assertInstanceOf(CensusColumnNull::class, $columns[36]); 87 self::assertInstanceOf(CensusColumnNull::class, $columns[37]); 88 self::assertInstanceOf(CensusColumnNull::class, $columns[38]); 89 90 self::assertSame('Name', $columns[0]->abbreviation()); 91 self::assertSame('M0', $columns[1]->abbreviation()); 92 self::assertSame('M5', $columns[2]->abbreviation()); 93 self::assertSame('M10', $columns[3]->abbreviation()); 94 self::assertSame('M15', $columns[4]->abbreviation()); 95 self::assertSame('M20', $columns[5]->abbreviation()); 96 self::assertSame('M30', $columns[6]->abbreviation()); 97 self::assertSame('M40', $columns[7]->abbreviation()); 98 self::assertSame('M50', $columns[8]->abbreviation()); 99 self::assertSame('M60', $columns[9]->abbreviation()); 100 self::assertSame('M70', $columns[10]->abbreviation()); 101 self::assertSame('M80', $columns[11]->abbreviation()); 102 self::assertSame('M90', $columns[12]->abbreviation()); 103 self::assertSame('M100', $columns[13]->abbreviation()); 104 self::assertSame('F0', $columns[14]->abbreviation()); 105 self::assertSame('F5', $columns[15]->abbreviation()); 106 self::assertSame('F10', $columns[16]->abbreviation()); 107 self::assertSame('F15', $columns[17]->abbreviation()); 108 self::assertSame('F20', $columns[18]->abbreviation()); 109 self::assertSame('F30', $columns[19]->abbreviation()); 110 self::assertSame('F40', $columns[20]->abbreviation()); 111 self::assertSame('F50', $columns[21]->abbreviation()); 112 self::assertSame('F60', $columns[22]->abbreviation()); 113 self::assertSame('F70', $columns[23]->abbreviation()); 114 self::assertSame('F80', $columns[24]->abbreviation()); 115 self::assertSame('F90', $columns[25]->abbreviation()); 116 self::assertSame('F100', $columns[26]->abbreviation()); 117 self::assertSame('M0', $columns[27]->abbreviation()); 118 self::assertSame('M10', $columns[28]->abbreviation()); 119 self::assertSame('M24', $columns[29]->abbreviation()); 120 self::assertSame('M36', $columns[30]->abbreviation()); 121 self::assertSame('M55', $columns[31]->abbreviation()); 122 self::assertSame('M100', $columns[32]->abbreviation()); 123 self::assertSame('F0', $columns[33]->abbreviation()); 124 self::assertSame('F10', $columns[34]->abbreviation()); 125 self::assertSame('F24', $columns[35]->abbreviation()); 126 self::assertSame('F36', $columns[36]->abbreviation()); 127 self::assertSame('F55', $columns[37]->abbreviation()); 128 self::assertSame('F100', $columns[38]->abbreviation()); 129 130 self::assertSame('Name of head of family', $columns[0]->title()); 131 self::assertSame('Free white males 0-5 years', $columns[1]->title()); 132 self::assertSame('Free white males 5-10 years', $columns[2]->title()); 133 self::assertSame('Free white males 10-15 years', $columns[3]->title()); 134 self::assertSame('Free white males 15-20 years', $columns[4]->title()); 135 self::assertSame('Free white males 20-30 years', $columns[5]->title()); 136 self::assertSame('Free white males 30-40 years', $columns[6]->title()); 137 self::assertSame('Free white males 40-50 years', $columns[7]->title()); 138 self::assertSame('Free white males 50-60 years', $columns[8]->title()); 139 self::assertSame('Free white males 60-70 years', $columns[9]->title()); 140 self::assertSame('Free white males 70-80 years', $columns[10]->title()); 141 self::assertSame('Free white males 80-90 years', $columns[11]->title()); 142 self::assertSame('Free white males 90-100 years', $columns[12]->title()); 143 self::assertSame('Free white males 100+ years', $columns[13]->title()); 144 self::assertSame('Free white females 0-5 years', $columns[14]->title()); 145 self::assertSame('Free white females 5-10 years', $columns[15]->title()); 146 self::assertSame('Free white females 10-15 years', $columns[16]->title()); 147 self::assertSame('Free white females 15-20 years', $columns[17]->title()); 148 self::assertSame('Free white females 20-30 years', $columns[18]->title()); 149 self::assertSame('Free white females 30-40 years', $columns[19]->title()); 150 self::assertSame('Free white females 40-50 years', $columns[20]->title()); 151 self::assertSame('Free white females 50-60 years', $columns[21]->title()); 152 self::assertSame('Free white females 60-70 years', $columns[22]->title()); 153 self::assertSame('Free white females 70-80 years', $columns[23]->title()); 154 self::assertSame('Free white females 80-90 years', $columns[24]->title()); 155 self::assertSame('Free white females 90-100 years', $columns[25]->title()); 156 self::assertSame('Free white females 100+ years', $columns[26]->title()); 157 self::assertSame('Free colored males 0-10 years', $columns[27]->title()); 158 self::assertSame('Free colored males 10-24 years', $columns[28]->title()); 159 self::assertSame('Free colored males 24-36 years', $columns[29]->title()); 160 self::assertSame('Free colored males 36-55 years', $columns[30]->title()); 161 self::assertSame('Free colored males 55-100 years', $columns[31]->title()); 162 self::assertSame('Free colored males 100+ years', $columns[32]->title()); 163 self::assertSame('Free colored females 0-10 years', $columns[33]->title()); 164 self::assertSame('Free colored females 10-24 years', $columns[34]->title()); 165 self::assertSame('Free colored females 24-36 years', $columns[35]->title()); 166 self::assertSame('Free colored females 36-55 years', $columns[36]->title()); 167 self::assertSame('Free colored females 55-100 years', $columns[37]->title()); 168 self::assertSame('Free colored females 100+ years', $columns[38]->title()); 169 } 170} 171