diff options
-rw-r--r-- | scripts/automation/regression/unit_tests/functional_tests/stl_basic_tests.py | 31 | ||||
-rw-r--r-- | scripts/exp/udp_1pkt.pcap | bin | 0 -> 3824 bytes | |||
-rw-r--r-- | scripts/exp/udp_1pkt_1mac.pcap | bin | 0 -> 3824 bytes | |||
-rw-r--r-- | scripts/exp/udp_1pkt_1mac_override.pcap | bin | 0 -> 3824 bytes | |||
-rw-r--r-- | scripts/exp/udp_1pkt_mac.pcap | bin | 0 -> 3824 bytes | |||
-rw-r--r-- | scripts/exp/udp_1pkt_tuple_gen.pcap | bin | 0 -> 3824 bytes | |||
-rw-r--r-- | scripts/exp/udp_rand_len_9k.pcap | bin | 0 -> 211086 bytes | |||
-rw-r--r-- | scripts/stl/profiles/udp_1pkt_1mac.py | 44 | ||||
-rw-r--r-- | scripts/stl/profiles/udp_1pkt_1mac_override.py | 53 | ||||
-rw-r--r-- | scripts/stl/profiles/udp_1pkt_mac.py | 44 |
10 files changed, 171 insertions, 1 deletions
diff --git a/scripts/automation/regression/unit_tests/functional_tests/stl_basic_tests.py b/scripts/automation/regression/unit_tests/functional_tests/stl_basic_tests.py index 51dccd98..e55fa804 100644 --- a/scripts/automation/regression/unit_tests/functional_tests/stl_basic_tests.py +++ b/scripts/automation/regression/unit_tests/functional_tests/stl_basic_tests.py @@ -116,7 +116,21 @@ class CStlBasic_Test(functional_general_test.CGeneralFunctional_Test): finally: os.unlink(output_cap) - + + def run_py_profile_path (self, profile, options,silent = False, do_no_remove=False,compare =True): + output_cap = "a.pcap" + input_file = os.path.join('stl/profiles/', profile) + golden_file = os.path.join('exp',os.path.basename(profile).split('.')[0]+'.pcap'); + try: + rc = self.run_sim(input_file, output_cap, options, silent) + assert_equal(rc, True) + if compare: + self.compare_caps(output_cap, golden_file) + finally: + if not do_no_remove: + os.unlink(output_cap) + + # test for IMIX def test_imix (self): @@ -130,6 +144,21 @@ class CStlBasic_Test(functional_general_test.CGeneralFunctional_Test): def test_tuple_gen (self): self.golden_run("basic_tuple_gen", "imix_tuple_gen", "-m 50kpps --limit 500 --cores 8", silent = False) + def test_all_profiles (self): + p=[ + ["udp_1pkt_1mac_override.py","-m 1 -l 50",True], + ["syn_attack.py","-m 1 -l 50",False], # can't compare random now + ["udp_1pkt_1mac.py","-m 1 -l 50",True], + ["udp_1pkt_mac.py","-m 1 -l 50",True], + ["udp_1pkt.py","-m 1 -l 50",True], + ["udp_1pkt_tuple_gen.py","-m 1 -l 50",True], + ["udp_rand_len_9k.py","-m 1 -l 50",False] # can't do the compare + ]; + + for obj in p: + self.run_py_profile_path (obj[0],obj[1],compare =obj[2], do_no_remove=False) + + # valgrind tests def test_valgrind_various_profiles (self): diff --git a/scripts/exp/udp_1pkt.pcap b/scripts/exp/udp_1pkt.pcap Binary files differnew file mode 100644 index 00000000..e75bdd87 --- /dev/null +++ b/scripts/exp/udp_1pkt.pcap diff --git a/scripts/exp/udp_1pkt_1mac.pcap b/scripts/exp/udp_1pkt_1mac.pcap Binary files differnew file mode 100644 index 00000000..4141830e --- /dev/null +++ b/scripts/exp/udp_1pkt_1mac.pcap diff --git a/scripts/exp/udp_1pkt_1mac_override.pcap b/scripts/exp/udp_1pkt_1mac_override.pcap Binary files differnew file mode 100644 index 00000000..350f3e2a --- /dev/null +++ b/scripts/exp/udp_1pkt_1mac_override.pcap diff --git a/scripts/exp/udp_1pkt_mac.pcap b/scripts/exp/udp_1pkt_mac.pcap Binary files differnew file mode 100644 index 00000000..840cee52 --- /dev/null +++ b/scripts/exp/udp_1pkt_mac.pcap diff --git a/scripts/exp/udp_1pkt_tuple_gen.pcap b/scripts/exp/udp_1pkt_tuple_gen.pcap Binary files differnew file mode 100644 index 00000000..e993ddcf --- /dev/null +++ b/scripts/exp/udp_1pkt_tuple_gen.pcap diff --git a/scripts/exp/udp_rand_len_9k.pcap b/scripts/exp/udp_rand_len_9k.pcap Binary files differnew file mode 100644 index 00000000..ecddbe3a --- /dev/null +++ b/scripts/exp/udp_rand_len_9k.pcap diff --git a/scripts/stl/profiles/udp_1pkt_1mac.py b/scripts/stl/profiles/udp_1pkt_1mac.py new file mode 100644 index 00000000..4e666ad7 --- /dev/null +++ b/scripts/stl/profiles/udp_1pkt_1mac.py @@ -0,0 +1,44 @@ +import sys +import os + +# Should be removed +# TBD fix this +CURRENT_PATH = os.path.dirname(os.path.realpath(__file__)) +API_PATH = os.path.join(CURRENT_PATH, "../../api/stl") +sys.path.insert(0, API_PATH) + +from scapy.all import * +from trex_stl_api import * + +# 1 clients MAC override the LSB of destination +class STLS1(object): + + def __init__ (self): + self.fsize =64; # the size of the packet + + def create_stream (self): + + # create a base packet and pad it to size + size = self.fsize - 4; # no FCS + base_pkt = Ether()/IP(src="16.0.0.1",dst="48.0.0.1")/UDP(dport=12,sport=1025) + pad = max(0, size - len(base_pkt)) * 'x' + + vm = CTRexScRaw( [ CTRexVmDescFlowVar(name="mac_src", min_value=1, max_value=1, size=1, op="inc"), # 1 byte varible, range 1-1 ( workaround) + CTRexVmDescWrFlowVar(fv_name="mac_src", pkt_offset= 11) # write it to LSB of SRC offset it 11 + ] + ) + + return STLStream(packet = STLPktBuilder(pkt = base_pkt/pad,vm = vm), + mode = STLTXCont( pps=10 )) + + def get_streams (self, direction = 0): + # create 1 stream + return [ self.create_stream() ] + + +# dynamic load - used for trex console or simulator +def register(): + return STLS1() + + + diff --git a/scripts/stl/profiles/udp_1pkt_1mac_override.py b/scripts/stl/profiles/udp_1pkt_1mac_override.py new file mode 100644 index 00000000..38f10d9a --- /dev/null +++ b/scripts/stl/profiles/udp_1pkt_1mac_override.py @@ -0,0 +1,53 @@ +import sys +import os + +# Should be removed +# TBD fix this +CURRENT_PATH = os.path.dirname(os.path.realpath(__file__)) +API_PATH = os.path.join(CURRENT_PATH, "../../api/stl") +sys.path.insert(0, API_PATH) + +from scapy.all import * +from trex_stl_api import * + +# 1 clients MAC override the LSB of destination +# overide the destination mac 00:bb::12:34:56:01 -00:bb::12:34:56:0a +class STLS1(object): + + + def __init__ (self): + self.fsize =64; # the size of the packet + + def create_stream (self): + + # create a base packet and pad it to size + size = self.fsize - 4; # no FCS + base_pkt = Ether()/IP(src="16.0.0.1",dst="48.0.0.1")/UDP(dport=12,sport=1025) + pad = max(0, size - len(base_pkt)) * 'x' + + vm = CTRexScRaw( [ CTRexVmDescFlowVar(name="dyn_mac_src", min_value=1, max_value=10, size=1, op="inc"), # 1 byte varible, range 1-1 ( workaround) + + CTRexVmDescFlowVar(name="static_mac_src_lsb", min_value=0x12345600, max_value=0x12345600, size=4, op="inc"), # workaround to override the mac 4 LSB byte + CTRexVmDescFlowVar(name="static_mac_src_msb", min_value=0x00bb, max_value=0x00bb, size=2, op="inc"), # workaround to override the mac 2 MSB byte + + CTRexVmDescWrFlowVar(fv_name="static_mac_src_msb", pkt_offset= 6), + CTRexVmDescWrFlowVar(fv_name="static_mac_src_lsb", pkt_offset= 8), + + CTRexVmDescWrFlowVar(fv_name="dyn_mac_src", pkt_offset= 11) + ] + ) + + return STLStream(packet = STLPktBuilder(pkt = base_pkt/pad,vm = vm), + mode = STLTXCont( pps=10 )) + + def get_streams (self, direction = 0): + # create 1 stream + return [ self.create_stream() ] + + +# dynamic load - used for trex console or simulator +def register(): + return STLS1() + + + diff --git a/scripts/stl/profiles/udp_1pkt_mac.py b/scripts/stl/profiles/udp_1pkt_mac.py new file mode 100644 index 00000000..760bca12 --- /dev/null +++ b/scripts/stl/profiles/udp_1pkt_mac.py @@ -0,0 +1,44 @@ +import sys +import os + +# Should be removed +# TBD fix this +CURRENT_PATH = os.path.dirname(os.path.realpath(__file__)) +API_PATH = os.path.join(CURRENT_PATH, "../../api/stl") +sys.path.insert(0, API_PATH) + +from scapy.all import * +from trex_stl_api import * + +# 10 clients override the LSB of destination +class STLS1(object): + + def __init__ (self): + self.fsize =64; # the size of the packet + + def create_stream (self): + + # create a base packet and pad it to size + size = self.fsize - 4; # no FCS + base_pkt = Ether()/IP(src="16.0.0.1",dst="48.0.0.1")/UDP(dport=12,sport=1025) + pad = max(0, size - len(base_pkt)) * 'x' + + vm = CTRexScRaw( [ CTRexVmDescFlowVar(name="mac_src", min_value=1, max_value=10, size=1, op="inc"), # 1 byte varible, range 1-10 + CTRexVmDescWrFlowVar(fv_name="mac_src", pkt_offset= 11) # write it to LSB of SRC + ] + ) + + return STLStream(packet = STLPktBuilder(pkt = base_pkt/pad,vm = vm), + mode = STLTXCont( pps=10 )) + + def get_streams (self, direction = 0): + # create 1 stream + return [ self.create_stream() ] + + +# dynamic load - used for trex console or simulator +def register(): + return STLS1() + + + |