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(CensusOfUnitedStates1820::class)] 27#[CoversClass(AbstractCensusColumn::class)] 28class CensusOfUnitedStates1820Test extends TestCase 29{ 30 /** 31 * Test the census place and date 32 */ 33 public function testPlaceAndDate(): void 34 { 35 $census = new CensusOfUnitedStates1820(); 36 37 self::assertSame('United States', $census->censusPlace()); 38 self::assertSame('07 AUG 1820', $census->censusDate()); 39 } 40 41 /** 42 * Test the census columns 43 */ 44 public function testColumns(): void 45 { 46 $census = new CensusOfUnitedStates1820(); 47 $columns = $census->columns(); 48 49 self::assertCount(32, $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 83 self::assertSame('Name', $columns[0]->abbreviation()); 84 self::assertSame('M0-10', $columns[1]->abbreviation()); 85 self::assertSame('M10-16', $columns[2]->abbreviation()); 86 self::assertSame('M16-18', $columns[3]->abbreviation()); 87 self::assertSame('M16-26', $columns[4]->abbreviation()); 88 self::assertSame('M26-45', $columns[5]->abbreviation()); 89 self::assertSame('M45+', $columns[6]->abbreviation()); 90 self::assertSame('F0-10', $columns[7]->abbreviation()); 91 self::assertSame('F10-16', $columns[8]->abbreviation()); 92 self::assertSame('F16-26', $columns[9]->abbreviation()); 93 self::assertSame('F26-45', $columns[10]->abbreviation()); 94 self::assertSame('F45+', $columns[11]->abbreviation()); 95 self::assertSame('FNR', $columns[12]->abbreviation()); 96 self::assertSame('AG', $columns[13]->abbreviation()); 97 self::assertSame('COM', $columns[14]->abbreviation()); 98 self::assertSame('MNF', $columns[15]->abbreviation()); 99 self::assertSame('M0', $columns[16]->abbreviation()); 100 self::assertSame('M14', $columns[17]->abbreviation()); 101 self::assertSame('M26', $columns[18]->abbreviation()); 102 self::assertSame('M45', $columns[19]->abbreviation()); 103 self::assertSame('F0', $columns[20]->abbreviation()); 104 self::assertSame('F14', $columns[21]->abbreviation()); 105 self::assertSame('F26', $columns[22]->abbreviation()); 106 self::assertSame('F45', $columns[23]->abbreviation()); 107 self::assertSame('M0', $columns[24]->abbreviation()); 108 self::assertSame('M14', $columns[25]->abbreviation()); 109 self::assertSame('M26', $columns[26]->abbreviation()); 110 self::assertSame('M45', $columns[27]->abbreviation()); 111 self::assertSame('F0', $columns[28]->abbreviation()); 112 self::assertSame('F14', $columns[29]->abbreviation()); 113 self::assertSame('F26', $columns[30]->abbreviation()); 114 self::assertSame('F45', $columns[31]->abbreviation()); 115 116 self::assertSame('Name of head of family', $columns[0]->title()); 117 self::assertSame('Free white males 0-10 years', $columns[1]->title()); 118 self::assertSame('Free white males 10-16 years', $columns[2]->title()); 119 self::assertSame('Free white males 16-18 years', $columns[3]->title()); 120 self::assertSame('Free white males 16-26 years', $columns[4]->title()); 121 self::assertSame('Free white males 26-45 years', $columns[5]->title()); 122 self::assertSame('Free white males 45+ years', $columns[6]->title()); 123 self::assertSame('Free white females 0-10 years', $columns[7]->title()); 124 self::assertSame('Free white females 10-16 years', $columns[8]->title()); 125 self::assertSame('Free white females 16-26 years', $columns[9]->title()); 126 self::assertSame('Free white females 26-45 years', $columns[10]->title()); 127 self::assertSame('Free white females 45+ years', $columns[11]->title()); 128 self::assertSame('Foreigners not naturalized', $columns[12]->title()); 129 self::assertSame('No. engaged in agriculture', $columns[13]->title()); 130 self::assertSame('No. engaged in commerce', $columns[14]->title()); 131 self::assertSame('No. engaged in manufactures', $columns[15]->title()); 132 self::assertSame('Slave males 0-14 years', $columns[16]->title()); 133 self::assertSame('Slave males 14-26 years', $columns[17]->title()); 134 self::assertSame('Slave males 26-45 years', $columns[18]->title()); 135 self::assertSame('Slave males 45+ years', $columns[19]->title()); 136 self::assertSame('Slave females 0-14 years', $columns[20]->title()); 137 self::assertSame('Slave females 14-26 years', $columns[21]->title()); 138 self::assertSame('Slave females 26-45 years', $columns[22]->title()); 139 self::assertSame('Slave females 45+ years', $columns[23]->title()); 140 self::assertSame('Free colored males 0-14 years', $columns[24]->title()); 141 self::assertSame('Free colored males 14-26 years', $columns[25]->title()); 142 self::assertSame('Free colored males 26-45 years', $columns[26]->title()); 143 self::assertSame('Free colored males 45+ years', $columns[27]->title()); 144 self::assertSame('Free colored females 0-14 years', $columns[28]->title()); 145 self::assertSame('Free colored females 14-26 years', $columns[29]->title()); 146 self::assertSame('Free colored females 26-45 years', $columns[30]->title()); 147 self::assertSame('Free colored females 45+ years', $columns[31]->title()); 148 } 149} 150