|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
declare( strict_types = 1 ); |
|
4
|
|
|
|
|
5
|
|
|
namespace Tests\DataValues\Geo\PackagePrivate; |
|
6
|
|
|
|
|
7
|
|
|
use DataValues\Geo\PackagePrivate\DmsPrecisionDetector; |
|
8
|
|
|
use DataValues\Geo\Parsers\DmsCoordinateParser; |
|
9
|
|
|
use PHPUnit\Framework\TestCase; |
|
10
|
|
|
|
|
11
|
|
|
/** |
|
12
|
|
|
* @covers \DataValues\Geo\PackagePrivate\DmsPrecisionDetector |
|
13
|
|
|
* @license GPL-2.0-or-later |
|
14
|
|
|
*/ |
|
15
|
|
|
class DmsPrecisionDetectorTest extends TestCase { |
|
16
|
|
|
|
|
17
|
|
|
/** |
|
18
|
|
|
* @dataProvider precisionDetectionProvider |
|
19
|
|
|
*/ |
|
20
|
|
|
public function testPrecisionDetection( string $coordinate, float $expectedPrecision ) { |
|
21
|
|
|
$latLong = ( new DmsCoordinateParser() )->parse( $coordinate ); |
|
22
|
|
|
|
|
23
|
|
|
$this->assertSame( |
|
24
|
|
|
$expectedPrecision, |
|
25
|
|
|
( new DmsPrecisionDetector() )->detectPrecision( $latLong )->toFloat() |
|
26
|
|
|
); |
|
27
|
|
|
} |
|
28
|
|
|
|
|
29
|
|
|
public function precisionDetectionProvider() { |
|
30
|
|
|
yield [ '1°3\'5" 2°4\'6"', 1 / 3600 ]; |
|
31
|
|
|
yield [ '1°3\'5" 2°0\'0"', 1 / 3600 ]; |
|
32
|
|
|
yield [ '1°0\'0" 2°4\'6"', 1 / 3600 ]; |
|
33
|
|
|
yield [ '1°3\'0" 2°4\'0"', 1 / 3600 ]; |
|
34
|
|
|
yield [ '1°3\'5.7" 2°4\'6.8"', 1 / 36000 ]; |
|
35
|
|
|
yield [ '1°3\'5.79" 2°4\'6.8"', 1 / 360000 ]; |
|
36
|
|
|
yield [ '1°3\'5.001" 2°4\'6.001"', 1 / 3600000 ]; |
|
37
|
|
|
yield [ '1°3\'5.0001" 2°4\'6.0001"', 1 / 36000000 ]; |
|
38
|
|
|
yield [ '1°3\'5.00001" 2°4\'6.00001"', 1 / 3600 ]; |
|
39
|
|
|
yield [ '1°3\'5.55555" 2°4\'6.55555"', 1 / 36000000 ]; |
|
40
|
|
|
|
|
41
|
|
|
yield [ '-1°3\'5" -2°4\'6"', 1 / 3600 ]; |
|
42
|
|
|
yield [ '-1°3\'5.00001" -2°4\'6.00001"', 1 / 3600 ]; |
|
43
|
|
|
yield [ '1°3\'5.55555" -2°4\'6.55555"', 1 / 36000000 ]; |
|
44
|
|
|
} |
|
45
|
|
|
|
|
46
|
|
|
} |
|
47
|
|
|
|