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