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