The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#!/usr/bin/perl -w
# -*- perl -*-

#
# $Id: base.t,v 0.1 2006/02/21 eserte Exp $
# Author: Michael R. Davis
#

=head1 NAME

base.t - Good examples concerning how to use this module

=cut

use strict;
use lib q{lib};
use lib q{../lib};
use constant NEAR_DEFAULT => 7;

sub near {
  my $x=shift();
  my $y=shift();
  my $p=shift()||NEAR_DEFAULT;
  if (($x-$y)/$y < 10**-$p) {
    return 1;
  } else {
    return 0;
  }
}

BEGIN {
    if (!eval q{
	use Test;
	1;
    }) {
	print "1..0 # tests only works with installed Test module\n";
	exit;
    }
}

BEGIN { plan tests => 2239 }

# just check that all modules can be compiled
ok(eval {require Geo::Functions; 1}, 1, $@);

my $o = Geo::Functions->new();
ok(ref $o, "Geo::Functions");

ok ($o->deg_rad(atan2(1,1)), 45);
ok ($o->deg_dms(40,42,46.5,"N"), 40+(42+46.5/60)/60);
ok ($o->rad_dms(40,42,46.5,"N"), $o->rad_deg(40+(42+46.5/60)/60));
ok ($o->rad_deg(45), atan2(1,1));
ok ($o->round(45.9), 46);
foreach (qw{5 10 25 50}) {
  ok($_, $o->mps_knots($o->knots_mps($_)));
}

use Geo::Functions qw{deg_rad deg_dms rad_deg round rad_dms dms_deg dm_deg mps_knots knots_mps};

ok (deg_rad(atan2(1,1)), 45);
ok (deg_dms(40,42,46.5,"s"), -1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,"S"), -1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,"w"), -1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,"W"), -1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,-1), -1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,-40), -1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,"N"), 1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,"n"), 1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,""), 1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5,undef), 1*(40+(42+46.5/60)/60));
ok (deg_dms(40,42,46.5), 1*(40+(42+46.5/60)/60));
ok (rad_deg(45), atan2(1,1));
ok (rad_deg(90), atan2(1,0));
ok (rad_deg(180), atan2(0,-1));
ok (rad_deg(-90), atan2(-1,0));
ok (round(0), 0);
ok (round(5.1), 5);
ok (round(5.5), 6);
ok (round(5.6), 6);
ok (round(-5.1), -5);
ok (round(-5.5), -6);
ok (round(-5.6), -6);
ok (rad_dms(55, 34, 76, "N"), rad_deg(deg_dms(55, 34, 76, "N")));
foreach my $d1 (0,5,15,67,88) {
  foreach my $m1 (0,3,43,57) {
    foreach my $s1 (5,15,34,45,56) {
      foreach my $sign1 (qw{N S}) {
        my ($d2,$m2,$s2,$sign2)=dms_deg(deg_dms($d1,$m1,$s1,$sign1), qw{N S});
        my ($d3,$m3,$sign3)=dm_deg(deg_dms($d1,$m1,$s1,$sign1), qw{N S});
        ok ($d1, $d2);
        ok ($m1, $m2);
        ok (near $s1, $s2);
        ok ($sign1, $sign2);
        ok ($d1, $d3);
        ok (near $m1+$s1/60, $m3);
        ok ($sign1, $sign3);
      }
      foreach my $sign1 (qw{E W}) {
        my ($d2,$m2,$s2,$sign2)=dms_deg(deg_dms($d1,$m1,$s1,$sign1), qw{E W});
        ok ($d1, $d2);
        ok ($m1, $m2);
        ok (near $s1, $s2);
        ok ($sign1, $sign2);
      }
    }
  }
}
foreach (qw{5 10 25 50}) {
  ok($_, mps_knots(knots_mps($_)));
}