<p>Alejandro Leal has uploaded this change for <strong>review</strong>.</p><p><a href="https://gerrit.osmocom.org/c/osmo-gsm-tester/+/24274">View Change</a></p><pre style="font-family: monospace,monospace; white-space: pre-wrap;">4g-iperf3-ul: modified the test to parameterize the number of ue in the test.<br><br>Parameterize the iperf3 uplink test for the 4g test suite to execute a<br>given number of UEs. By default, the number of ue is 1.<br><br>Change-Id: I4b006df04bd1af6c117bcb25e6a6b1609ac732fb<br>---<br>M sysmocom/suites/4g/iperf3_ul.py<br>1 file changed, 73 insertions(+), 23 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">git pull ssh://gerrit.osmocom.org:29418/osmo-gsm-tester refs/changes/74/24274/1</pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/sysmocom/suites/4g/iperf3_ul.py b/sysmocom/suites/4g/iperf3_ul.py</span><br><span>index e243774..541b0d0 100755</span><br><span>--- a/sysmocom/suites/4g/iperf3_ul.py</span><br><span>+++ b/sysmocom/suites/4g/iperf3_ul.py</span><br><span>@@ -1,48 +1,98 @@</span><br><span> #!/usr/bin/env python3</span><br><span> from osmo_gsm_tester.testenv import *</span><br><span> import os</span><br><span style="color: hsl(120, 100%, 40%);">+import threading</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+def run_iperf(proc):</span><br><span style="color: hsl(120, 100%, 40%);">+  proc.launch_sync()</span><br><span> </span><br><span> # Overlay suite-specific templates folder if it exists</span><br><span> if os.path.isdir(os.path.join(os.path.dirname(__file__), 'templates')):</span><br><span>   tenv.set_overlay_template_dir(os.path.join(os.path.dirname(__file__), 'templates'))</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+# Retrieve the number of physical ue from the test suite configuration.</span><br><span style="color: hsl(120, 100%, 40%);">+test_config = tenv.config_test_specific()</span><br><span style="color: hsl(120, 100%, 40%);">+nof_ue = int(test_config.get("nof_physical_ue", 1))</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+print(f'Number of physical ue: {nof_ue}')</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+ue = []</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+# Get the ue from the test configuration.</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  ue.append(tenv.modem())</span><br><span style="color: hsl(120, 100%, 40%);">+  print(f'ue index{n}: {ue[n]}')</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> epc = tenv.epc()</span><br><span> enb = tenv.enb()</span><br><span style="color: hsl(0, 100%, 40%);">-ue = tenv.modem()</span><br><span style="color: hsl(0, 100%, 40%);">-iperf3srv = tenv.iperf3srv({'addr': epc.tun_addr()})</span><br><span style="color: hsl(0, 100%, 40%);">-iperf3srv.set_run_node(epc.run_node())</span><br><span style="color: hsl(0, 100%, 40%);">-iperf3cli = iperf3srv.create_client()</span><br><span style="color: hsl(0, 100%, 40%);">-iperf3cli.set_run_node(ue.run_node())</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-epc.subscriber_add(ue)</span><br><span style="color: hsl(120, 100%, 40%);">+iperf3srv = []</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  iperf3srv.append(tenv.iperf3srv({'addr': epc.tun_addr()}, n))</span><br><span style="color: hsl(120, 100%, 40%);">+  iperf3srv[n].set_run_node(epc.run_node())</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+# Set the iperf clients in the ue.</span><br><span style="color: hsl(120, 100%, 40%);">+iperf3cli = []</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  iperf3cli.append(iperf3srv[n].create_client())</span><br><span style="color: hsl(120, 100%, 40%);">+  iperf3cli[n].set_run_node(ue[n].run_node())</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  epc.subscriber_add(ue[n])</span><br><span> epc.start()</span><br><span style="color: hsl(0, 100%, 40%);">-enb.ue_add(ue)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  enb.ue_add(ue[n])</span><br><span> enb.start(epc)</span><br><span> </span><br><span> print('waiting for ENB to connect to EPC...')</span><br><span> wait(epc.enb_is_connected, enb)</span><br><span> print('ENB is connected to EPC')</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-ue.connect(enb)</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  ue[n].connect(enb)</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-max_rate = enb.ue_max_rate(downlink=False, num_carriers=ue.num_carriers)</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  iperf3srv[n].start()</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-iperf3srv.start()</span><br><span style="color: hsl(0, 100%, 40%);">-proc = iperf3cli.prepare_test_proc(iperf3cli.DIR_UL, ue.netns(), bitrate=max_rate)</span><br><span style="color: hsl(120, 100%, 40%);">+proc = []</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-print('waiting for UE to attach...')</span><br><span style="color: hsl(0, 100%, 40%);">-wait(ue.is_registered)</span><br><span style="color: hsl(0, 100%, 40%);">-print('UE is attached')</span><br><span style="color: hsl(120, 100%, 40%);">+# Attach all the ue's.</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  max_rate = enb.ue_max_rate(downlink=False, num_carriers=ue[n].num_carriers)</span><br><span style="color: hsl(120, 100%, 40%);">+  client = iperf3cli[n].prepare_test_proc(iperf3cli[n].DIR_UL, ue[n].netns(), bitrate=max_rate)</span><br><span style="color: hsl(120, 100%, 40%);">+  print(f'Iperf client type: {type(client)}')</span><br><span style="color: hsl(120, 100%, 40%);">+  proc.append(client)</span><br><span style="color: hsl(120, 100%, 40%);">+  print(f'waiting for UE {n} to attach...')</span><br><span style="color: hsl(120, 100%, 40%);">+  wait(ue[n].is_registered)</span><br><span style="color: hsl(120, 100%, 40%);">+  print(f'UE {n} is attached')</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-print("Running iperf3 client to %s through %s" % (str(iperf3cli), ue.netns()))</span><br><span style="color: hsl(0, 100%, 40%);">-proc.launch_sync()</span><br><span style="color: hsl(0, 100%, 40%);">-iperf3srv.stop()</span><br><span style="color: hsl(120, 100%, 40%);">+# Start every iperf client.</span><br><span style="color: hsl(120, 100%, 40%);">+threads = []</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  print("Running iperf3 %u client to %s through %s" % (n, str(iperf3cli[n]), ue[n].netns()))</span><br><span style="color: hsl(120, 100%, 40%);">+  threads.append(threading.Thread(target=run_iperf, args=(proc[n],)))</span><br><span style="color: hsl(120, 100%, 40%);">+  threads[n].start()</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-iperf3cli.print_results()</span><br><span style="color: hsl(0, 100%, 40%);">-iperf3srv.print_results(iperf3cli.proto() == iperf3cli.PROTO_UDP)</span><br><span style="color: hsl(120, 100%, 40%);">+# Wait for all the iperfs to finish.</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  threads[n].join()</span><br><span style="color: hsl(120, 100%, 40%);">+  print(f'Iperf {n} finished')</span><br><span style="color: hsl(120, 100%, 40%);">+  iperf3srv[n].stop()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  iperf3cli[n].print_results() </span><br><span style="color: hsl(120, 100%, 40%);">+  iperf3srv[n].print_results(iperf3cli[n].proto() == iperf3cli[n].PROTO_UDP)</span><br><span> </span><br><span> # 80% of the maximum rate for half of the test duration</span><br><span style="color: hsl(0, 100%, 40%);">-half_duration = int(round(iperf3cli.time_sec() / 2))</span><br><span style="color: hsl(0, 100%, 40%);">-res_str = ue.verify_metric(max_rate * 0.8, operation='max_rolling_avg', metric='ul_brate', criterion='gt', window=half_duration)</span><br><span style="color: hsl(0, 100%, 40%);">-print(res_str)</span><br><span style="color: hsl(0, 100%, 40%);">-test.set_report_stdout(res_str)</span><br><span style="color: hsl(120, 100%, 40%);">+out = ''</span><br><span style="color: hsl(120, 100%, 40%);">+for n in range(0, nof_ue):</span><br><span style="color: hsl(120, 100%, 40%);">+  half_duration = int(round(iperf3cli[n].time_sec() / 2))</span><br><span style="color: hsl(120, 100%, 40%);">+  max_rate = enb.ue_max_rate(downlink=False, num_carriers=ue[n].num_carriers)</span><br><span style="color: hsl(120, 100%, 40%);">+  res_str = ue[n].verify_metric(max_rate * 0.8, operation='max_rolling_avg', metric='ul_brate', criterion='gt', window=half_duration)</span><br><span style="color: hsl(120, 100%, 40%);">+  print(res_str)</span><br><span style="color: hsl(120, 100%, 40%);">+  out += res_str</span><br><span style="color: hsl(120, 100%, 40%);">+  if n != nof_ue - 1:</span><br><span style="color: hsl(120, 100%, 40%);">+    out += '\n'</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+test.set_report_stdout(out)</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.osmocom.org/c/osmo-gsm-tester/+/24274">change 24274</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.osmocom.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.osmocom.org/c/osmo-gsm-tester/+/24274"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: osmo-gsm-tester </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-Change-Id: I4b006df04bd1af6c117bcb25e6a6b1609ac732fb </div>
<div style="display:none"> Gerrit-Change-Number: 24274 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: Alejandro Leal <alejandro.leal@srs.io> </div>
<div style="display:none"> Gerrit-MessageType: newchange </div>