object = GisMultiPolygon::singleton();
}
/**
* Tears down the fixture, for example, closes a network connection.
* This method is called after a test is executed.
*/
protected function tearDown(): void
{
parent::tearDown();
unset($this->object);
}
/**
* Provide some common data to data providers
*
* @return array common data for data providers
*/
private function getData(): array
{
return [
'MULTIPOLYGON' => [
'no_of_polygons' => 2,
0 => [
'no_of_lines' => 2,
0 => [
'no_of_points' => 5,
0 => [
'x' => 35,
'y' => 10,
],
1 => [
'x' => 10,
'y' => 20,
],
2 => [
'x' => 15,
'y' => 40,
],
3 => [
'x' => 45,
'y' => 45,
],
4 => [
'x' => 35,
'y' => 10,
],
],
1 => [
'no_of_points' => 4,
0 => [
'x' => 20,
'y' => 30,
],
1 => [
'x' => 35,
'y' => 32,
],
2 => [
'x' => 30,
'y' => 20,
],
3 => [
'x' => 20,
'y' => 30,
],
],
],
1 => [
'no_of_lines' => 1,
0 => [
'no_of_points' => 4,
0 => [
'x' => 123,
'y' => 0,
],
1 => [
'x' => 23,
'y' => 30,
],
2 => [
'x' => 17,
'y' => 63,
],
3 => [
'x' => 123,
'y' => 0,
],
],
],
],
];
}
/**
* data provider for testGenerateWkt
*
* @return array data for testGenerateWkt
*/
public function providerForTestGenerateWkt(): array
{
$temp = [
0 => $this->getData(),
];
$temp1 = $temp;
$temp1[0]['MULTIPOLYGON']['no_of_polygons'] = 0;
$temp2 = $temp;
$temp2[0]['MULTIPOLYGON'][1]['no_of_lines'] = 0;
$temp3 = $temp;
$temp3[0]['MULTIPOLYGON'][1][0]['no_of_points'] = 3;
return [
[
$temp,
0,
null,
'MULTIPOLYGON(((35 10,10 20,15 40,45 45,35 10)'
. ',(20 30,35 32,30 20,20 30)),((123 0,23 30,17 63,123 0)))',
],
// at lease one polygon should be there
[
$temp1,
0,
null,
'MULTIPOLYGON(((35 10,10 20,15 40,45 45,35 10),(20 30,35 32,30 20,20 30)))',
],
// a polygon should have at least one ring
[
$temp2,
0,
null,
'MULTIPOLYGON(((35 10,10 20,15 40,45 45,35 10)'
. ',(20 30,35 32,30 20,20 30)),((123 0,23 30,17 63,123 0)))',
],
// a ring should have at least four points
[
$temp3,
0,
'0',
'MULTIPOLYGON(((35 10,10 20,15 40,45 45,35 10)'
. ',(20 30,35 32,30 20,20 30)),((123 0,23 30,17 63,123 0)))',
],
];
}
/**
* data provider for testGenerateParams
*
* @return array data for testGenerateParams
*/
public function providerForTestGenerateParams(): array
{
$temp = $this->getData();
$temp1 = $this->getData();
$temp1['gis_type'] = 'MULTIPOLYGON';
return [
[
"'MULTIPOLYGON(((35 10,10 20,15 40,45 45,35 10),"
. "(20 30,35 32,30 20,20 30)),((123 0,23 30,17 63,123 0)))',124",
null,
[
'srid' => '124',
0 => $temp,
],
],
[
'MULTIPOLYGON(((35 10,10 20,15 40,45 45,35 10)'
. ',(20 30,35 32,30 20,20 30)),((123 0,23 30,17 63,123 0)))',
2,
[2 => $temp1],
],
];
}
/**
* test getShape method
*
* @param array $row_data array of GIS data
* @param string $shape expected shape in WKT
*
* @dataProvider providerForTestGetShape
*/
public function testGetShape(array $row_data, string $shape): void
{
$this->assertEquals($this->object->getShape($row_data), $shape);
}
/**
* data provider for testGetShape
*
* @return array data for testGetShape
*/
public function providerForTestGetShape(): array
{
return [
[
[
'parts' => [
0 => [
'points' => [
0 => [
'x' => 10,
'y' => 10,
],
1 => [
'x' => 10,
'y' => 40,
],
2 => [
'x' => 50,
'y' => 40,
],
3 => [
'x' => 50,
'y' => 10,
],
4 => [
'x' => 10,
'y' => 10,
],
],
],
1 => [
'points' => [
0 => [
'x' => 60,
'y' => 40,
],
1 => [
'x' => 75,
'y' => 65,
],
2 => [
'x' => 90,
'y' => 40,
],
3 => [
'x' => 60,
'y' => 40,
],
],
],
2 => [
'points' => [
0 => [
'x' => 20,
'y' => 20,
],
1 => [
'x' => 40,
'y' => 20,
],
2 => [
'x' => 25,
'y' => 30,
],
3 => [
'x' => 20,
'y' => 20,
],
],
],
],
],
'MULTIPOLYGON(((10 10,10 40,50 40,50 10,10 10),(20 20,40 20,25 30'
. ',20 20)),((60 40,75 65,90 40,60 40)))',
],
];
}
/**
* data provider for testScaleRow
*
* @return array data for testScaleRow
*/
public function providerForTestScaleRow(): array
{
return [
[
'MULTIPOLYGON(((136 40,147 83,16 75,136 40)),((105 0,56 20,78 73,105 0)))',
[
'minX' => 16,
'maxX' => 147,
'minY' => 0,
'maxY' => 83,
],
],
[
'MULTIPOLYGON(((35 10,10 20,15 40,45 45,35 10),(20 30,35 32,30 20'
. ',20 30)),((105 0,56 20,78 73,105 0)))',
[
'minX' => 10,
'maxX' => 105,
'minY' => 0,
'maxY' => 73,
],
],
];
}
/**
* @requires extension gd
*/
public function testPrepareRowAsPng(): void
{
$image = ImageWrapper::create(120, 150);
$this->assertNotNull($image);
$return = $this->object->prepareRowAsPng(
'MULTIPOLYGON(((136 40,147 83,16 75,136 40)),((105 0,56 20,78 73,105 0)))',
'image',
'#B02EE0',
['x' => 12, 'y' => 69, 'scale' => 2, 'height' => 150],
$image
);
$this->assertEquals(120, $return->width());
$this->assertEquals(150, $return->height());
}
/**
* test case for prepareRowAsPdf() method
*
* @param string $spatial GIS MULTIPOLYGON object
* @param string $label label for the GIS MULTIPOLYGON object
* @param string $fill_color color for the GIS MULTIPOLYGON object
* @param array $scale_data array containing data related to scaling
* @param TCPDF $pdf TCPDF instance
*
* @dataProvider providerForPrepareRowAsPdf
*/
public function testPrepareRowAsPdf(
string $spatial,
string $label,
string $fill_color,
array $scale_data,
TCPDF $pdf
): void {
$return = $this->object->prepareRowAsPdf($spatial, $label, $fill_color, $scale_data, $pdf);
$this->assertInstanceOf(TCPDF::class, $return);
}
/**
* data provider for testPrepareRowAsPdf() test case
*
* @return array test data for testPrepareRowAsPdf() test case
*/
public function providerForPrepareRowAsPdf(): array
{
return [
[
'MULTIPOLYGON(((136 40,147 83,16 75,136 40)),((105 0,56 20,78 73,105 0)))',
'pdf',
'#B02EE0',
[
'x' => 12,
'y' => 69,
'scale' => 2,
'height' => 150,
],
new TCPDF(),
],
];
}
/**
* test case for prepareRowAsSvg() method
*
* @param string $spatial GIS MULTIPOLYGON object
* @param string $label label for the GIS MULTIPOLYGON object
* @param string $fillColor color for the GIS MULTIPOLYGON object
* @param array $scaleData array containing data related to scaling
* @param string $output expected output
*
* @dataProvider providerForPrepareRowAsSvg
*/
public function testPrepareRowAsSvg(
string $spatial,
string $label,
string $fillColor,
array $scaleData,
string $output
): void {
$string = $this->object->prepareRowAsSvg($spatial, $label, $fillColor, $scaleData);
$this->assertEquals(1, preg_match($output, $string));
}
/**
* data provider for testPrepareRowAsSvg() test case
*
* @return array test data for testPrepareRowAsSvg() test case
*/
public function providerForPrepareRowAsSvg(): array
{
return [
[
'MULTIPOLYGON(((136 40,147 83,16 75,136 40)),((105 0,56 20,78 73,105 0)))',
'svg',
'#B02EE0',
[
'x' => 12,
'y' => 69,
'scale' => 2,
'height' => 150,
],
'/^()$/',
],
];
}
/**
* test case for prepareRowAsOl() method
*
* @param string $spatial GIS MULTIPOLYGON object
* @param int $srid spatial reference ID
* @param string $label label for the GIS MULTIPOLYGON object
* @param array $fill_color color for the GIS MULTIPOLYGON object
* @param array $scale_data array containing data related to scaling
* @param string $output expected output
*
* @dataProvider providerForPrepareRowAsOl
*/
public function testPrepareRowAsOl(
string $spatial,
int $srid,
string $label,
array $fill_color,
array $scale_data,
string $output
): void {
$this->assertEquals(
$output,
$this->object->prepareRowAsOl(
$spatial,
$srid,
$label,
$fill_color,
$scale_data
)
);
}
/**
* data provider for testPrepareRowAsOl() test case
*
* @return array test data for testPrepareRowAsOl() test case
*/
public function providerForPrepareRowAsOl(): array
{
return [
[
'MULTIPOLYGON(((136 40,147 83,16 75,136 40)),((105 0,56 20,78 73,105 0)))',
4326,
'Ol',
[176, 46, 224],
[
'minX' => '0',
'minY' => '0',
'maxX' => '1',
'maxY' => '1',
],
'var style = new ol.style.Style({fill: new ol.style.Fill({"color":[176,46,224,0.8]}'
. '),stroke: new ol.style.Stroke({"color":[0,0,0],"width":0.5}),text: new ol.style.'
. 'Text({"text":"Ol"})});var minLoc = [0, 0];var maxLoc = [1, 1];var ext = ol.exten'
. 't.boundingExtent([minLoc, maxLoc]);ext = ol.proj.transformExtent(ext, ol.proj.ge'
. 't("EPSG:4326"), ol.proj.get(\'EPSG:3857\'));map.getView().fit(ext, map.getSize()'
. ');var polygonArray = [];var arr = [];var lineArr = [];var line = new ol.geom.Lin'
. 'earRing(new Array((new ol.geom.Point([136,40]).transform(ol.proj.get("EPSG:4326"'
. '), ol.proj.get(\'EPSG:3857\'))).getCoordinates(), (new ol.geom.Point([147,83]).t'
. 'ransform(ol.proj.get("EPSG:4326"), ol.proj.get(\'EPSG:3857\'))).getCoordinates()'
. ', (new ol.geom.Point([16,75]).transform(ol.proj.get("EPSG:4326"), ol.proj.get(\''
. 'EPSG:3857\'))).getCoordinates(), (new ol.geom.Point([136,40]).transform(ol.proj.'
. 'get("EPSG:4326"), ol.proj.get(\'EPSG:3857\'))).getCoordinates()));var coord = li'
. 'ne.getCoordinates();for (var i = 0; i < coord.length; i++) lineArr.push(coord[i]);arr.'
. 'push(lineArr);var polygon = new ol.geom.Polygon(arr);polygonArray.push(polygon);var arr = [];v'
. 'ar lineArr = [];var line = new ol.geom.LinearRing(new Array((new ol.geom.Point(['
. '105,0]).transform(ol.proj.get("EPSG:4326"), ol.proj.get(\'EPSG:3857\'))).getCoor'
. 'dinates(), (new ol.geom.Point([56,20]).transform(ol.proj.get("EPSG:4326"), ol.pr'
. 'oj.get(\'EPSG:3857\'))).getCoordinates(), (new ol.geom.Point([78,73]).transform('
. 'ol.proj.get("EPSG:4326"), ol.proj.get(\'EPSG:3857\'))).getCoordinates(), (new ol'
. '.geom.Point([105,0]).transform(ol.proj.get("EPSG:4326"), ol.proj.get(\'EPSG:3857'
. '\'))).getCoordinates()));var coord = line.getCoordinates();for (var i = 0; i < coord.length;'
. ' i++) lineArr.push(coord[i]);arr.push(lineArr);var polygon = new ol.geom.Polygon(arr);po'
. 'lygonArray.push(polygon);var multiPolygon = new ol.geom.MultiPolygon(polygonArra'
. 'y);var feature = new ol.Feature(multiPolygon);feature.setStyle(style);vectorLaye'
. 'r.addFeature(feature);',
],
];
}
}