Leitgedanken/#pma/test/classes/gis/GISGeometryTest.php
2022-11-21 09:47:28 +01:00

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