################################################################################ # Version 1.0 $Revision: 1 $ # $Author: Matei-Eugen Vasile $ # # Copyright © 1997 - 2007 by IXIA # All Rights Reserved. # # Revision Log: # 3-16-2007 Matei-Eugen Vasile # ################################################################################ ################################################################################ # # # LEGAL NOTICE: # # ============== # # The following code and documentation (hereinafter "the script") is an # # example script for demonstration purposes only. # # The script is not a standard commercial product offered by Ixia and have # # been developed and is being provided for use only as indicated herein. The # # script [and all modifications, enhancements and updates thereto (whether # # made by Ixia and/or by the user and/or by a third party)] shall at all times # # remain the property of Ixia. # # # # Ixia does not warrant (i) that the functions contained in the script will # # meet the user's requirements or (ii) that the script will be without # # omissions or error-free. # # THE SCRIPT IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND, AND IXIA # # DISCLAIMS ALL WARRANTIES, EXPRESS, IMPLIED, STATUTORY OR OTHERWISE, # # INCLUDING BUT NOT LIMITED TO ANY WARRANTY OF MERCHANTABILITY AND FITNESS FOR # # A PARTICULAR PURPOSE OR OF NON-INFRINGEMENT. # # THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE SCRIPT IS WITH THE # # USER. # # IN NO EVENT SHALL IXIA BE LIABLE FOR ANY DAMAGES RESULTING FROM OR ARISING # # OUT OF THE USE OF, OR THE INABILITY TO USE THE SCRIPT OR ANY PART THEREOF, # # INCLUDING BUT NOT LIMITED TO ANY LOST PROFITS, LOST BUSINESS, LOST OR # # DAMAGED DATA OR SOFTWARE OR ANY INDIRECT, INCIDENTAL, PUNITIVE OR # # CONSEQUENTIAL DAMAGES, EVEN IF IXIA HAS BEEN ADVISED OF THE POSSIBILITY OF # # SUCH DAMAGES IN ADVANCE. # # Ixia will not be required to provide any software maintenance or support # # services of any kind (e.g., any error corrections) in connection with the # # script or any part thereof. The user acknowledges that although Ixia may # # from time to time and in its sole discretion provide maintenance or support # # services for the script, any such services are subject to the warranty and # # damages limitations set forth herein and will not obligate Ixia to provide # # any additional maintenance or support services. # # # ############################################################################### ################################################################################ # # # Description: # # This sample creates a DHCPv6 three groups on two different ports, binds # # them and gathers the DHCPv6 statistics from the port on which the groups # # were configured. # # # # Module: # # The sample was tested on a TXS4 module. # # # ################################################################################ ################################################################################ # DUT config: # ################################################################################ # conf t # # # # ipv6 local pool ixa_pool 2001:4::/48 64 # # # # ipv6 dhcp pool ixaccess # # prefix-delegation pool ixa_pool # # exit # # # # interface GigabitEthernet1/13 # # ipv6 enable # # ipv6 dhcp server ixaccess # # no shutdown # # exit # # # # interface GigabitEthernet1/14 # # ipv6 enable # # ipv6 dhcp server ixaccess # # no shutdown # # exit # # # # end # ################################################################################ package require Ixia set test_name [info script] set chassis_ip sylvester set port_list [list 2/3 2/4] # Connect to the chassis. set connect_status [::ixia::connect \ -reset \ -device $chassis_ip \ -port_list $port_list \ -username ixiaApiUser ] if {[keylget connect_status status] != $::SUCCESS} { return "FAIL - $test_name - [keylget connect_status log]" } set port_handle1 [keylget connect_status port_handle.$chassis_ip.[lindex $port_list 0]] set port_handle2 [keylget connect_status port_handle.$chassis_ip.[lindex $port_list 1]] # Create DHCPv6 settings objects. # NOTE: Cisco supported only IAPD at the time this test script was written. set dhcp_settings_obj1 [::ixia::emulation_dhcpv6_config \ -mode create \ -port_handle $port_handle1 \ -ia_id 53 \ -ia_type IAPD \ -lease_time 300 \ -max_setup_rate 25 \ -reset \ ] if {[keylget dhcp_settings_obj1 status] != $::SUCCESS} { return "FAIL - $test_name - [keylget dhcp_settings_obj1 log]" } set settings_handle1 [keylget dhcp_settings_obj1 handle] set dhcp_settings_obj2 [::ixia::emulation_dhcpv6_config \ -mode create \ -port_handle $port_handle2 \ -ia_id 45 \ -ia_type IAPD \ -lease_time 200 \ -max_setup_rate 15 \ ] if {[keylget dhcp_settings_obj2 status] != $::SUCCESS} { return "FAIL - $test_name - [keylget dhcp_settings_obj2 log]" } set settings_handle2 [keylget dhcp_settings_obj2 handle] # Create DHCPv6 clients croups. # NOTE: # -encap has the default set to "ethernet" # -target_subport has the default set to "0" set dhcp_group_obj1 [::ixia::emulation_dhcpv6_group_config \ -mode create \ -handle $settings_handle1 \ -encap ethernet \ -target_subport 0 \ -mac_addr 00:00:11:11:22:22 \ -mac_addr_step 10 \ -num_sessions 5 \ ] if {[keylget dhcp_group_obj1 status] != $::SUCCESS} { return "FAIL - $test_name - [keylget dhcp_group_obj1 log]" } set group_handle1 [keylget dhcp_group_obj1 handle] set dhcp_group_obj2 [::ixia::emulation_dhcpv6_group_config \ -mode create \ -handle $settings_handle1 \ -encap ethernet \ -target_subport 0 \ -mac_addr 00:00:AA:AA:11:11 \ -mac_addr_step 5 \ -num_sessions 3 \ ] if {[keylget dhcp_group_obj2 status] != $::SUCCESS} { return "FAIL - $test_name - [keylget dhcp_group_obj2 log]" } set group_handle2 [keylget dhcp_group_obj2 handle] set dhcp_group_obj3 [::ixia::emulation_dhcpv6_group_config \ -mode create \ -handle $settings_handle2 \ -encap ethernet \ -target_subport 0 \ -mac_addr 00:11:22:33:44:55 \ -mac_addr_step 16 \ -num_sessions 4 \ ] if {[keylget dhcp_group_obj3 status] != $::SUCCESS} { return "FAIL - $test_name - [keylget dhcp_group_obj3 log]" } set group_handle3 [keylget dhcp_group_obj3 handle] # Get IPv6 addresses for the clients emulated on port $port_handle. set dhcp_port_status [::ixia::emulation_dhcpv6_control \ -port_handle [list $port_handle1 $port_handle2] \ -bind bind \ ] if {[keylget dhcp_port_status status] != $::SUCCESS} { return "FAIL - $test_name - [keylget dhcp_port_status log]" } after 30000 # Get aggregated statistics for all groups configured on ports $port_handle1 # and $port_handle2. set dhcp_control_status [::ixia::emulation_dhcpv6_stats \ -port_handle [list $port_handle1 $port_handle2] \ -handle [list [list $group_handle1 $group_handle2] $group_handle3] \ ] if {[keylget dhcp_control_status status] != $::SUCCESS} { return "FAIL - $test_name - [keylget dhcp_control_status log]" } return "SUCCESS - $test_name - [clock format [clock seconds]]"