1 # Copyright 2015 Intel Corporation.
3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at
7 # http://www.apache.org/licenses/LICENSE-2.0
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
15 # This file describes a list of testcases. Each testcase is described as a
16 # dictionary in a list of dictionaries.
18 # The dictionary keys, their meanings and available values are:
20 # "Name": "phy2phy_burst", # A human-readable string identifying the
22 # "Traffic Type": "rfc2544", # One of the supported traffic types.
23 # # It can be overridden by cli option traffic_type.
24 # # Default value is "rfc2544".
25 # "Deployment": "p2p", # One of the supported deployment scenarios.
26 # "Description": "Lorem ipsum..." # Optional. A human-readable string
27 # # describing the test.
28 # "Frame Modification": "vlan" # One of the supported frame modifications:
29 # # vlan, mpls, mac, dscp, ttl, ip_addr,
31 # "biDirectional": [true|false], # Specifies if generated traffic will be
32 # # full-duplex (true) or half-duplex (false)
33 # # It can be overridden by cli option bidirectional.
34 # # Default value is "false".
35 # "MultiStream": 0-65535 # Optional. Defines number of flows simulated
36 # # by traffic generator. Value 0 disables
37 # # MultiStream feature
38 # # It can be overridden by cli option multistream.
39 # "Stream Type": ["L2"|"L3"|"L4"] # Optional. Stream Type is an extension
40 # # of the "MultiStream" feature. If MultiStream
41 # # is disabled, then Stream Type will be ignored.
42 # # Stream Type defines ISO OSI network layer
43 # # used for simulation of multiple streams.
44 # # It can be overridden by cli option stream_type.
46 # # "L2" - iteration of destination MAC address
47 # # "L3" - iteration of destination IP address
48 # # "L4" - iteration of destination UDP port
49 # # Default value is "L4".
50 # "Pre-installed Flows": ["Yes"|"No"]
51 # # Optional. Pre-installed Flows is an extension
52 # # of the "MultiStream" feature. If MultiStream
53 # # is disabled, then Pre-installed Flows will be
54 # # ignored. It defines if stream specific flows
55 # # will be inserted into OVS or not.
56 # # It can be overridden by cli option
57 # # pre-installed_flows
59 # # "Yes" - flows will be inserted into OVS
60 # # "No" - flows won't be inserted into OVS
61 # # Default value is "No".
62 # "Flow Type": ["port"|"IP"] # Optional. Defines flows complexity. In case
63 # # it isn't specified, then "port" will be used.
65 # # "port" - flow is defined by ingress ports
66 # # "IP" - flow is defined by ingress ports
67 # # and src and dst IP addresses
68 # "iLoad": 0-100 # Optional. Defines desired percentage
69 # # of frame rate used during continuous stream
70 # # tests. Can be overridden by cli option
72 # "Load": dictionary # Optional. Configures background load
73 # # during testcase execution.
74 # Description of "Load" dictionary keys, their meanings and available values:
76 # "tool": "stress" # One of the supported load generators.
77 # "load": 0-100 # percentage of cores which should be
78 # # utilized by load generator
79 # # e.g. load = 70%, detected cpu cores = 14 =>
80 # # round(14*0.7)=10, i.e. 10 instances of load
81 # # generator will be executed
82 # "reserved": 0- (Default 0) # Optional. Defines number of cores reserved
84 # # e.g. load = 80%, detected cpu cores = 14,
85 # # reserved = 4 => round((14-4)*0.8)=8,
86 # # i.e. 8 load gen. instances will be executed
87 # "pattern" : "c" # stress/stress-ng specific; Number of 'c',
88 # # 'm' and 'i' defines ratio between cpu, mem
89 # # and io workers respectively
90 # # e.g. "ccccmmi" => ratio among workers types
91 # # will be 3:2:1, so in case that 12 stress
92 # # instances should be executed, then 6 cpu,
93 # # 4 memory and 2 io workers will be executed
94 # "load_memory": 0-100 # Optional. Defines percentage of the system
95 # # memory, which should be utilized by memory
96 # # workers (if they are part of "pattern").
97 # # if not specified then default stress(-ng)
98 # # value will be used
99 # "options": "" # Optional. Additional command line options
100 # # to be passed to the load generator.
101 # "Test Modifier": [FrameMod|Other],
102 # "Dependency": [Test_Case_Name |None],
104 PERFORMANCE_TESTS = [
106 "Name": "phy2phy_tput",
107 "Traffic Type": "rfc2544",
109 "biDirectional": "True",
110 "Description": "LTD.Throughput.RFC2544.PacketLossRatio",
114 "Traffic Type": "back2back",
116 "biDirectional": "True",
117 "Description": "LTD.Throughput.RFC2544.BackToBackFrames",
120 "Name": "phy2phy_tput_mod_vlan",
121 "Traffic Type": "rfc2544",
123 "Frame Modification": "vlan",
124 "biDirectional": "False",
125 "Description": "LTD.Throughput.RFC2544.PacketLossRatioFrameModification"
128 "Name": "phy2phy_cont",
129 "Traffic Type": "continuous",
131 "Description": "Phy2Phy Continuous Stream",
132 "biDirectional": "True",
137 "Traffic Type": "continuous",
139 "Description": "PVP Continuous Stream",
140 "biDirectional": "True",
145 "Traffic Type": "continuous",
146 "Deployment": "pvvp",
147 "Description": "PVVP Continuous Stream",
148 "biDirectional": "True",
152 "Name": "phy2phy_scalability",
153 "Traffic Type": "rfc2544",
155 "biDirectional": "True",
156 "Description": "LTD.Scalability.RFC2544.0PacketLoss",
157 "MultiStream": "8000",
161 "Traffic Type": "rfc2544",
163 "Description": "LTD.Throughput.RFC2544.PacketLossRatio",
164 "biDirectional": "True",
167 "Name": "pvp_back2back",
168 "Traffic Type": "back2back",
170 "Description": "LTD.Throughput.RFC2544.BackToBackFrames",
171 "biDirectional": "True",
175 "Traffic Type": "rfc2544",
177 "Deployment": "pvvp",
178 "Description": "LTD.Throughput.RFC2544.PacketLossRatio",
179 "biDirectional": "True",
182 "Name": "pvvp_back2back",
183 "Traffic Type": "back2back",
185 "Deployment": "pvvp",
186 "Description": "LTD.Throughput.RFC2544.BackToBackFrames",
187 "biDirectional": "True",
190 "Name": "phy2phy_cpu_load",
191 "Traffic Type": "rfc2544",
193 "biDirectional": "True",
194 "Description": "LTD.CPU.RFC2544.0PacketLoss",
196 "tool" : "stress-ng",
203 "Name": "phy2phy_mem_load",
204 "Traffic Type": "rfc2544",
206 "biDirectional": "True",
207 "Description": "LTD.Memory.RFC2544.0PacketLoss",
209 "tool" : "stress-ng",