#!/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_RetransRen.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) = (100,200); my ($start, $rd, $MRD) = (0, 0, $time2); my $IRT = $REN_TIMEOUT; my $MRT = $REN_MAX_RT; my $acceptablerange = 0; my $mrdflag = 0; my $min_rt = 0; my $startT2 = 0; 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; } #vClear($IF0); #--------------------------------------------------------------# #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; } vClear($IF0); #--------------------------------------------------------------# #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; } vClear($IF0); #--------------------------------------------------------------# #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
'); vLogHTML('11 23.1 48.51 101.871 213.9291
'); vLogHTML("Capable Maximum RD is T2 - T1 = $MRD sec
"); vLogHTML('
'); while(1){ if($initflag != 0){ $timeout = (2 + $RAND) * $interval; }else{ $timeout = (1 + $RAND) * $IRT; } $initflag=1; # #----------- Wait for next retransmission # ($retren2,%ren2) = wait_for_renew($IF0, $timeout + 1); #----------- Massege is NOT received and rd is expired #----------- Correct case if($retren2 == 1 && $mrdflag == 1) { $nextime = time(); $rd = $nextime - $start; # vLogHTML("Current RD is $rd sec, MRD is $MRD
"); # vLogHTML("No retransmission was observed
"); last; } #----------- Massege is received and rd is not expired #----------- Correct case if($retren2 == 0 && $mrdflag == 0){ $nextime = getReceivedtime(\%ren2); $ret = compare_message(\%ren1,\%ren2); if($ret != 0){ vLogHTML('Message has been changed!
'); dhcpExitFail; } } #----------- Massege is received and rd might be expired #----------- Incorrect case if($retren2 == 0 && $mrdflag == 1) { $nextime = getReceivedtime(\%ren2); $rd = $nextime - $start; $interval = $nextime - $pretime; vLogHTML("RT is shorter than expected.
"); vLogHTML("Actual RT is $interval, expected RT is $timeout
"); dhcpExitFail; } #----------- Massege is NOT received and rd is NOT expired #----------- Incorrect case if($retren2 == 1 && $mrdflag == 0) { $nextime = time(); $rd = $nextime - $start; vLogHTML("Current RD is $rd sec, MRD is $$MRD
"); vLogHTML("No retransmission was observed within MRD
"); dhcpExitFail; } # #----------- Calcurate current RT # $rd = $nextime - $start; $interval = $nextime - $pretime; $pretime = $nextime; vLogHTML("Actual RT is $interval sec, RD is $rd
"); if ($interval > $timeout) { vLogHTML("Actual RT is bigger than the expected maximum value
"); dhcpExitFail; } # #----------- MRD Expiration, but it must not happen # if($rd > $MRD){ vLogHTML('MRD expired!
'); dhcpExitFail; } $min_rt = (2 - $RAND) * $interval; if($min_rt > $MRT){ $min_rt = (1 - $RAND) * $MRT; } if($rd + $min_rt > $MRD){ vLogHTML('Next message must not be observed
'); $mrdflag += 1; } # #----------- Check if RT satisfies RT = MRT(1+RAND) # if(!check_equal($interval,$MRT,$RAND)){ vLogHTML('RT = MRT(1+RAND) observed
'); } } vLogHTML('No Retransmission is observed after MRD
'); vClear($IF0); vStop($IF0); dhcpExitPass; ############################################################################### __END__ =head1 NAME C_RFC3315_18_1_3_RetransRen.seq - Check MRD of Renew =head1 TARGET Client =head1 SYNOPSIS =begin html
   C_RFC3315_18_1_3_RetransRen.seq [-tooloption...] 
-pkt C_RFC3315_18_1_3_RetransRen.def
-tooloption : v6eval tool option
See Also DHCPv6.def
=end html =head1 INITIALIZATION =begin html =end html =head1 TEST PROCEDURE =begin html

NUT TN | | | |Initialize NUT(as a DHCPv6 client) | | | ----> |Solicit | <---- |Advertise | ----> |Request | <---- |Reply w/IA_NA option(T1=100, T2=160) | | | <---- |Echo Request | ----> |Echo Reply | | | |Wait T1 time expire | | | ----> |Renew(7*) | | | |Retransmit Renew before T2 time expires | | | ---> X|Renew(8*) After T2 time expire | |
=end html =head1 JUDGEMENT =begin html

(7*)PASS:TN receives Renew message. (8*)PASS:TN doesn't receive Renew message.
=end html =head1 TERMINATION =begin html
  N/A
=end html =head1 REFERENCE =begin html
  Also see RFC3315

18.1.3. Creation and Transmission of Renew Messages
=end html =head1 SEE ALSO =begin html

perldoc V6evalTool
=end html