blob: 9f24236c1fc08de2c9875b32b58294a07a47559c [file] [log] [blame]
<PARAMS>
<testcases>1,2</testcases>
<GRAPH>
<nodeCluster>pairedleaves</nodeCluster>
<builds>20</builds>
<jobName>QOS</jobName>
<branch>master</branch>
</GRAPH>
<persistent_setup>True</persistent_setup>
<kubernetes>
<appName>onos-classic</appName>
<namespace>tost</namespace>
</kubernetes>
<use_stern>True</use_stern>
<UP4>
<s1u_address>10.32.11.126</s1u_address>
<slice_id>1</slice_id>
<enodebs>
<enodeb_1>
<host>TRexClient</host>
<enb_address>10.32.11.124</enb_address>
<interface>pairbond</interface> <!-- useless for this test, we use TRex to generate traffic -->
<ues>ue1,ue2</ues>
</enodeb_1>
</enodebs>
<ues>
<ue1>
<ue_address>10.240.0.1</ue_address>
<teid>100</teid>
<up_id>10</up_id>
<down_id>11</down_id>
<tc>0</tc> <!-- Best Effort -->
<five_g>False</five_g>
</ue1>
<ue2>
<ue_address>10.240.0.2</ue_address>
<teid>200</teid>
<up_id>20</up_id>
<down_id>21</down_id>
<tc>2</tc> <!-- Real Time -->
<five_g>False</five_g>
</ue2>
</ues>
<app_filters>
<allowPort>
<app_id>0</app_id>
<!-- Default ALLOW -->
<action>allow</action>
</allowPort>
</app_filters>
</UP4>
<TREX>
<port_stats>0,2,3</port_stats> <!-- TRex port 0 = PDN, TRex port 2 = eNodeB, TRex port 3 = second eNB -->
<flows>
<BE1_FROM_UE>
<name>Best Effort 1</name>
<l1_bps>40000000000</l1_bps>
<trex_port>2</trex_port>
<packet>
<pktlen>1400</pktlen>
<ip_src>10.240.0.1</ip_src>
<ip_dst>10.32.11.125</ip_dst>
<eth_src>40:A6:B7:22:AB:20</eth_src>
<eth_dst>00:00:0A:4C:1C:46</eth_dst>
<gtp_teid>100</gtp_teid>
<s1u_addr>10.32.11.126</s1u_addr>
<enb_addr>10.32.11.124</enb_addr>
</packet>
</BE1_FROM_UE>
<BE2_FROM_UE>
<name>Best Effort 2</name>
<l1_bps>35000000000</l1_bps>
<trex_port>3</trex_port>
<packet>
<pktlen>1400</pktlen>
<ip_src>10.240.0.1</ip_src>
<ip_dst>10.32.11.125</ip_dst>
<eth_src>40:A6:B7:22:AB:21</eth_src>
<eth_dst>00:00:0A:4C:1C:46</eth_dst>
<gtp_teid>100</gtp_teid>
<s1u_addr>10.32.11.126</s1u_addr>
<enb_addr>10.32.11.123</enb_addr>
</packet>
</BE2_FROM_UE>
<RT_FROM_UE>
<name>Real Time</name>
<l1_bps>22000000</l1_bps> <!-- Smaller than the smaller RT max BW -->
<trex_port>3</trex_port>
<packet>
<pktlen>1400</pktlen>
<ip_src>10.240.0.2</ip_src>
<ip_dst>10.32.11.125</ip_dst>
<eth_src>40:A6:B7:22:AB:21</eth_src>
<eth_dst>00:00:0A:4C:1C:46</eth_dst>
<gtp_teid>200</gtp_teid>
<s1u_addr>10.32.11.126</s1u_addr>
<enb_addr>10.32.11.123</enb_addr>
</packet>
<latency_stats>true</latency_stats>
<flow_id>10</flow_id>
<delay>50000</delay>
<expected_max_dropped>0</expected_max_dropped>
<expected_max_latency>1500</expected_max_latency>
<!-- Verify the 90th percentile instead of 99.9th because of latency introduced by TRex SW Mode -->
<expected_90_percentile_latency>200</expected_90_percentile_latency>
</RT_FROM_UE>
<BE_FROM_PDN>
<name>Best Effort</name>
<l1_bps>2000000000</l1_bps>
<trex_port>0</trex_port>
<packet>
<pktlen>1400</pktlen>
<ip_src>10.32.11.125</ip_src>
<ip_dst>10.240.0.1</ip_dst>
<eth_src>40:A6:B7:22:AB:40</eth_src>
<eth_dst>00:00:0A:4C:1C:46</eth_dst>
</packet>
</BE_FROM_PDN>
<RT_FROM_PDN>
<name>Real Time</name>
<l1_bps>22000000</l1_bps> <!-- Smaller than the smaller RT max BW -->
<trex_port>0</trex_port>
<packet>
<pktlen>1400</pktlen>
<ip_src>10.32.11.125</ip_src>
<ip_dst>10.240.0.2</ip_dst>
<eth_src>40:A6:B7:22:AB:40</eth_src>
<eth_dst>00:00:0A:4C:1C:46</eth_dst>
</packet>
<latency_stats>true</latency_stats>
<flow_id>10</flow_id> <!-- Mandatory when latency_stats=true -->
<delay>50000</delay> <!-- wait 50 ms till start to let queues fill up -->
<expected_min_received>1</expected_min_received>
<expected_max_dropped>0</expected_max_dropped>
<expected_99_9_percentile_latency>100</expected_99_9_percentile_latency>
</RT_FROM_PDN>
</flows>
</TREX>
<TOPO>
<switchNum>2</switchNum>
<linkNum>2</linkNum>
</TOPO>
<ONOS_Logging>
<org.onosproject.segmentrouting>DEBUG</org.onosproject.segmentrouting>
<org.omecproject.up4>TRACE</org.omecproject.up4>
</ONOS_Logging>
<ONOS_Logging_Reset>
<org.onosproject.segmentrouting>DEBUG</org.onosproject.segmentrouting>
<org.omecproject.up4>INFO</org.omecproject.up4>
</ONOS_Logging_Reset>
<ENV>
<cellName>productionCell</cellName>
<cellApps>drivers,fpm,lldpprovider,hostprovider,netcfghostprovider,drivers.bmv2,org.opencord.fabric-tofino,pipelines.fabric,org.stratumproject.fabric-tna,drivers.barefoot,segmentrouting,t3,up4</cellApps>
</ENV>
<DEPENDENCY>
<useCommonConf>False</useCommonConf>
<useCommonTopo>True</useCommonTopo>
<useBmv2>True</useBmv2>
<bmv2SwitchType>stratum</bmv2SwitchType>
<switchPrefix></switchPrefix>
<stratumRoot>~/stratum</stratumRoot>
<topology>trellis_fabric.py</topology>
<lib></lib>
</DEPENDENCY>
<SCALE>
<size>3</size>
<max>3</max>
</SCALE>
</PARAMS>