add more simulation tests
authorHanoh Haim <[email protected]>
Tue, 9 Feb 2016 14:01:13 +0000 (16:01 +0200)
committerHanoh Haim <[email protected]>
Tue, 9 Feb 2016 14:01:13 +0000 (16:01 +0200)
scripts/automation/regression/unit_tests/functional_tests/stl_basic_tests.py
scripts/exp/udp_1pkt.pcap [new file with mode: 0644]
scripts/exp/udp_1pkt_1mac.pcap [new file with mode: 0644]
scripts/exp/udp_1pkt_1mac_override.pcap [new file with mode: 0644]
scripts/exp/udp_1pkt_mac.pcap [new file with mode: 0644]
scripts/exp/udp_1pkt_tuple_gen.pcap [new file with mode: 0644]
scripts/exp/udp_rand_len_9k.pcap [new file with mode: 0644]
scripts/stl/profiles/udp_1pkt_1mac.py [new file with mode: 0644]
scripts/stl/profiles/udp_1pkt_1mac_override.py [new file with mode: 0644]
scripts/stl/profiles/udp_1pkt_mac.py [new file with mode: 0644]

index 51dccd9..e55fa80 100644 (file)
@@ -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
new file mode 100644 (file)
index 0000000..e75bdd8
Binary files /dev/null and b/scripts/exp/udp_1pkt.pcap differ
diff --git a/scripts/exp/udp_1pkt_1mac.pcap b/scripts/exp/udp_1pkt_1mac.pcap
new file mode 100644 (file)
index 0000000..4141830
Binary files /dev/null and b/scripts/exp/udp_1pkt_1mac.pcap differ
diff --git a/scripts/exp/udp_1pkt_1mac_override.pcap b/scripts/exp/udp_1pkt_1mac_override.pcap
new file mode 100644 (file)
index 0000000..350f3e2
Binary files /dev/null and b/scripts/exp/udp_1pkt_1mac_override.pcap differ
diff --git a/scripts/exp/udp_1pkt_mac.pcap b/scripts/exp/udp_1pkt_mac.pcap
new file mode 100644 (file)
index 0000000..840cee5
Binary files /dev/null and b/scripts/exp/udp_1pkt_mac.pcap differ
diff --git a/scripts/exp/udp_1pkt_tuple_gen.pcap b/scripts/exp/udp_1pkt_tuple_gen.pcap
new file mode 100644 (file)
index 0000000..e993ddc
Binary files /dev/null and b/scripts/exp/udp_1pkt_tuple_gen.pcap differ
diff --git a/scripts/exp/udp_rand_len_9k.pcap b/scripts/exp/udp_rand_len_9k.pcap
new file mode 100644 (file)
index 0000000..ecddbe3
Binary files /dev/null and b/scripts/exp/udp_rand_len_9k.pcap differ
diff --git a/scripts/stl/profiles/udp_1pkt_1mac.py b/scripts/stl/profiles/udp_1pkt_1mac.py
new file mode 100644 (file)
index 0000000..4e666ad
--- /dev/null
@@ -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 (file)
index 0000000..38f10d9
--- /dev/null
@@ -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 (file)
index 0000000..760bca1
--- /dev/null
@@ -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()
+
+
+