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; 23 24/** 25 * Test harness for the class CensusOfUnitedStates1820 26 */ 27class CensusOfUnitedStates1820Test extends TestCase 28{ 29 /** 30 * Test the census place and date 31 * 32 * @covers \Fisharebest\Webtrees\Census\CensusOfUnitedStates1820 33 * 34 * @return void 35 */ 36 public function testPlaceAndDate(): void 37 { 38 $census = new CensusOfUnitedStates1820(); 39 40 self::assertSame('United States', $census->censusPlace()); 41 self::assertSame('07 AUG 1820', $census->censusDate()); 42 } 43 44 /** 45 * Test the census columns 46 * 47 * @covers \Fisharebest\Webtrees\Census\CensusOfUnitedStates1820 48 * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumn 49 * 50 * @return void 51 */ 52 public function testColumns(): void 53 { 54 $census = new CensusOfUnitedStates1820(); 55 $columns = $census->columns(); 56 57 self::assertCount(32, $columns); 58 self::assertInstanceOf(CensusColumnFullName::class, $columns[0]); 59 self::assertInstanceOf(CensusColumnNull::class, $columns[1]); 60 self::assertInstanceOf(CensusColumnNull::class, $columns[2]); 61 self::assertInstanceOf(CensusColumnNull::class, $columns[3]); 62 self::assertInstanceOf(CensusColumnNull::class, $columns[4]); 63 self::assertInstanceOf(CensusColumnNull::class, $columns[5]); 64 self::assertInstanceOf(CensusColumnNull::class, $columns[6]); 65 self::assertInstanceOf(CensusColumnNull::class, $columns[7]); 66 self::assertInstanceOf(CensusColumnNull::class, $columns[8]); 67 self::assertInstanceOf(CensusColumnNull::class, $columns[9]); 68 self::assertInstanceOf(CensusColumnNull::class, $columns[10]); 69 self::assertInstanceOf(CensusColumnNull::class, $columns[11]); 70 self::assertInstanceOf(CensusColumnNull::class, $columns[12]); 71 self::assertInstanceOf(CensusColumnNull::class, $columns[13]); 72 self::assertInstanceOf(CensusColumnNull::class, $columns[14]); 73 self::assertInstanceOf(CensusColumnNull::class, $columns[15]); 74 self::assertInstanceOf(CensusColumnNull::class, $columns[16]); 75 self::assertInstanceOf(CensusColumnNull::class, $columns[17]); 76 self::assertInstanceOf(CensusColumnNull::class, $columns[18]); 77 self::assertInstanceOf(CensusColumnNull::class, $columns[19]); 78 self::assertInstanceOf(CensusColumnNull::class, $columns[20]); 79 self::assertInstanceOf(CensusColumnNull::class, $columns[21]); 80 self::assertInstanceOf(CensusColumnNull::class, $columns[22]); 81 self::assertInstanceOf(CensusColumnNull::class, $columns[23]); 82 self::assertInstanceOf(CensusColumnNull::class, $columns[24]); 83 self::assertInstanceOf(CensusColumnNull::class, $columns[25]); 84 self::assertInstanceOf(CensusColumnNull::class, $columns[26]); 85 self::assertInstanceOf(CensusColumnNull::class, $columns[27]); 86 self::assertInstanceOf(CensusColumnNull::class, $columns[28]); 87 self::assertInstanceOf(CensusColumnNull::class, $columns[29]); 88 self::assertInstanceOf(CensusColumnNull::class, $columns[30]); 89 self::assertInstanceOf(CensusColumnNull::class, $columns[31]); 90 91 self::assertSame('Name', $columns[0]->abbreviation()); 92 self::assertSame('M0-10', $columns[1]->abbreviation()); 93 self::assertSame('M10-16', $columns[2]->abbreviation()); 94 self::assertSame('M16-18', $columns[3]->abbreviation()); 95 self::assertSame('M16-26', $columns[4]->abbreviation()); 96 self::assertSame('M26-45', $columns[5]->abbreviation()); 97 self::assertSame('M45+', $columns[6]->abbreviation()); 98 self::assertSame('F0-10', $columns[7]->abbreviation()); 99 self::assertSame('F10-16', $columns[8]->abbreviation()); 100 self::assertSame('F16-26', $columns[9]->abbreviation()); 101 self::assertSame('F26-45', $columns[10]->abbreviation()); 102 self::assertSame('F45+', $columns[11]->abbreviation()); 103 self::assertSame('FNR', $columns[12]->abbreviation()); 104 self::assertSame('AG', $columns[13]->abbreviation()); 105 self::assertSame('COM', $columns[14]->abbreviation()); 106 self::assertSame('MNF', $columns[15]->abbreviation()); 107 self::assertSame('M0', $columns[16]->abbreviation()); 108 self::assertSame('M14', $columns[17]->abbreviation()); 109 self::assertSame('M26', $columns[18]->abbreviation()); 110 self::assertSame('M45', $columns[19]->abbreviation()); 111 self::assertSame('F0', $columns[20]->abbreviation()); 112 self::assertSame('F14', $columns[21]->abbreviation()); 113 self::assertSame('F26', $columns[22]->abbreviation()); 114 self::assertSame('F45', $columns[23]->abbreviation()); 115 self::assertSame('M0', $columns[24]->abbreviation()); 116 self::assertSame('M14', $columns[25]->abbreviation()); 117 self::assertSame('M26', $columns[26]->abbreviation()); 118 self::assertSame('M45', $columns[27]->abbreviation()); 119 self::assertSame('F0', $columns[28]->abbreviation()); 120 self::assertSame('F14', $columns[29]->abbreviation()); 121 self::assertSame('F26', $columns[30]->abbreviation()); 122 self::assertSame('F45', $columns[31]->abbreviation()); 123 124 self::assertSame('Name of head of family', $columns[0]->title()); 125 self::assertSame('Free white males 0-10 years', $columns[1]->title()); 126 self::assertSame('Free white males 10-16 years', $columns[2]->title()); 127 self::assertSame('Free white males 16-18 years', $columns[3]->title()); 128 self::assertSame('Free white males 16-26 years', $columns[4]->title()); 129 self::assertSame('Free white males 26-45 years', $columns[5]->title()); 130 self::assertSame('Free white males 45+ years', $columns[6]->title()); 131 self::assertSame('Free white females 0-10 years', $columns[7]->title()); 132 self::assertSame('Free white females 10-16 years', $columns[8]->title()); 133 self::assertSame('Free white females 16-26 years', $columns[9]->title()); 134 self::assertSame('Free white females 26-45 years', $columns[10]->title()); 135 self::assertSame('Free white females 45+ years', $columns[11]->title()); 136 self::assertSame('Foreigners not naturalized', $columns[12]->title()); 137 self::assertSame('No. engaged in agriculture', $columns[13]->title()); 138 self::assertSame('No. engaged in commerce', $columns[14]->title()); 139 self::assertSame('No. engaged in manufactures', $columns[15]->title()); 140 self::assertSame('Slave males 0-14 years', $columns[16]->title()); 141 self::assertSame('Slave males 14-26 years', $columns[17]->title()); 142 self::assertSame('Slave males 26-45 years', $columns[18]->title()); 143 self::assertSame('Slave males 45+ years', $columns[19]->title()); 144 self::assertSame('Slave females 0-14 years', $columns[20]->title()); 145 self::assertSame('Slave females 14-26 years', $columns[21]->title()); 146 self::assertSame('Slave females 26-45 years', $columns[22]->title()); 147 self::assertSame('Slave females 45+ years', $columns[23]->title()); 148 self::assertSame('Free colored males 0-14 years', $columns[24]->title()); 149 self::assertSame('Free colored males 14-26 years', $columns[25]->title()); 150 self::assertSame('Free colored males 26-45 years', $columns[26]->title()); 151 self::assertSame('Free colored males 45+ years', $columns[27]->title()); 152 self::assertSame('Free colored females 0-14 years', $columns[28]->title()); 153 self::assertSame('Free colored females 14-26 years', $columns[29]->title()); 154 self::assertSame('Free colored females 26-45 years', $columns[30]->title()); 155 self::assertSame('Free colored females 45+ years', $columns[31]->title()); 156 } 157} 158