xref: /webtrees/tests/app/Census/CensusColumnConditionEnglishTest.php (revision b6017f990d38d8c56e04c0096ce9a7e8745ad4ba)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2021 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\Date;
23use Fisharebest\Webtrees\Fact;
24use Fisharebest\Webtrees\Family;
25use Fisharebest\Webtrees\Individual;
26use Fisharebest\Webtrees\TestCase;
27use Illuminate\Support\Collection;
28
29/**
30 * Test harness for the class CensusColumnConditionEnglish
31 */
32class CensusColumnConditionEnglishTest extends TestCase
33{
34    /**
35     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
36     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
37     *
38     * @return void
39     */
40    public function testNoSpouseFamiliesMale(): void
41    {
42        $individual = self::createMock(Individual::class);
43        $individual->method('sex')->willReturn('M');
44        $individual->method('spouseFamilies')->willReturn(new Collection());
45        $individual->method('getEstimatedBirthDate')->willReturn(new Date('1800'));
46
47        $census = self::createMock(CensusInterface::class);
48        $census->method('censusDate')->willReturn('30 JUN 1830');
49
50        $column = new CensusColumnConditionEnglish($census, '', '');
51
52        self::assertSame('Unm', $column->generate($individual, $individual));
53    }
54
55    /**
56     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
57     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
58     *
59     * @return void
60     */
61    public function testNoSpouseFamiliesFemale(): void
62    {
63        $individual = self::createMock(Individual::class);
64        $individual->method('sex')->willReturn('F');
65        $individual->method('spouseFamilies')->willReturn(new Collection());
66        $individual->method('getEstimatedBirthDate')->willReturn(new Date('1800'));
67
68        $census = self::createMock(CensusInterface::class);
69        $census->method('censusDate')->willReturn('30 JUN 1830');
70
71        $column = new CensusColumnConditionEnglish($census, '', '');
72
73        self::assertSame('Unm', $column->generate($individual, $individual));
74    }
75
76    /**
77     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
78     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
79     *
80     * @return void
81     */
82    public function testNoFamilyFactsMale(): void
83    {
84        $family = self::createMock(Family::class);
85        $family->method('getMarriageDate')->willReturn(new Date(''));
86        $family->method('facts')->with(['MARR'])->willReturn(new Collection());
87
88        $individual = self::createMock(Individual::class);
89        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
90        $individual->method('getEstimatedBirthDate')->willReturn(new Date('1800'));
91        $individual->method('sex')->willReturn('M');
92
93        $census = self::createMock(CensusInterface::class);
94
95        $column = new CensusColumnConditionEnglish($census, '', '');
96        $census->method('censusDate')->willReturn('30 JUN 1830');
97
98        self::assertSame('Unm', $column->generate($individual, $individual));
99    }
100
101    /**
102     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
103     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
104     *
105     * @return void
106     */
107    public function testNoFamilyFactsFemale(): void
108    {
109        $family = self::createMock(Family::class);
110        $family->method('getMarriageDate')->willReturn(new Date(''));
111        $family->method('facts')->with(['MARR'])->willReturn(new Collection());
112
113        $individual = self::createMock(Individual::class);
114        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
115        $individual->method('getEstimatedBirthDate')->willReturn(new Date('1800'));
116        $individual->method('sex')->willReturn('F');
117
118        $census = self::createMock(CensusInterface::class);
119
120        $column = new CensusColumnConditionEnglish($census, '', '');
121        $census->method('censusDate')->willReturn('30 JUN 1830');
122
123        self::assertSame('Unm', $column->generate($individual, $individual));
124    }
125
126    /**
127     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
128     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
129     *
130     * @return void
131     */
132    public function testSpouseDeadMale(): void
133    {
134        $fact = self::createMock(Fact::class);
135
136        $spouse = self::createMock(Individual::class);
137        $spouse->method('getDeathDate')->willReturn(new Date('1820'));
138
139        $family = self::createMock(Family::class);
140        $family
141            ->expects(self::exactly(2))
142            ->method('facts')
143            ->withConsecutive(
144                [['MARR']],
145                [['DIV']]
146            )
147            ->willReturnOnConsecutiveCalls(
148                new Collection([$fact]),
149                new Collection()
150            );
151        $family->expects(self::once())->method('spouse')->willReturn($spouse);
152
153        $individual = self::createMock(Individual::class);
154        $individual->method('sex')->willReturn('M');
155        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
156
157        $census = self::createMock(CensusInterface::class);
158
159        $column = new CensusColumnConditionEnglish($census, '', '');
160        $census->method('censusDate')->willReturn('30 JUN 1830');
161
162        self::assertSame('Wid', $column->generate($individual, $individual));
163    }
164
165    /**
166     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
167     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
168     *
169     * @return void
170     */
171    public function testSpouseDeadFemale(): void
172    {
173        $fact = self::createMock(Fact::class);
174
175        $spouse = self::createMock(Individual::class);
176        $spouse->method('getDeathDate')->willReturn(new Date('1820'));
177
178        $family = self::createMock(Family::class);
179        $family
180            ->expects(self::exactly(2))
181            ->method('facts')
182            ->withConsecutive(
183                [['MARR']],
184                [['DIV']]
185            )
186            ->willReturnOnConsecutiveCalls(
187                new Collection([$fact]),
188                new Collection()
189            );
190        $family->expects(self::once())->method('spouse')->willReturn($spouse);
191
192        $individual = self::createMock(Individual::class);
193        $individual->method('sex')->willReturn('F');
194        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
195
196        $census = self::createMock(CensusInterface::class);
197
198        $column = new CensusColumnConditionEnglish($census, '', '');
199        $census->method('censusDate')->willReturn('30 JUN 1830');
200
201        self::assertSame('Wid', $column->generate($individual, $individual));
202    }
203
204    /**
205     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
206     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
207     *
208     * @return void
209     */
210    public function testNoFamilyUnmarriedMale(): void
211    {
212        $family = self::createMock(Family::class);
213        $family->method('getMarriageDate')->willReturn(new Date(''));
214        $family->method('facts')->with(['MARR'])->willReturn(new Collection());
215
216        $individual = self::createMock(Individual::class);
217        $individual->method('sex')->willReturn('M');
218        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
219        $individual->method('getEstimatedBirthDate')->willReturn(new Date('1800'));
220
221        $census = self::createMock(CensusInterface::class);
222        $census->method('censusDate')->willReturn('30 JUN 1830');
223
224        $column = new CensusColumnConditionEnglish($census, '', '');
225
226        self::assertSame('Unm', $column->generate($individual, $individual));
227    }
228
229    /**
230     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
231     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
232     *
233     * @return void
234     */
235    public function testNoFamilyUnmarriedFemale(): void
236    {
237        $family = self::createMock(Family::class);
238        $family->method('getMarriageDate')->willReturn(new Date(''));
239        $family->method('facts')->with(['MARR'])->willReturn(new Collection());
240
241        $individual = self::createMock(Individual::class);
242        $individual->method('sex')->willReturn('F');
243        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
244        $individual->method('getEstimatedBirthDate')->willReturn(new Date('1800'));
245
246        $census = self::createMock(CensusInterface::class);
247        $census->method('censusDate')->willReturn('30 JUN 1830');
248
249        $column = new CensusColumnConditionEnglish($census, '', '');
250
251        self::assertSame('Unm', $column->generate($individual, $individual));
252    }
253
254    /**
255     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
256     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
257     *
258     * @return void
259     */
260    public function testChildMale(): void
261    {
262        $family = self::createMock(Family::class);
263        $family->method('getMarriageDate')->willReturn(new Date(''));
264        $family->method('facts')->with(['MARR'])->willReturn(new Collection());
265
266        $individual = self::createMock(Individual::class);
267        $individual->method('sex')->willReturn('M');
268        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
269        $individual->method('getEstimatedBirthDate')->willReturn(new Date('1820'));
270
271        $census = self::createMock(CensusInterface::class);
272        $census->method('censusDate')->willReturn('30 JUN 1830');
273
274        $column = new CensusColumnConditionEnglish($census, '', '');
275
276        self::assertSame('', $column->generate($individual, $individual));
277    }
278
279    /**
280     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
281     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
282     *
283     * @return void
284     */
285    public function testChildFemale(): void
286    {
287        $family = self::createMock(Family::class);
288        $family->method('getMarriageDate')->willReturn(new Date(''));
289        $family->method('facts')->with(['MARR'])->willReturn(new Collection());
290
291        $individual = self::createMock(Individual::class);
292        $individual->method('sex')->willReturn('F');
293        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
294        $individual->method('getEstimatedBirthDate')->willReturn(new Date('1820'));
295
296        $census = self::createMock(CensusInterface::class);
297        $census->method('censusDate')->willReturn('30 JUN 1830');
298
299        $column = new CensusColumnConditionEnglish($census, '', '');
300
301        self::assertSame('', $column->generate($individual, $individual));
302    }
303
304    /**
305     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
306     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
307     *
308     * @return void
309     */
310    public function testDivorcedMale(): void
311    {
312        $fact = self::createMock(Fact::class);
313
314        $family = self::createMock(Family::class);
315        $family
316            ->expects(self::exactly(2))
317            ->method('facts')
318            ->withConsecutive(
319                [['MARR']],
320                [['DIV']]
321            )
322            ->willReturn(
323                new Collection([$fact]),
324                new Collection([$fact])
325            );
326
327        $individual = self::createMock(Individual::class);
328        $individual->method('sex')->willReturn('M');
329        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
330
331        $census = self::createMock(CensusInterface::class);
332
333        $column = new CensusColumnConditionEnglish($census, '', '');
334        $census->method('censusDate')->willReturn('30 JUN 1830');
335
336        self::assertSame('Div', $column->generate($individual, $individual));
337    }
338
339    /**
340     * @covers \Fisharebest\Webtrees\Census\CensusColumnConditionEnglish
341     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumnCondition
342     *
343     * @return void
344     */
345    public function testDivorcedFemale(): void
346    {
347        $fact = self::createMock(Fact::class);
348
349        $family = self::createMock(Family::class);
350        $family
351            ->expects(self::exactly(2))
352            ->method('facts')
353            ->withConsecutive(
354                [['MARR']],
355                [['DIV']]
356            )
357            ->willReturn(
358                new Collection([$fact]),
359                new Collection([$fact])
360            );
361
362        $individual = self::createMock(Individual::class);
363        $individual->method('sex')->willReturn('F');
364        $individual->method('spouseFamilies')->willReturn(new Collection([$family]));
365
366        $census = self::createMock(CensusInterface::class);
367
368        $column = new CensusColumnConditionEnglish($census, '', '');
369        $census->method('censusDate')->willReturn('30 JUN 1830');
370
371        self::assertSame('Div', $column->generate($individual, $individual));
372    }
373}
374