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()))))))' ) ); } }