xref: /webtrees/tests/app/Census/CensusColumnMonthIfBornWithinYearTest.php (revision 873953697c930fadbf3243d2b8c0029fd684da0e)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2018 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 <http://www.gnu.org/licenses/>.
16 */
17namespace Fisharebest\Webtrees\Census;
18
19use Fisharebest\Webtrees\Date;
20use Mockery;
21
22/**
23 * Test harness for the class CensusColumnMonthIfBornWithinYear
24 */
25class CensusColumnMonthIfBornWithinYearTest extends \PHPUnit\Framework\TestCase
26{
27    /**
28     * Delete mock objects
29     */
30    public function tearDown()
31    {
32        Mockery::close();
33    }
34
35    /**
36     * @covers \Fisharebest\Webtrees\Census\CensusColumnMonthIfBornWithinYear
37     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumn
38     */
39    public function testBornWithinYear()
40    {
41        $individual = Mockery::mock('Fisharebest\Webtrees\Individual');
42        $individual->shouldReceive('getBirthDate')->andReturn(new Date('01 JAN 1860'));
43
44        $census = Mockery::mock('Fisharebest\Webtrees\Census\CensusInterface');
45        $census->shouldReceive('censusDate')->andReturn('01 JUN 1860');
46
47        $column = new CensusColumnMonthIfBornWithinYear($census, '', '');
48
49        $this->assertSame('Jan', $column->generate($individual, $individual));
50    }
51
52    /**
53     * @covers \Fisharebest\Webtrees\Census\CensusColumnMonthIfBornWithinYear
54     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumn
55     */
56    public function testBornOverYearBeforeTheCensus()
57    {
58        $individual = Mockery::mock('Fisharebest\Webtrees\Individual');
59        $individual->shouldReceive('getBirthDate')->andReturn(new Date('01 JAN 1859'));
60
61        $census = Mockery::mock('Fisharebest\Webtrees\Census\CensusInterface');
62        $census->shouldReceive('censusDate')->andReturn('01 JUN 1860');
63
64        $column = new CensusColumnMonthIfBornWithinYear($census, '', '');
65
66        $this->assertSame('', $column->generate($individual, $individual));
67    }
68
69    /**
70     * @covers \Fisharebest\Webtrees\Census\CensusColumnMonthIfBornWithinYear
71     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumn
72     */
73    public function testBornAfterTheCensus()
74    {
75        $individual = Mockery::mock('Fisharebest\Webtrees\Individual');
76        $individual->shouldReceive('getBirthDate')->andReturn(new Date('02 JUN 1860'));
77
78        $census = Mockery::mock('Fisharebest\Webtrees\Census\CensusInterface');
79        $census->shouldReceive('censusDate')->andReturn('01 JUN 1860');
80
81
82        $column = new CensusColumnMonthIfBornWithinYear($census, '', '');
83
84        $this->assertSame('', $column->generate($individual, $individual));
85    }
86
87
88    /**
89     * @covers \Fisharebest\Webtrees\Census\CensusColumnMonthIfBornWithinYear
90     * @covers \Fisharebest\Webtrees\Census\AbstractCensusColumn
91     */
92    public function testNoBirth()
93    {
94        $individual = Mockery::mock('Fisharebest\Webtrees\Individual');
95        $individual->shouldReceive('getBirthDate')->andReturn(new Date(''));
96
97        $census = Mockery::mock('Fisharebest\Webtrees\Census\CensusInterface');
98        $census->shouldReceive('censusDate')->andReturn('01 JUN 1860');
99
100        $column = new CensusColumnMonthIfBornWithinYear($census, '', '');
101
102        $this->assertSame('', $column->generate($individual, $individual));
103    }
104}
105