#!/usr/bin/perl
#
#Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
# Yokogawa Electric Corporation.
#All rights reserved.
#
#Redistribution and use of this software in source and binary
#forms, with or without modification, are permitted provided that
#the following conditions and disclaimer are agreed and accepted
#by the user:
#
#1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
#2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in
# the documentation and/or other materials provided with
# the distribution.
#
#3. Neither the names of the copyrighters, the name of the project
# which is related to this software (hereinafter referred to as
# "project") nor the names of the contributors may be used to
# endorse or promote products derived from this software without
# specific prior written permission.
#
#4. No merchantable use may be permitted without prior written
# notification to the copyrighters.
#
#5. The copyrighters, the project and the contributors may prohibit
# the use of this software at any time.
#
#THIS SOFTWARE IS PROVIDED BY THE COPYRIGHTERS, THE PROJECT AND
#CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING
#BUT NOT LIMITED THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
#FOR A PARTICULAR PURPOSE, ARE DISCLAIMED. IN NO EVENT SHALL THE
#COPYRIGHTERS, THE PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
#INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
#(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
#SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
#HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
#STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
#IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
#POSSIBILITY OF SUCH DAMAGE.
#
#$Id: C_RFC3315_18_1_3_RenRetransMRT.seq,v 1.9 2008/04/02 08:19:41 miyata Exp $
###############################################################################
BEGIN{
$V6evalTool::TestVersion = '$Name: DHCPv6_Self_Test_P2_1_0_14 $';
}
use strict;
use V6evalTool;
use lib '../.';
use DHCPv6_common;
use Client_pktdesc;
dhcpExitNS if(ChkFuncSupport('ADDRASSIGN') && ChkFuncSupport('DNS'));
#--------------------------------------------------------------#
# Initialization variables
#--------------------------------------------------------------#
my $IF0_NUT = $V6evalTool::NutDef{"Link0_device"};
my $IF0 = "Link0";
my ($pretime, $nextime, $interval) = (0, 0, 0);
my ($plifetime, $vlifetime) = (8000, 9000);
my ($time1, $time2) = (40,2000);
my ($start, $rd, $MRD) = (0, 0, $time2);
my $IRT = $REN_TIMEOUT;
my $MRT = $REN_MAX_RT;
my $startT2 = 0;
my $mrtflag = 0;
my $MAXCOUNT = 1;
#------------------ My proposal
#my ($time1, $time2) = (40,2500);
#my $MAXCOUNT = 1;
#------------------ My proposal
vCapture($IF0);
#--------------------------------------------------------------#
# Initialize DHCPv6 Client
#--------------------------------------------------------------#
my $ret = initial_ra_w_ping($IF0,'ra_server2_to_all');
if($ret == 0){
vLogHTML('Global Address of NUT is assigned by RA!
');
dhcpExitFail;
}
$ret = vRemote("dhcp6c.rmt", "start", "iana", "iaid=111111", "link0=$IF0_NUT");
if($ret != 0) {
vLogHTML('Cannot Initialize DHCPv6 Client program.
');
dhcpExitFail;
};
#--------------------------------------------------------------#
#1. Wait until Solicit arrives
#--------------------------------------------------------------#
my ($retsol,%sol) = wait_for_solicit($IF0,30);
if($retsol != 0){
dhcpExitFail;
}
#--------------------------------------------------------------#
#2. Send Advertise to reply to Solicit
#--------------------------------------------------------------#
$SID_OPTION = "opt_SID_LLT_server1";
$IA_NA_OPTION = "opt_IA_NA_Addr_woStatus";
my ($retadv, %adv) = send_advertise($IF0, "advertise_server1_to_nut", \%sol, "");
if($retadv != 0){
dhcpExitFail;
}
#--------------------------------------------------------------#
#3. Wait until Request arrives
#--------------------------------------------------------------#
my ($retreq, %req) = wait_for_request($IF0,30);
if($retreq != 0){
dhcpExitFail;
}
#--------------------------------------------------------------#
#4. send Reply message
#--------------------------------------------------------------#
$IA_NA_OPTION = "opt_IA_NA_Addr";
$StatusCode_OPTION = "opt_StatusCode";
my ($retrep, %rep) = send_reply($IF0, "reply_server1_to_nut", \%req, "-DIA_NA_TIME1=$time1 -DIA_NA_TIME2=$time2 -DIA_ADDR_PLTIME=$plifetime -DIA_ADDR_VLTIME=$vlifetime ");
if($retrep !=0){
dhcpExitFail;
}
# wait for DAD completion
$ret = undef;
my %dad = vRecv($IF0, 3, 0, 0, 'dadns_nutga');
#
#----------- get T2 start time
#
if ($dad{status} == 0){
$startT2 = getReceivedtime(\%dad);
}else{
$startT2 = time() - 3;
}
vSleep(3);
$ret = ping_test($IF0);
if($ret != 0){
dhcpExitFail;
}
#--------------------------------------------------------------#
#5. Wait until renew arrives
#--------------------------------------------------------------#
my $timeout = $time1 + 5;
my ($retren1,%ren1) = wait_for_renew($IF0, $timeout);
if($retren1 != 0){
dhcpExitFail;
}
$ret = options_exist(\%ren1,$CMP_ETIME);
if($ret != 0){
dhcpExitFail;
}
$pretime = getReceivedtime(\%ren1);
$start = $pretime;
$MRD = $time2 - ($start - $startT2);
#--------------------------------------------------------------#
#6. Wait until retransmitted message arrives
#--------------------------------------------------------------#
my ($retren2,%ren2) = (1, ());
my $initflag = 0;
vLogHTML('
');
vLogHTML("IRT is $IRT, MRT is $MRT, MRD is $MRD sec
");
vLogHTML('Retransmitted Maximum Renew RT.
');
vLogHTML('1st 2nd 3rd 4th 5th 6th 7th
');
vLogHTML('11 23.1 48.51 101.871 213.9291 449.25111 660
');
vLogHTML('');
while($mrtflag < $MAXCOUNT){
if($initflag != 0){
$timeout = (2 + $RAND) * $interval;
}else{
$timeout = (1 + $RAND) * $IRT;
}
$initflag=1;
# If $timeout is bigger than MRT, expected RT is MRT + RAND * MRT
if($timeout > $MRT){
$timeout = (1 + $RAND) * $MRT;
}
#
#----------- Wait for next retransmission
#
($retren2,%ren2) = wait_for_renew($IF0, $timeout + 1);
if($retren2 != 0){
dhcpExitFail;
}
$ret = compare_message(\%ren1,\%ren2);
if($ret != 0){
vLogHTML('Message has been changed!C_RFC3315_18_1_3_RenRetransMRT.seq [-tooloption...]=end html =head1 INITIALIZATION =begin html
-pkt C_RFC3315_18_1_3_RenRetransMRT.def
-tooloption : v6eval tool option
See Also DHCPv6.def
NUT(Client)
|
|
Link0 --+--------+------------------------ 3ffe:501:ffff:100::/64
|
|
TN(Server)
The client transmits the message using the following parameters:
IRT REN_TIMEOUT
MRT REN_MAX_RT
MRC 0
MRD Remaining time until T2
RT for each transmission is based on the previous value of RT:
RT = 2*RTprev + RAND*RTprev
If (RT > MRT)
RT = MRT + RAND*MRT
| Device Name | Device Type | Interface | Assigned Prefix | Link Local Addr | MAC Addr |
| Client | NUT | Link0 | 3ffe:501:ffff:100::/64 | NUT's Linklocal address | NUT's MAC address |
| Server | TN | Link0 | 3ffe:501:ffff:100::/64 | fe80::200:ff:fe00:a1a1 | 00:00:00:00:a1:a1 |
=end html =head1 JUDGEMENT =begin html
NUT TN | | | |Initialize NUT(as a DHCPv6 client) | ----> |Solicit | <---- |Advertise | ----> |Request | <---- |Reply w/IA_NA option (T1=40, T2=2000) | | | <---- |Echo Request | ----> |Echo Reply | | | |Before T1 time expires | | | ----> |Renew | | | |Waiting for DHCPv6 message until RT=MRT+RAND*MRT | | | ----> |Renew (8*) | |
(8*)PASS: MRT for Renew conforms to Verification Points.=end html =head1 TERMINATION =begin html
N/A=end html =head1 REFERENCE =begin html
Also see RFC3315=end html =head1 SEE ALSO =begin html
18.1.3. Creation and Transmission of Renew Messages
=end html
perldoc V6evalTool