# 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: 32\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;