1 #jinja2:variable_start_string:'[[', variable_end_string:']]', block_start_string:'[%', block_end_string:'%]'
2 # Copyright (c) 2016-2017 Intel Corporation
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
8 # http://www.apache.org/licenses/LICENSE-2.0
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
16 # flow definition for ACL tests - 1K flows - ipv4 only
18 # the number of flows defines the widest range of parameters
19 # 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
20 # and it should define only 16 flows
22 # there is assumption that packets generated will have a random sequences of following addresses pairs
24 # 1. src=1.x.x.x(x.x.x =random from 1..255) dst=10.x.x.x (random from 1..512)
25 # 2. src=1.x.x.x(x.x.x =random from 1..255) dst=10.x.x.x (random from 1..512)
27 # 512. src=1.x.x.x(x.x.x =random from 1..255) dst=10.x.x.x (random from 1..512)
29 # not all combination should be filled
30 # Any other field with random range will be added to flow definition
32 # the example.yaml provides all possibilities for traffic generation
34 # the profile defines a public and private side to make limited traffic correlation
35 # between private and public side same way as it is made by IXIA solution.
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: IXIARFC2544Profile # defines traffic behavior - constant or look for highest possible throughput
46 frame_rate: 100 # pc of linerate
47 duration: {{ duration }}
49 [% for vnf_num in range(num_vnfs|int) %]
52 id: [[vnf_num * 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 1400B: "{{get(imix, 'imix.uplink.1400B', '0') }}"
62 1500B: "{{get(imix, 'imix.uplink.1500B', '0') }}"
63 1518B: "{{get(imix, 'imix.uplink.1518B', '0') }}"
66 srcip4: "{{get(flow, 'flow.src_ip_[[ vnf_num ]]', '1.1.1.1-1.1.255.255') }}"
67 dstip4: "{{get(flow, 'flow.dst_ip_[[ vnf_num ]]', '90.90.1.1-90.90.255.255') }}"
68 count: "{{get(flow, 'flow.count', '1') }}"
72 srcport: "{{get(flow, 'flow.src_port_[[ vnf_num ]]', '1234-4321') }}"
73 dstport: "{{get(flow, 'flow.dst_port_[[ vnf_num ]]', '2001-4001') }}"
74 count: "{{get(flow, 'flow.count', '1') }}"
75 downlink_[[ vnf_num ]]:
77 id: [[vnf_num * 2 + 2]]
80 64B: "{{ get(imix, 'imix.downlink.64B', '0') }}"
81 128B: "{{ get(imix, 'imix.downlink.128B', '0') }}"
82 256B: "{{ get(imix, 'imix.downlink.256B', '0') }}"
83 373b: "{{ get(imix, 'imix.downlink.373B', '0') }}"
84 512B: "{{ get(imix, 'imix.downlink.512B', '0') }}"
85 570B: "{{get(imix, 'imix.downlink.570B', '0') }}"
86 1400B: "{{get(imix, 'imix.downlink.1400B', '0') }}"
87 1500B: "{{get(imix, 'imix.downlink.1500B', '0') }}"
88 1518B: "{{get(imix, 'imix.downlink.1518B', '0') }}"
91 srcip4: "{{get(flow, 'flow.dst_ip_[[ vnf_num ]]', '90.90.1.1-90.90.255.255') }}"
92 dstip4: "{{get(flow, 'flow.public_ip_[[ vnf_num ]]', '1.1.1.1-1.1.255.255') }}"
93 count: "{{get(flow, 'flow.count', '1') }}"
97 srcport: "{{get(flow, 'flow.dst_port_[[ vnf_num ]]', '1234-4321') }}"
98 dstport: "{{get(flow, 'flow.src_port_[[ vnf_num ]]', '2001-4001') }}"
99 count: "{{get(flow, 'flow.count', '1') }}"