summaryrefslogtreecommitdiff
path: root/www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/DataValues/Time/JulianDayTest.php
blob: 1a7223295f84b65f35f5ae5bba56434be245c0d1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
<?php

namespace SMW\Tests\DataValues\Time;

use SMW\DataValues\Time\JulianDay;

/**
 * @covers \SMW\DataValues\Time\JulianDay
 * @group semantic-mediawiki
 *
 * @license GNU GPL v2+
 * @since 2.4
 *
 * @author mwjames
 */
class JulianDayTest extends \PHPUnit_Framework_TestCase {

	/**
	 * @dataProvider valueProvider
	 */
	public function testConvert( $calendarModel, $seralization, $jdValue ) {

		list( $year, $month, $day, $hour, $minute, $second ) = explode( '/', $seralization );

		$this->assertEquals(
			$jdValue,
			JulianDay::getJD( $calendarModel, $year, $month, $day, $hour, $minute, $second )
		);
	}

	public function testGetJD_Issue2454() {

		$offset = -4 / 24;

		$this->assertSame(
			2457869.3333333,
			JulianDay::getJD( 1, 2017, 4, 25, 20, 0, 0 )
		);

		$this->assertNotSame(
			2457869.5,
			JulianDay::getJD( 1, 2017, 4, 25, 20, 0, 0 ) - $offset // returns 2457869.4999999665
		);

		$this->assertSame(
			2457869.5,
			JulianDay::format( JulianDay::getJD( 1, 2017, 4, 25, 20, 0, 0 ) - $offset )
		);
	}

	public function valueProvider() {

		$provider[] = [
			JulianDay::CM_JULIAN,
			'1352/01/01/0/0/0',
			'2214875.500000'
		];

		$provider[] = [
			JulianDay::CM_GREGORIAN,
			'2100/10/04/0/0/0',
			'2488345.500000'
		];

		$provider[] = [
			JulianDay::CM_GREGORIAN,
			'2100/10/04/0/0/0',
			'2488345.500000'
		];

		$provider[] = [
			JulianDay::CM_JULIAN,
			'1582/10/04/0/0/0',
			'2299159.500000'
		];

		$provider[] = [
			JulianDay::CM_GREGORIAN,
			'1582/10/15/0/0/0',
			'2299160.5'
		];

		$provider[] = [
			JulianDay::CM_JULIAN,
			'-900/10/4/0/0/0',
			'1392974.500000'
		];

		$provider[] = [
			JulianDay::CM_JULIAN,
			'-4713/01/02/0/0/0',
			'0.5'
		];

		$provider[] = [
			JulianDay::CM_JULIAN,
			'-4713/01/02/12/0/0/0',
			'1'
		];

		$provider[] = [
			JulianDay::CM_JULIAN,
			'-9000/10/4/0/0/0',
			'-1565550.5'
		];

		$provider[] = [
			JulianDay::CM_GREGORIAN,
			'2100/10/4/13/55/55',
			'2488346.0804977'
		];

		$provider[] = [
			JulianDay::CM_GREGORIAN,
			'2100/10/4/13/55/55',
			2488346.0804977
		];

		return $provider;
	}

}