xref: /webtrees/tests/app/Census/CensusOfUnitedStates1820Test.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 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