summaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'scripts')
-rw-r--r--scripts/automation/regression/unit_tests/functional_tests/stl_basic_tests.py37
-rw-r--r--scripts/exp/imix.pcapbin0 -> 73096 bytes
-rw-r--r--scripts/exp/udp_1pkt.pcapbin0 -> 3824 bytes
-rw-r--r--scripts/exp/udp_1pkt_1mac.pcapbin0 -> 3824 bytes
-rw-r--r--scripts/exp/udp_1pkt_1mac_override.pcapbin0 -> 3824 bytes
-rw-r--r--scripts/exp/udp_1pkt_mac.pcapbin0 -> 3824 bytes
-rw-r--r--scripts/exp/udp_1pkt_mpls.pcapbin0 -> 1486 bytes
-rw-r--r--scripts/exp/udp_1pkt_mpls_vm.pcapbin0 -> 8624 bytes
-rw-r--r--scripts/exp/udp_1pkt_tuple_gen.pcapbin0 -> 3824 bytes
-rw-r--r--scripts/exp/udp_inc_len_9k.pcapbin0 -> 12974 bytes
-rw-r--r--scripts/exp/udp_rand_len_9k.pcapbin0 -> 211086 bytes
-rw-r--r--scripts/stl/imix.py13
-rw-r--r--scripts/stl/profiles/udp_1pkt_1mac.py44
-rw-r--r--scripts/stl/profiles/udp_1pkt_1mac_override.py53
-rw-r--r--scripts/stl/profiles/udp_1pkt_mac.py44
-rw-r--r--scripts/stl/profiles/udp_1pkt_mpls.py37
-rw-r--r--scripts/stl/profiles/udp_1pkt_mpls_vm.py42
-rw-r--r--scripts/stl/profiles/udp_inc_len_9k.py57
18 files changed, 320 insertions, 7 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 0a25c0ac..7d17d0e2 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,27 @@ 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
+ ["udp_1pkt_mpls.py","-m 1 -l 50",True],
+ ["udp_1pkt_mpls_vm.py","-m 1 ",True],
+ ["imix.py","-m 1 -l 100",True],
+ ["udp_inc_len_9k.py","-m 1 -l 100",True]
+ ];
+
+ #p=[ ["udp_inc_len_9k.py","-m 1 -l 100",True] ]
+
+ 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/imix.pcap b/scripts/exp/imix.pcap
new file mode 100644
index 00000000..a05ba218
--- /dev/null
+++ b/scripts/exp/imix.pcap
Binary files differ
diff --git a/scripts/exp/udp_1pkt.pcap b/scripts/exp/udp_1pkt.pcap
new file mode 100644
index 00000000..e75bdd87
--- /dev/null
+++ b/scripts/exp/udp_1pkt.pcap
Binary files differ
diff --git a/scripts/exp/udp_1pkt_1mac.pcap b/scripts/exp/udp_1pkt_1mac.pcap
new file mode 100644
index 00000000..4141830e
--- /dev/null
+++ b/scripts/exp/udp_1pkt_1mac.pcap
Binary files differ
diff --git a/scripts/exp/udp_1pkt_1mac_override.pcap b/scripts/exp/udp_1pkt_1mac_override.pcap
new file mode 100644
index 00000000..350f3e2a
--- /dev/null
+++ b/scripts/exp/udp_1pkt_1mac_override.pcap
Binary files differ
diff --git a/scripts/exp/udp_1pkt_mac.pcap b/scripts/exp/udp_1pkt_mac.pcap
new file mode 100644
index 00000000..840cee52
--- /dev/null
+++ b/scripts/exp/udp_1pkt_mac.pcap
Binary files differ
diff --git a/scripts/exp/udp_1pkt_mpls.pcap b/scripts/exp/udp_1pkt_mpls.pcap
new file mode 100644
index 00000000..4b6e0682
--- /dev/null
+++ b/scripts/exp/udp_1pkt_mpls.pcap
Binary files differ
diff --git a/scripts/exp/udp_1pkt_mpls_vm.pcap b/scripts/exp/udp_1pkt_mpls_vm.pcap
new file mode 100644
index 00000000..cfa69421
--- /dev/null
+++ b/scripts/exp/udp_1pkt_mpls_vm.pcap
Binary files differ
diff --git a/scripts/exp/udp_1pkt_tuple_gen.pcap b/scripts/exp/udp_1pkt_tuple_gen.pcap
new file mode 100644
index 00000000..e993ddcf
--- /dev/null
+++ b/scripts/exp/udp_1pkt_tuple_gen.pcap
Binary files differ
diff --git a/scripts/exp/udp_inc_len_9k.pcap b/scripts/exp/udp_inc_len_9k.pcap
new file mode 100644
index 00000000..bf367953
--- /dev/null
+++ b/scripts/exp/udp_inc_len_9k.pcap
Binary files differ
diff --git a/scripts/exp/udp_rand_len_9k.pcap b/scripts/exp/udp_rand_len_9k.pcap
new file mode 100644
index 00000000..ecddbe3a
--- /dev/null
+++ b/scripts/exp/udp_rand_len_9k.pcap
Binary files differ
diff --git a/scripts/stl/imix.py b/scripts/stl/imix.py
index 3abce1d4..875f2544 100644
--- a/scripts/stl/imix.py
+++ b/scripts/stl/imix.py
@@ -12,12 +12,12 @@ class STLImix(object):
'dst': {'start': "8.0.0.1", 'end': "8.0.0.254"}}
# default IMIX properties
- self.imix_table = [ {'size': 60, 'pps': 28},
- {'size': 590, 'pps': 20},
- {'size': 1514, 'pps': 4}]
+ self.imix_table = [ {'size': 60, 'pps': 28, 'isg':0 },
+ {'size': 590, 'pps': 20, 'isg':0.1 },
+ {'size': 1514, 'pps': 4, 'isg':0.2 } ]
- def create_stream (self, size, pps, vm):
+ def create_stream (self, size, pps,isg, vm ):
# create a base packet and pad it to size
base_pkt = Ether()/IP()/UDP()
pad = max(0, size - len(base_pkt)) * 'x'
@@ -25,7 +25,8 @@ class STLImix(object):
pkt = STLPktBuilder(pkt = base_pkt/pad,
vm = vm)
- return STLStream(packet = pkt,
+ return STLStream(isg = isg,
+ packet = pkt,
mode = STLTXCont())
@@ -55,7 +56,7 @@ class STLImix(object):
]
# create imix streams
- return [self.create_stream(x['size'], x['pps'], vm) for x in self.imix_table]
+ return [self.create_stream(x['size'], x['pps'],x['isg'] , vm) for x in self.imix_table]
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()
+
+
+
diff --git a/scripts/stl/profiles/udp_1pkt_mpls.py b/scripts/stl/profiles/udp_1pkt_mpls.py
new file mode 100644
index 00000000..6e3a7645
--- /dev/null
+++ b/scripts/stl/profiles/udp_1pkt_mpls.py
@@ -0,0 +1,37 @@
+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 scapy.contrib.mpls import * # import from contrib folder of scapy
+from trex_stl_api import *
+
+
+class STLS1(object):
+
+ def __init__ (self):
+ pass;
+
+ def create_stream (self):
+ # 2 MPLS label the internal with s=1 (last one)
+ pkt = Ether()/MPLS(label=17,cos=1,s=0,ttl=255)/MPLS(label=12,cos=1,s=1,ttl=12)/IP(src="16.0.0.1",dst="48.0.0.1")/UDP(dport=12,sport=1025)/('x'*20)
+
+ # burst of 17 packets
+ return STLStream(packet = STLPktBuilder(pkt = pkt ,vm = []),
+ mode = STLTXSingleBurst( pps = 1, total_pkts = 17) )
+
+
+ def get_streams (self, direction = 0):
+ # create 1 stream
+ return [ self.create_stream() ]
+
+def register():
+ return STLS1()
+
+
+
diff --git a/scripts/stl/profiles/udp_1pkt_mpls_vm.py b/scripts/stl/profiles/udp_1pkt_mpls_vm.py
new file mode 100644
index 00000000..b324a88d
--- /dev/null
+++ b/scripts/stl/profiles/udp_1pkt_mpls_vm.py
@@ -0,0 +1,42 @@
+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 scapy.contrib.mpls import * # import from contrib folder of scapy
+from trex_stl_api import *
+
+
+class STLS1(object):
+
+ def __init__ (self):
+ pass;
+
+ def create_stream (self):
+ # 2 MPLS label the internal with s=1 (last one)
+ pkt = Ether()/MPLS(label=17,cos=1,s=0,ttl=255)/MPLS(label=0,cos=1,s=1,ttl=12)/IP(src="16.0.0.1",dst="48.0.0.1")/UDP(dport=12,sport=1025)/('x'*20)
+
+ vm = CTRexScRaw( [ CTRexVmDescFlowVar(name="mlabel", min_value=1, max_value=2000, size=2, op="inc"), # 2 bytes var
+ CTRexVmDescWrFlowVar(fv_name="mlabel", pkt_offset= "MPLS:1.label") # LABEL is 20 bits expected is val*8 as 3 LSB are off, 16,32,64 .. using new instruction it will be possible to write to any bits
+ ]
+ )
+
+ # burst of 100 packets
+ return STLStream(packet = STLPktBuilder(pkt = pkt ,vm = vm),
+ mode = STLTXSingleBurst( pps = 1, total_pkts = 100) )
+
+
+ def get_streams (self, direction = 0):
+ # create 1 stream
+ return [ self.create_stream() ]
+
+def register():
+ return STLS1()
+
+
+
diff --git a/scripts/stl/profiles/udp_inc_len_9k.py b/scripts/stl/profiles/udp_inc_len_9k.py
new file mode 100644
index 00000000..fc22e295
--- /dev/null
+++ b/scripts/stl/profiles/udp_inc_len_9k.py
@@ -0,0 +1,57 @@
+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 *
+
+class STLS1(object):
+
+ def __init__ (self):
+ self.max_pkt_size_l3 =9*1024;
+
+ def create_stream (self):
+ # pkt
+ p_l2 = Ether();
+ p_l3 = IP(src="16.0.0.1",dst="48.0.0.1")
+ p_l4 = UDP(dport=12,sport=1025)
+ pyld_size = max(0, self.max_pkt_size_l3 - len(p_l3/p_l4));
+ base_pkt = p_l2/p_l3/p_l4/('\x55'*(pyld_size))
+
+ l3_len_fix =-(len(p_l2));
+ l4_len_fix =-(len(p_l2/p_l3));
+
+
+ # vm
+ vm = CTRexScRaw( [ CTRexVmDescFlowVar(name="fv_rand", min_value=64, max_value=len(base_pkt), size=2, op="inc"),
+ CTRexVmDescTrimPktSize("fv_rand"), # total packet size
+ CTRexVmDescWrFlowVar(fv_name="fv_rand", pkt_offset= "IP.len", add_val=l3_len_fix), # fix ip len
+ CTRexVmDescFixIpv4(offset = "IP"), # fix checksum
+ CTRexVmDescWrFlowVar(fv_name="fv_rand", pkt_offset= "UDP.len", add_val=l4_len_fix) # fix udp len
+ ]
+ )
+
+ pkt = STLPktBuilder(pkt = base_pkt,
+ vm = vm)
+
+ return STLStream(packet = pkt,
+ mode = STLTXCont())
+
+
+
+ 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()
+
+
+