Initial commit
This commit is contained in:
		
							
								
								
									
										340
									
								
								#pma/test/classes/gis/GISGeometryTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										340
									
								
								#pma/test/classes/gis/GISGeometryTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,340 @@ | ||||
| <?php | ||||
| /* vim: set expandtab sw=4 ts=4 sts=4: */ | ||||
| /** | ||||
|  * Test for PMA\libraries\gis\GISGeometry | ||||
|  * | ||||
|  * @package PhpMyAdmin-test | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Tests for PMA\libraries\gis\GISGeometry class | ||||
|  * | ||||
|  * @package PhpMyAdmin-test | ||||
|  */ | ||||
| class GISGeometryTest extends PHPUnit_Framework_TestCase | ||||
| { | ||||
|     /** | ||||
|      * @access protected | ||||
|      */ | ||||
|     protected $object; | ||||
|  | ||||
|     /** | ||||
|      * Sets up the fixture, for example, opens a network connection. | ||||
|      * This method is called before a test is executed. | ||||
|      * | ||||
|      * @access protected | ||||
|      * @return void | ||||
|      */ | ||||
|     protected function setUp() | ||||
|     { | ||||
|         $this->object = $this->getMockForAbstractClass('PMA\libraries\gis\GISGeometry'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Tears down the fixture, for example, closes a network connection. | ||||
|      * This method is called after a test is executed. | ||||
|      * | ||||
|      * @access protected | ||||
|      * @return void | ||||
|      */ | ||||
|     protected function tearDown() | ||||
|     { | ||||
|         unset($this->object); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Call protected functions by making the visibility to public. | ||||
|      * | ||||
|      * @param string $name   method name | ||||
|      * @param array  $params parameters for the invocation | ||||
|      * | ||||
|      * @return the output from the protected method. | ||||
|      */ | ||||
|     private function _callProtectedFunction($name, $params) | ||||
|     { | ||||
|         $class = new ReflectionClass('PMA\libraries\gis\GISGeometry'); | ||||
|         $method = $class->getMethod($name); | ||||
|         $method->setAccessible(true); | ||||
|         return $method->invokeArgs($this->object, $params); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * tests setMinMax method | ||||
|      * | ||||
|      * @param string $point_set Point set | ||||
|      * @param array  $min_max   Existing min, max values | ||||
|      * @param array  $output    Expected output array | ||||
|      * | ||||
|      * @dataProvider providerForTestSetMinMax | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testSetMinMax($point_set, $min_max, $output) | ||||
|     { | ||||
|         $this->assertEquals( | ||||
|             $this->_callProtectedFunction( | ||||
|                 'setMinMax', | ||||
|                 array($point_set, $min_max) | ||||
|             ), | ||||
|             $output | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * data provider for testSetMinMax | ||||
|      * | ||||
|      * @return data for testSetMinMax | ||||
|      */ | ||||
|     public function providerForTestSetMinMax() | ||||
|     { | ||||
|         return array( | ||||
|             array( | ||||
|                 '12 35,48 75,69 23,25 45,14 53,35 78', | ||||
|                 array(), | ||||
|                 array( | ||||
|                     'minX' => 12, | ||||
|                     'maxX' => 69, | ||||
|                     'minY' => 23, | ||||
|                     'maxY' => 78 | ||||
|                 ) | ||||
|             ), | ||||
|             array( | ||||
|                 '12 35,48 75,69 23,25 45,14 53,35 78', | ||||
|                 array( | ||||
|                     'minX' => 2, | ||||
|                     'maxX' => 29, | ||||
|                     'minY' => 23, | ||||
|                     'maxY' => 128 | ||||
|                 ), | ||||
|                 array( | ||||
|                     'minX' => 2, | ||||
|                     'maxX' => 69, | ||||
|                     'minY' => 23, | ||||
|                     'maxY' => 128 | ||||
|                 ) | ||||
|             ) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * tests generateParams method | ||||
|      * | ||||
|      * @param string $value  Geometry data | ||||
|      * @param string $output Expected output | ||||
|      * | ||||
|      * @dataProvider providerForTestGenerateParams | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testGenerateParams($value, $output) | ||||
|     { | ||||
|         $this->assertEquals( | ||||
|             $this->_callProtectedFunction( | ||||
|                 'generateParams', | ||||
|                 array($value) | ||||
|             ), | ||||
|             $output | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * data provider for testGenerateParams | ||||
|      * | ||||
|      * @return data for testGenerateParams | ||||
|      */ | ||||
|     public function providerForTestGenerateParams() | ||||
|     { | ||||
|         return array( | ||||
|             array( | ||||
|                 "'MULTIPOINT(125 50,156 25,178 43,175 80)',125", | ||||
|                 array( | ||||
|                     'srid' => '125', | ||||
|                     'wkt'  => 'MULTIPOINT(125 50,156 25,178 43,175 80)', | ||||
|                 ), | ||||
|             ), | ||||
|             array( | ||||
|                 'MULTIPOINT(125 50,156 25,178 43,175 80)', | ||||
|                 array( | ||||
|                     'srid' => '0', | ||||
|                     'wkt'  => 'MULTIPOINT(125 50,156 25,178 43,175 80)', | ||||
|                 ), | ||||
|             ), | ||||
|             array( | ||||
|                 "foo", | ||||
|                 array( | ||||
|                     'srid' => '0', | ||||
|                     'wkt'  => '', | ||||
|                 ), | ||||
|             ), | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * tests extractPoints method | ||||
|      * | ||||
|      * @param string  $point_set  String of comma separated points | ||||
|      * @param array   $scale_data Data related to scaling | ||||
|      * @param boolean $linear     If true, as a 1D array, else as a 2D array | ||||
|      * @param array   $output     Expected output | ||||
|      * | ||||
|      * @dataProvider providerForTestExtractPoints | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testExtractPoints($point_set, $scale_data, $linear, $output) | ||||
|     { | ||||
|         $this->assertEquals( | ||||
|             $this->_callProtectedFunction( | ||||
|                 'extractPoints', | ||||
|                 array($point_set, $scale_data, $linear) | ||||
|             ), | ||||
|             $output | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * data provider for testExtractPoints | ||||
|      * | ||||
|      * @return data for testExtractPoints | ||||
|      */ | ||||
|     public function providerForTestExtractPoints() | ||||
|     { | ||||
|         return array( | ||||
|             // with no scale data | ||||
|             array( | ||||
|                 '12 35,48 75,69 23', | ||||
|                 null, | ||||
|                 false, | ||||
|                 array( | ||||
|                     0 => array(12, 35), | ||||
|                     1 => array(48, 75), | ||||
|                     2 => array(69, 23), | ||||
|                 ), | ||||
|             ), | ||||
|             // with scale data | ||||
|             array( | ||||
|                 '12 35,48 75,69 23', | ||||
|                 array( | ||||
|                     'x'      => 5, | ||||
|                     'y'      => 5, | ||||
|                     'scale'  => 2, | ||||
|                     'height' => 200, | ||||
|                 ), | ||||
|                 false, | ||||
|                 array( | ||||
|                     0 => array(14, 140), | ||||
|                     1 => array(86, 60), | ||||
|                     2 => array(128, 164), | ||||
|                 ), | ||||
|             ), | ||||
|             // linear output | ||||
|             array( | ||||
|                 '12 35,48 75,69 23', | ||||
|                 null, | ||||
|                 true, | ||||
|                 array(12, 35, 48, 75, 69, 23), | ||||
|             ), | ||||
|             // if a single part of a coordinate is empty | ||||
|             array( | ||||
|                 '12 35,48 75,69 ', | ||||
|                 null, | ||||
|                 false, | ||||
|                 array( | ||||
|                     0 => array(12, 35), | ||||
|                     1 => array(48, 75), | ||||
|                     2 => array('', ''), | ||||
|                 ), | ||||
|             ), | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * test case for getBoundsForOl() method | ||||
|      * | ||||
|      * @param string $srid       spatial reference ID | ||||
|      * @param array  $scale_data data related to scaling | ||||
|      * @param string $output     expected output | ||||
|      * | ||||
|      * @return void | ||||
|      * @dataProvider providerForTestGetBoundsForOl | ||||
|      */ | ||||
|     public function testGetBoundsForOl($srid, $scale_data, $output) | ||||
|     { | ||||
|         $this->assertEquals( | ||||
|             $this->_callProtectedFunction( | ||||
|                 'getBoundsForOl', | ||||
|                 array($srid, $scale_data) | ||||
|             ), | ||||
|             $output | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * data provider for testGetBoundsForOl() test case | ||||
|      * | ||||
|      * @return array test data for the testGetBoundsForOl() test case | ||||
|      */ | ||||
|     public function providerForTestGetBoundsForOl() | ||||
|     { | ||||
|         return array( | ||||
|             array( | ||||
|                 4326, | ||||
|                 array( | ||||
|                     'minX' => '0', | ||||
|                     'minY' => '0', | ||||
|                     'maxX' => '1', | ||||
|                     'maxY' => '1', | ||||
|                 ), | ||||
|                 'bound = new OpenLayers.Bounds(); ' | ||||
|                     . 'bound.extend(new OpenLayers.LonLat(0, 0).transform(' | ||||
|                     . 'new OpenLayers.Projection("EPSG:4326"), ' | ||||
|                     . 'map.getProjectionObject())); ' | ||||
|                     . 'bound.extend(new OpenLayers.LonLat(1, 1).transform(' | ||||
|                     . 'new OpenLayers.Projection("EPSG:4326"), ' | ||||
|                     . 'map.getProjectionObject()));' | ||||
|             ) | ||||
|  | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * test case for getPolygonArrayForOpenLayers() method | ||||
|      * | ||||
|      * @param array  $polygons x and y coordinate pairs for each polygon | ||||
|      * @param string $srid     spatial reference id | ||||
|      * @param string $output   expected output | ||||
|      * | ||||
|      * @return void | ||||
|      * @dataProvider providerForTestGetPolygonArrayForOpenLayers | ||||
|      */ | ||||
|     public function testGetPolygonArrayForOpenLayers($polygons, $srid, $output) | ||||
|     { | ||||
|         $this->assertEquals( | ||||
|             $this->_callProtectedFunction( | ||||
|                 'getPolygonArrayForOpenLayers', | ||||
|                 array($polygons, $srid) | ||||
|             ), | ||||
|             $output | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * data provider for testGetPolygonArrayForOpenLayers() test case | ||||
|      * | ||||
|      * @return array test data for testGetPolygonArrayForOpenLayers() test case | ||||
|      */ | ||||
|     public function providerForTestGetPolygonArrayForOpenLayers() | ||||
|     { | ||||
|         return array( | ||||
|             array( | ||||
|                 array('Triangle'), | ||||
|                 4326, | ||||
|                 'new Array(' | ||||
|                     . 'new OpenLayers.Geometry.Polygon(' | ||||
|                     . 'new Array(' | ||||
|                     . 'new OpenLayers.Geometry.LinearRing(' | ||||
|                     . 'new Array(' | ||||
|                     . '(new OpenLayers.Geometry.Point(,)).transform(' | ||||
|                     . 'new OpenLayers.Projection("EPSG:4326"), ' | ||||
|                     . 'map.getProjectionObject()))))))' | ||||
|             ) | ||||
|         ); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user