#!/usr/bin/perl
#
# $Copyright$
#
# $TAHI: ct/nd/routerSendUnsolRaMax.seq,v 1.7 2003/06/17 17:16:24 masaxmasa Exp $

########################################################################
BEGIN { $V6evalTool::TestVersion = '$Name:  $ '; }
 
use V6evalTool;
use nd;
use ra;

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;
$wait_ra=$ra::maxRAmaxInterval*2;

#
#
#
$type=$V6evalTool::NutDef{Type};
if($type eq host) {
    vLogHTML("This test is for the router only<BR>");
    exit $V6evalTool::exitRouterOnly;
}

$type=$V6evalTool::NutDef{Type};
if($type ne router) {
    vLogHTML(ndErrmsg("ERROR: $V6evalTool::NutDef{Type}: ".
		      "Unknown target type<BR>"));
    exit $V6evalTool::exitFail;
}

#
#
#
raStartMaxRA() || exit $V6evalTool::exitFail;

#
#
#
vCapture($IF);

#
#
#
$r=raRecvMaxRA($IF, $wait_ra, 0, 0, %ret);
if($ret{status} != 0 || $r == 0) {
    $exit_rtn=$V6evalTool::exitFail;
    goto end;
}

#
#
#
end:
    if($exit_rtn == $V6evalTool::exitPass) {
	vLogHTML("OK<BR>");
    } else {
	vLogHTML(ndErrmsg("NG<BR>"));
    }
    exit $exit_rtn;

########################################################################
__END__

=head1 NAME

routerSendUnsolRaMax - NUT sends configured RAs.

=head1 TARGET

  Router only

=head1 SYNOPSIS

  routerSendUnsolRaMax.seq [-tooloption ...] -p routerSendUnsolRaMax.def

=head1 INITIALIZATION

  Start NUT advertising RAs:

    MaxRtrAdvInterval                   10
    MinRtrAdvInterval                   7
    AdvCurHopLimit                      64
    AdvManagedFlag&AdvOtherConfigFlag   False
    AdvDefaultLifetime                  9000 (max value)
    AdvReachableTime                    3600000 (max value)
    AdvRetransTimer                     0
    AdvOnlinkFlag&AdvAutonomousFlag     True
    AdvValidLifetime                    2592000
    AdvPreferredLifetime                604800
    AdvLinkMTU                          1500

=head1 TEST PROCEDURE

=begin html
<B>routerSendUnsolRaMax</B> verifies that NUT sends RAs
<UL>
<LI>whose parameters are as same as <A HREF="#INITIALIZATION">configured</A>.
<LI>that may contain a Prefix option and/or a MUT option and/or SLL option.
</UL>

=end html

=head1 TERMINATION

  N/A

=head1 NOTE

  TBD

=head1 REFERENCE

=begin html
<pre>
RFC2461
<hr>
6.2.4.  Sending Unsolicited Router Advertisements<br>
   A host MUST NOT send Router Advertisement messages at any time.<br>
   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.  <b>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.</b>
</pre>

=end html

=head1 SEE ALSO

  perldoc V6evalTool
  perldoc V6evalRemote

=cut
