#!/usr/bin/perl # #$Copyright$ # #$Id: C_RFC3315_18_1_2_RetransCnf.seq,v 1.3 2007/09/20 02:00:29 hide Exp $ ############################################################################### BEGIN{ $V6evalTool::TestVersion = '$Name: $'; } 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 ($start,$rd,$MRD) = (0,0,$CNF_MAX_RD); my $timeout = 2*$CNF_MAX_RT; 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 #--------------------------------------------------------------# $StatusCode_OPTION = "opt_StatusCode"; my ($retrep, %rep) = send_reply($IF0, "reply_server1_to_nut", \%req, ""); if($retrep !=0){ dhcpExitFail; } # wait for DAD completion vRecv($IF0, 3, 0, 0, 'dadns_nutga'); vSleep(3); my $ret = ping_test($IF0); if($ret != 0){ dhcpExitFail; } vClear($IF0); #--------------------------------------------------------------# # Restart DHCP Client #--------------------------------------------------------------# #dhcpCltRestart(); #$ret = undef; #$ret = vRemoteAsync("dhcp6c.rmt", "restart", "link0=$IF0_NUT"); #if($ret != 0) { # vLogHTML('Cannot Restart DHCPv6 Client.
'); # vRemoteAsyncWait(); # dhcpExitFail; #}; # interface up/down ifDown($IF0_NUT); vSleep(5); ifUp($IF0_NUT); #--------------------------------------------------------------# #5. Wait until confirm arrives #--------------------------------------------------------------# my ($retcnf1,%cnf1) = wait_for_confirm($IF0, $timeout); if($retcnf1 != 0){ # vRemoteAsyncWait(); dhcpExitFail; } $ret = options_exist(\%cnf1,$CMP_ETIME); if($ret != 0){ dhcpExitFail; } $start = getElapsedtime(\%cnf1); my $ago = $start; #First retransmitted RT my ($retcnf2,%cnf2) = wait_for_confirm($IF0, $timeout); if($retcnf2 != 0){ # vRemoteAsyncWait(); dhcpExitFail; } my $now = getElapsedtime(\%cnf2); $rd = $now - $start; my $RT = $now - $ago; vLogHTML("RT = $RT
"); vLogHTML("RD = $rd
"); my $RTnextMAX = $RT*2 + $RAND*$RT; my $RTnextMIN = $RT*2 - $RAND*$RT; $ago = $now; #--------------------------------------------------------------# #6. Wait until retransmitted message arrives #--------------------------------------------------------------# while($rd + $RTnextMIN <= $MRD){ ($retcnf2,%cnf2) = wait_for_confirm($IF0,$RTnextMAX); if($retcnf2 != 0){ # vRemoteAsyncWait(); dhcpExitFail; } $now = getElapsedtime(\%cnf2); $rd = $now - $start; $RT = $now - $ago; vLogHTML("RT = $RT
"); vLogHTML("RD = $rd
"); $RTnextMAX = $RT*2 + $RAND*$RT; $RTnextMIN = $RT*2 - $RAND*$RT; $ago = $now; } my ($retcnf2,%cnf2) = wait_for_confirm($IF0, $timeout); if($retcnf2 == 0){ vLogHTML(" RD more than CNF_MAX_RD($MRD) !
"); # vRemoteAsyncWait(); dhcpExitFail; } #vRemoteAsyncWait(); dhcpExitPass; ############################################################################### __END__ =head1 NAME C_RFC3315_18_1_2_RetransCnf.seq - Check MRD for retransmission of Confirm =head1 TARGET Client =head1 SYNOPSIS =begin html
   C_RFC3315_18_1_2_RetransCnf.seq [-tooloption...] 
-pkt C_RFC3315_18_1_2_RetransCnf.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 | <---- |Echo Request | ----> |Echo Reply | | | |Reboot NUT | | | ----> |Confirm | | | |Repeat unitl evaluating retransmission time is more than MRD | | | ----> |Confirm(8*) | | | |
=end html =head1 JUDGEMENT =begin html

(8*)PASS: NUT does NOT retransmit Confirm message.
=end html =head1 TERMINATION =begin html
  N/A
=end html =head1 REFERENCE =begin html
  Also see RFC3315

18.1.2. Creation and Transmission of Confirm Messages
=end html =head1 SEE ALSO =begin html

perldoc V6evalTool
=end html