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