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