341 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			341 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?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()))))))'
 | |
|             )
 | |
|         );
 | |
|     }
 | |
| }
 |