1 # Copyright (c) 2018 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 # flow definition for ACL tests - 1K flows - ipv4 only
17 # the number of flows defines the widest range of parameters
18 # for example if srcip_range=1.0.0.1-1.0.0.255 and dst_ip_range=10.0.0.1-10.0.1.255
19 # and it should define only 16 flows
21 #there is assumption that packets generated will have a random sequences of following addresses pairs
23 # 1. src=1.x.x.x(x.x.x =random from 1..255) dst=10.x.x.x (random from 1..512)
24 # 2. src=1.x.x.x(x.x.x =random from 1..255) dst=10.x.x.x (random from 1..512)
26 # 512. src=1.x.x.x(x.x.x =random from 1..255) dst=10.x.x.x (random from 1..512)
28 # not all combination should be filled
29 # Any other field with random range will be added to flow definition
31 # the example.yaml provides all possibilities for traffic generation
33 # the profile defines a public and private side to make limited traffic correlation
34 # between private and public side same way as it is made by IXIA solution.
36 {% set num_vnfs = get(extra_args, 'num_vnfs', 1) %}
38 schema: "nsb:traffic_profile:0.1"
40 description: Traffic profile to run RFC2544 latency
42 traffic_type : RFC2544Profile # defines traffic behavior - constant or look for highest possible throughput
43 frame_rate : 100 # pc of linerate
44 # that specifies a range (e.g. ipv4 address, port)
45 {% for vnf_num in range(num_vnfs|int) %}
48 id: {{ (vnf_num * 2) + 1 }}
51 64B: "{{get(imix, 'imix.uplink.64B', '0') }}"
52 128B: "{{get(imix, 'imix.uplink.128B', '0') }}"
53 256B: "{{get(imix, 'imix.uplink.256B', '0') }}"
54 373B: "{{get(imix, 'imix.uplink.373B', '0') }}"
55 512B: "{{get(imix, 'imix.uplink.512B', '0') }}"
56 570B: "{{get(imix, 'imix.uplink.570B', '0') }}"
57 1024B: "{{get(imix, 'imix.uplink.1024B', '0') }}"
58 1280B: "{{get(imix, 'imix.uplink.1280B', '0') }}"
59 1400B: "{{get(imix, 'imix.uplink.1400B', '0') }}"
60 1500B: "{{get(imix, 'imix.uplink.1500B', '0') }}"
61 1518B: "{{get(imix, 'imix.uplink.1518B', '0') }}"
65 srcip4: "{{get(flow, 'flow.src_ip_{{ vnf_num }}', '10.0.2.1-10.0.2.255') }}"
66 dstip4: "{{get(flow, 'flow.dst_ip_{{ vnf_num }}', '10.0.3.1-10.0.3.255') }}"
67 count: "{{get(flow, 'flow.count', '1') }}"
71 srcport: "{{get(flow, 'flow.src_port_{{ vnf_num }}', '1234-4321') }}"
72 dstport: "{{get(flow, 'flow.dst_port_{{ vnf_num }}', '2001-4001') }}"
73 count: "{{get(flow, 'flow.count', '1') }}"
74 downlink_{{ vnf_num }}:
76 id: {{ (vnf_num * 2) + 2 }}
79 64B: "{{ get(imix, 'imix.downlink.64B', '0') }}"
80 128B: "{{ get(imix, 'imix.downlink.128B', '0') }}"
81 256B: "{{ get(imix, 'imix.downlink.256B', '0') }}"
82 373b: "{{ get(imix, 'imix.downlink.373B', '0') }}"
83 512B: "{{ get(imix, 'imix.downlink.512B', '0') }}"
84 570B: "{{get(imix, 'imix.downlink.570B', '0') }}"
85 1024B: "{{get(imix, 'imix.downlink.1024B', '0') }}"
86 1280B: "{{get(imix, 'imix.downlink.1280B', '0') }}"
87 1400B: "{{get(imix, 'imix.downlink.1400B', '0') }}"
88 1500B: "{{get(imix, 'imix.downlink.1500B', '0') }}"
89 1518B: "{{get(imix, 'imix.downlink.1518B', '0') }}"
93 srcip4: "{{get(flow, 'flow.dst_ip_{{ vnf_num }}', '10.0.3.1-10.0.3.255') }}"
94 dstip4: "{{get(flow, 'flow.src_ip_{{ vnf_num }}', '10.0.2.1-10.0.2.255') }}"
95 count: "{{get(flow, 'flow.count', '1') }}"
99 srcport: "{{get(flow, 'flow.dst_port_{{ vnf_num }}', '1234-4321') }}"
100 dstport: "{{get(flow, 'flow.src_port_{{ vnf_num }}', '2001-4001') }}"
101 count: "{{get(flow, 'flow.count', '1') }}"