#!/usr/bin/perl # # $Copyright_v6PC$ # # $Copyright$ # # $TAHI: ct/nd/routerSendUnsolRaDefault2.seq,v 1.13 2004/04/02 02:28:24 akisada Exp $ ######################################################################## BEGIN { $V6evalTool::TestVersion = '$Name: $ '; } use V6evalTool; use nd; use ra; my $wait_readout = $nd::DELAY_FIRST_PROBE_TIME + $nd::RETRANS_TIMER * $nd::MAX_UNICAST_SOLICIT + 1; ndOptions(@ARGV); # The following generate debugging messages. $nd::debug=$ndOpt_v|$ndOpt_vv; # You can specifies debug options to a remote control program. # If you want to know more detail, please see the following: # - V6evalTool.pm: perldoc V6evalTool # - V6evalRemote.pm: perldoc V6evalRemote $nd::remote_debug="-o1" if $ndOpt_vv; $IF=Link0; $exit_rtn=$V6evalTool::exitPass; $wait_ra=$ra::defaultRA2maxInterval*2; $max_ras=$nd::MAX_INITIAL_RTR_ADVERTISEMENTS*2; $ra_mininterval=$ra::defaultRA2minInterval; $ra_maxinterval=$ra::defaultRA2maxInterval; $ra_advs=$nd::MAX_INITIAL_RTR_ADVERTISEMENTS; # # # $type=$V6evalTool::NutDef{Type}; if($type eq host) { vLogHTML("This test is for the router only
"); exit $V6evalTool::exitRouterOnly; } $type=$V6evalTool::NutDef{Type}; if($type ne router) { vLogHTML(ndErrmsg("ERROR: $V6evalTool::NutDef{Type}: ". "Unknown target type
")); exit $V6evalTool::exitFail; } # # # raStartDefaultRA2() || exit $V6evalTool::exitFail; # # # vCapture($IF); # # # vLogHTML("Wait for RA
"); for($i=0; $i<$max_ras; $i++) { # $r=raRecvDefaultRA($IF, $wait_ra, 0, 0, %ret); $r=raRecvAnyRA($IF, $wait_ra, 0, 0, %ret); last if $ret{status} == 1; # timeout if($ret{status} != 0) { vLogHTML(ndErrmsg(vErrmsg(%ret))."
"); $exit_rtn=$V6evalTool::exitFail; goto end; } $exit_rtn=$V6evalTool::exitFail if $r == 0; $n = $ret{recvCount}; $time[$i] = $ret{"recvTime$n"}; } if($i == 0) { vLogHTML(ndErrmsg("ERROR: Could not get any unsolicited RA
")); $exit_rtn=$V6evalTool::exitFail; goto end; } elsif($i == 1) { vLogHTML(ndErrmsg("ERROR: Got single RA, ". "could not test interval time
")); $exit_rtn=$V6evalTool::exitFail; goto end; } # # Check intervals of the RAs # for($j=0, $over=0, $mark=''; $j<$i-1; $j++, $mark='') { #$delta = int(vRoundoff($time[$j+1] - $time[$j] + 0.5)); $delta = int($time[$j+1] - $time[$j] + 0.5); if($delta < $ra_mininterval || $delta > $ra_maxinterval) { $over=1; $mark=ndErrmsg('*'); } vLogHTML("Retransmit interval[$j]: $mark$delta sec.
"); } if($over) { vLogHTML(ndErrmsg("ERROR: Rate limit violation ". "(< $ra_mininterval, > $ra_maxinterval sec.)". "
")); $exit_rtn=$V6evalTool::exitFail; } # # # end: if($exit_rtn == $V6evalTool::exitPass) { vLogHTML("OK
"); } else { vLogHTML(ndErrmsg("NG
")); readout($IF, $wait_readout); } exit $exit_rtn; sub readout($$) { my ($if, $timeout) = @_; return(vRecv($if, $timeout, 0, 0)); } ######################################################################## __END__ =head1 NAME routerSendUnsolRaDefault2 - verify a host sending valid RSs =head1 TARGET Router Only =head1 SYNOPSIS routerSendUnsolRaDefault2.seq [-tooloption ...] -p routerSendUnsolRaDefault2.def =head1 INITIALIZATION =begin html Start NUT advertising RAs whose parameters are as same as those except the followings: =end html =head1 TEST PROCEDURE B verifies that a NUT send valid RAs by the rules. The interval of RAs is between 7 sec. and 10 sec. =head1 JUDGMENT =begin html
  1. NUT throw valid RAs:
     - whose parameter are as same as those.
     - that may contain a source link-layer option.
     - that may contain a MTU option.
     - that may contain a Prefix option.

2. The interval of RAs is between 7 sec. and 10 sec.
=end html =head1 TERMINATION N/A =head1 NOTE The test invokes remote command - rtadvd.rmt. =head1 REFERENCE =begin html
6.2.4.  Sending Unsolicited Router Advertisements

Unsolicited Router Advertisements are not strictly periodic: the interval between subsequent transmissions is randomized to reduce the probability of synchronization with the advertisements from other routers on the same link [SYNC]. Each advertising interface has its own timer. Whenever a multicast advertisement is sent from an interface, the timer is reset to a uniformly-distributed random value between the interface's configured MinRtrAdvInterval and MaxRtrAdvInterval; expiration of the timer causes the next advertisement to be sent and a new random value to be chosen.
For the first few advertisements (up to MAX_INITIAL_RTR_ADVERTISEMENTS) sent from an interface when it becomes an advertising interface, if the randomly chosen interval is greater than MAX_INITIAL_RTR_ADVERT_INTERVAL, the timer SHOULD be set to MAX_INITIAL_RTR_ADVERT_INTERVAL instead. Using a smaller interval for the initial advertisements increases the likelihood of a router being discovered quickly when it first becomes available, in the presence of possible packet loss.
=end html =head1 SEE ALSO perldoc V6evalTool perldoc V6evalRemote =cut