The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;
use Test::More qw(no_plan);
BEGIN { use_ok('Geo::GDAL') };

Geo::GDAL::PushFinderLocation('../../data'); # built in src tree
Geo::GDAL::PushFinderLocation('./gdal/data'); # built with downloaded srcs

my $find = Geo::GDAL::FindFile('pcs.csv');

SKIP: {
    skip "GDAL data files are not available", 2 if !$find;
    my $srs1 = Geo::OSR::SpatialReference->new(EPSG=>2936);
    my $srs2 = Geo::OSR::SpatialReference->new(Text=>$srs1->AsText);
    ok($srs1->ExportToProj4 eq $srs2->ExportToProj4, "new EPSG, Text, Proj4");

    my $src = Geo::OSR::SpatialReference->new(EPSG => 2392);
    my $dst = Geo::OSR::SpatialReference->new(EPSG => 2393);
    ok(($src and $dst), "new Geo::OSR::SpatialReference");
}

SKIP: {
    skip "GDAL data files are not available", 3 if !$find;

    my $src = Geo::OSR::SpatialReference->new(EPSG => 2392);
    my $dst = Geo::OSR::SpatialReference->new(EPSG => 2393);

    skip "PROJSO not set", 1 if (!$ENV{PROJSO} and $^O eq 'MSWin32');
    my ($t1, $t2);
    eval {
	$t1 = Geo::OSR::CoordinateTransformation->new($src, $dst);
	$t2 = Geo::OSR::CoordinateTransformation->new($dst, $src);
    };
    skip "Unable to load PROJ.4 library",1 if $@ =~ /Unable to load/;
    ok($t1, "new Geo::OSR::CoordinateTransformation $@");

    skip "new Geo::OSR::CoordinateTransformation failed",1 unless ($t1 and $t2);

    my @points = ([2492055.205, 6830493.772],
		  [2492065.205, 6830483.772],
		  [2492075.205, 6830483.772]);

    my $p1 = $points[0][0];

    my @polygon = ([[2492055.205, 6830483.772],
		    [2492075.205, 6830483.772],
		    [2492075.205, 6830493.772],
		    [2492055.205, 6830483.772]]);

    my $p2 = $polygon[0][0][0];
    
    $t1->TransformPoints(\@points);
    $t1->TransformPoints(\@polygon);

    $t2->TransformPoints(\@points);
    $t2->TransformPoints(\@polygon);

    ok(int($p1) == int($points[0][0]), "from EPSG 2392 to 2393 and back in line"); 
    ok(int($p2) == int($polygon[0][0][0]), "from EPSG 2392 to 2393 and back in polygon"); 
    
}