#!/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_22_9_ElapTimeOpt_time.seq,v 1.4 2007/10/31 08:59:40 miyata Exp $ ############################################################################### BEGIN{ $V6evalTool::TestVersion = '$Name: DHCPv6_Self_Test_P2_1_0_13 $'; } 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 ($firstime, $nextime) = (0, 0); my $interval = 0; my $maxsolcounter = 5; my $delta = 0.5; 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 ($retsol1,%sol1) = wait_for_solicit($IF0,30) ; $firstime = getReceivedtime(\%sol1); if($retsol1 != 0){ dhcpExitFail; } #--------------------------------------------------------------# # Parse the option #--------------------------------------------------------------# my $ret = options_exist(\%sol1,$CMP_ETIME); if($ret != 0){ dhcpExitFail; } my $option_ElapsedTime = "Frame_Ether.Packet_IPv6.Upp_UDP.Udp_DHCPv6_Solicit.Opt_DHCPv6_ElapsedTime.Time"; my $time = $sol1{$option_ElapsedTime}; #$time = (($time>>8)&0x00ff)+(($time<<8)&0xff00); my $elapsedtime = $time/100; if($elapsedtime != 0){ vLogHTML("Elapsed Time in Option Field is $elapsedtime sec
"); dhcpExitFail; } my $solcounter = 0; while($solcounter < $maxsolcounter){ my ($retsol2,%sol2) = wait_for_solicit($IF0, 40); if($retsol2 != 0){ dhcpExitFail; } $nextime = getReceivedtime(\%sol2); $time = $sol2{$option_ElapsedTime}; #$time = (($time>>8)&0x00ff)+(($time<<8)&0xff00); $elapsedtime = $time/100; $interval = $nextime - $firstime; vLogHTML("Elapsed-time in Option Field is $elapsedtime sec
"); vLogHTML("Actual Elapsed time is $interval sec
"); if((($interval - $delta) > $elapsedtime) || ($elapsedtime > ($interval + $delta))){ vLogHTML("elapsed-time field is incorrect
"); dhcpExitFail; } $solcounter++; } vStop($IF0); dhcpExitPass; #NEED ############################################################################### __END__ =head1 NAME C_RFC3315_22_9_ElapTimeOpt_time.seq - Elapsed Time in elapsed-time field =head1 TARGET Client =head1 SYNOPSIS =begin html
   C_RFC3315_22_9_ElapTimeOpt_time.seq [-tooloption...] 
-pkt C_RFC3315_22_9_ElapTimeOpt_time.def
-tooloption : v6eval tool option
See Also DHCPv6.def
=end html =head1 INITIALIZATION =begin html
  • Network Topology
  •           NUT(Client)
              |           
              |                        
    Link0   --+--------+------------------------ 3ffe:501:ffff:100::/64
                       |
                       |          
                       TN(Server) 
       
  • Verification Points

  •    The format of Elapsed Time option is :  
    0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | OPTION_ELAPSED_TIME | option-len | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | elapsed-time | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
    option-code OPTION_ELAPSED_TIME (8).
    option-len 2.
    elapsed-time The amount of time since the client began its current DHCP transaction. This time is expressed in hundredths of a second (10^-2 seconds).
    A client MUST include an Elapsed Time option in messages to indicate how long the client has been trying to complete a DHCP message exchange.
    A client MUST include an Elapsed Time option in messages to indicate how long the client has been trying to complete a DHCP message exchange. The elapsed time is measured from the time at which the client sent the first message in the message exchange, and the elapsed-time field is set to 0 in the first message in the message exchange.
  • Configurations


  • 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 TEST PROCEDURE =begin html

NUT TN | | | |Initialize NUT(as a DHCPv6 client) | ----> |Solicit (1*) | | | ----> |Solicit (2*) | | | ----> |Solicit (3*) | | | ----> |Solicit (4*) | | | ----> |Solicit (5*) | | | ----> |Solicit (6*) | |
=end html =head1 JUDGEMENT =begin html

(1*)PASS: NUT transmits Solicit message with Elapsed time option with elapsed-time field set to 0. (2*) - (6*)PASS: NUT transmits Solicit message with Elapsed time option with elapsed-time field set to the time elapsed since the first Solicit message was received (+0.5 or - 0.5 second).
=end html =head1 TERMINATION =begin html
  N/A
=end html =head1 REFERENCE =begin html
  Also see RFC3315

22.9. Elapsed Time Option
=end html =head1 SEE ALSO =begin html

perldoc V6evalTool
=end html