# Before `make install' is performed this script should be runnable with
# `make test'. After `make install' it should work as `perl test.pl'
######################### We start with some black magic to print on failure.
# Change 1..1 below to 1..last_test_to_print .
# (It may become useful if the test is moved to ./t subdirectory.)
BEGIN { $| = 1; print "1..27\n"; }
END {print "not ok 1\n" unless $loaded;}
use NetAddr::IP::Util qw(
	ipv6_aton
	ipv6_n2x
	ipv6_n2d
);
$loaded = 1;
print "ok 1\n";
######################### End of black magic.
# Insert your test code below (better if it prints "ok 13"
# (correspondingly "not ok 13") depending on the success of chunk 13
# of the test code):
$test = 2;
sub ok {
  print "ok $test\n";
  ++$test;
}
my @num = #	in			    exphex			    expd
qw(
		::			0:0:0:0:0:0:0:0			0:0:0:0:0:0:0.0.0.0
		43::			43:0:0:0:0:0:0:0		43:0:0:0:0:0:0.0.0.0
		::21			0:0:0:0:0:0:0:21		0:0:0:0:0:0:0.0.0.33
	::1:2:3:4:5:6:7			0:1:2:3:4:5:6:7			0:1:2:3:4:5:0.6.0.7
	1:2:3:4:5:6:7::			1:2:3:4:5:6:7:0			1:2:3:4:5:6:0.7.0.0
		1::8			1:0:0:0:0:0:0:8			1:0:0:0:0:0:0.0.0.8
	FF00::FFFF			FF00:0:0:0:0:0:0:FFFF		FF00:0:0:0:0:0:0.0.255.255
	FFFF::FFFF:FFFF			FFFF:0:0:0:0:0:FFFF:FFFF	FFFF:0:0:0:0:0:255.255.255.255
);
for (my $i=0;$i<@num;$i+=3) {
  my $bits = ipv6_aton($num[$i]);
  my $len = length($bits);
  print "bad len = $len, exp: 16\nnot "
	unless $len == 16;		# 16 bytes x 8 bits
  &ok;
  my $ipv6x = ipv6_n2x($bits);
  print "got: $ipv6x\nexp: $num[$i +1]\nnot "
	unless $ipv6x eq $num[$i +1];
  &ok;
  my $ipv6d = ipv6_n2d($bits);
  print "got: $ipv6d\nexp: $num[$i +2]\nnot "
	unless $ipv6d eq $num[$i +2];
  &ok;
}
## test 26	check bad length n2x
my $try = '1234';
my $notempty = eval {
	ipv6_n2x($try);
};
print "failed bad argument length test for ipv6_n2x\nnot "
	unless $@ && $@ =~ /Bad arg/;
&ok;
## test 27	check bad length n2d
$notempty = eval {
	ipv6_n2d($try);
};
print "failed bad argument length test for ipv6_n2d\nnot "
	unless $@ && $@ =~ /Bad arg/;
&ok;