1 # Copyright (c) 2016-2019 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 vports = get(extra_args, 'vports', 2) %}
38 schema: "nsb:traffic_profile:0.1"
40 # This file is a template, it will be filled with values from tc.yaml before passing to the traffic generator
43 description: Traffic profile to run RFC2544 latency
45 traffic_type: RFC2544Profile # defines traffic behavior - constant or look for highest possible throughput
46 frame_rate: 100 # pc of linerate
47 duration: {{ duration }}
49 {% for vport in range((vports / 2)|int) %}
52 id: {{ (vport * 2) + 1 }}
55 64B: "{{ get(imix, 'imix.uplink.64B', '0') }}"
56 128B: "{{ get(imix, 'imix.uplink.128B', '0') }}"
57 256B: "{{ get(imix, 'imix.uplink.256B', '0') }}"
58 373b: "{{ get(imix, 'imix.uplink.373B', '0') }}"
59 512B: "{{ get(imix, 'imix.uplink.512B', '0') }}"
60 570B: "{{ get(imix, 'imix.uplink.570B', '0') }}"
61 1024B: "{{get(imix, 'imix.uplink.1024B', '0') }}"
62 1400B: "{{ get(imix, 'imix.uplink.1400B', '0') }}"
63 1500B: "{{ get(imix, 'imix.uplink.1500B', '0') }}"
64 1518B: "{{ get(imix, 'imix.uplink.1518B', '0') }}"
67 srcip4: {{ get(flow, 'flow.src_ip_%s'| format(vport), '1.%s.1.1-1.%s.255.255'| format(vport, vport)) }}
68 dstip4: {{ get(flow, 'flow.dst_ip_%s'| format(vport), '90.%s.1.1-90.%s.255.255'| format(vport, vport)) }}
69 count: {{ get(flow, 'flow.count', '1') }}
73 srcport: {{ get(flow, 'flow.src_port_%s'| format(vport), '1234-4321') }}
74 dstport: {{ get(flow, 'flow.dst_port_%s'| format(vport), '2001-4001') }}
75 count: {{ get(flow, 'flow.count', '1') }}
78 id: {{ (vport * 2) + 2}}
81 64B: "{{ get(imix, 'imix.downlink.64B', '0') }}"
82 128B: "{{ get(imix, 'imix.downlink.128B', '0') }}"
83 256B: "{{ get(imix, 'imix.downlink.256B', '0') }}"
84 373b: "{{ get(imix, 'imix.downlink.373B', '0') }}"
85 512B: "{{ get(imix, 'imix.downlink.512B', '0') }}"
86 570B: "{{ get(imix, 'imix.downlink.570B', '0') }}"
87 1024B: "{{get(imix, 'imix.downlink.1024B', '0') }}"
88 1400B: "{{ get(imix, 'imix.downlink.1400B', '0') }}"
89 1500B: "{{ get(imix, 'imix.downlink.1500B', '0') }}"
90 1518B: "{{ get(imix, 'imix.downlink.1518B', '0') }}"
94 srcip4: {{ get(flow, 'flow.dst_ip_%s'| format(vport), '90.%s.1.1-90.%s.255.255'| format(vport, vport)) }}
95 dstip4: {{ get(flow, 'flow.src_ip_%s'| format(vport), '1.%s.1.1-1.%s.255.255'| format(vport, vport)) }}
96 count: {{ get(flow, 'flow.count', '1') }}
100 srcport: {{ get(flow, 'flow.dst_port_%s'| format(vport), '1234-4321') }}
101 dstport: {{ get(flow, 'flow.src_port_%s'| format(vport), '2001-4001') }}
102 count: {{ get(flow, 'flow.count', '1') }}