#!/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...]=end html =head1 INITIALIZATION =begin html
-pkt C_RFC3315_18_1_2_RetransCnf.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 CNF_TIMEOUT
MRT CNF_MAX_RT
MRC 0
MRD CNF_MAX_RD
When the duration of retransmission is more than CNF_MAX_RD, the client stops retransmission.
| 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 | <---- |Echo Request | ----> |Echo Reply | | | |Reboot NUT | | | ----> |Confirm | | | |Repeat unitl evaluating retransmission time is more than MRD | | | ----> |Confirm(8*) | | | |
=end html =head1 TERMINATION =begin html
(8*)PASS: NUT does NOT retransmit Confirm message.
N/A=end html =head1 REFERENCE =begin html
Also see RFC3315=end html =head1 SEE ALSO =begin html
18.1.2. Creation and Transmission of Confirm Messages
=end html
perldoc V6evalTool