aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xhost/tests/devtest/benchmark_rate_test.py46
1 files changed, 27 insertions, 19 deletions
diff --git a/host/tests/devtest/benchmark_rate_test.py b/host/tests/devtest/benchmark_rate_test.py
index 598fbc8f0..56761f974 100755
--- a/host/tests/devtest/benchmark_rate_test.py
+++ b/host/tests/devtest/benchmark_rate_test.py
@@ -31,15 +31,16 @@ class uhd_benchmark_rate_test(uhd_example_test_case):
"""
Runs benchmark_rate with the given parameters. Parses output and writes
results to file.
-
- We always run both tx and rx.
"""
# rel_samp_err_threshold = 0.1 # 10% off is still quite generous
samp_rate = test_args.get('rate', 1e6)
duration = test_args.get('duration', 1)
chan = test_args.get('chan', '0')
n_chans = len(chan.split(","))
- expected_samples = n_chans * duration * samp_rate
+ expected_rx_samples = n_chans * duration * samp_rate \
+ if 'rx' in test_args.get('direction', '') else 0
+ expected_tx_samples = n_chans * duration * samp_rate \
+ if 'tx' in test_args.get('direction', '') else 0
self.log.info('Running test {n}, Channel = {c}, Sample Rate = {r}'.format(
n=test_name, c=chan, r=samp_rate,
))
@@ -59,35 +60,43 @@ class uhd_benchmark_rate_test(uhd_example_test_case):
if 'tx' in test_args.get('direction', ''):
args.append('--tx_rate')
args.append(str(samp_rate))
-
if 'rx' in test_args.get('direction', ''):
args.append('--rx_rate')
args.append(str(samp_rate))
(app, run_results) = self.run_example('benchmark_rate', args)
+
match = re.search(r'(Num received samples):\s*(.*)', app.stdout)
run_results['num_rx_samples'] = int(match.group(2)) if match else -1
- if run_results['num_rx_samples'] != -1:
- run_results['rel_rx_samples_error'] = 1.0 * abs(
- run_results['num_rx_samples']
- - test_args.get('rx_buffer', 0)
- - expected_samples
- ) / expected_samples
+ if expected_rx_samples != 0:
+ if run_results['num_rx_samples'] != -1:
+ run_results['rel_rx_samples_error'] = 1.0 * abs(
+ run_results['num_rx_samples']
+ - test_args.get('rx_buffer', 0)
+ - expected_rx_samples
+ ) / expected_rx_samples
+ else:
+ run_results['rel_rx_samples_error'] = 100
else:
- run_results['rel_rx_samples_error'] = 100
+ run_results['rel_rx_samples_error'] = 0 \
+ if run_results['num_rx_samples'] == 0 else 1
match = re.search(r'(Num dropped samples):\s*(.*)', app.stdout)
run_results['num_rx_dropped'] = int(match.group(2)) if match else -1
match = re.search(r'(Num overruns detected):\s*(.*)', app.stdout)
run_results['num_rx_overruns'] = int(match.group(2)) if match else -1
match = re.search(r'(Num transmitted samples):\s*(.*)', app.stdout)
run_results['num_tx_samples'] = int(match.group(2)) if match else -1
- if run_results['num_tx_samples'] != -1:
- run_results['rel_tx_samples_error'] = 1.0 * abs(
- run_results['num_tx_samples']
- - test_args.get('tx_buffer', 0)
- - expected_samples
- ) / expected_samples
+ if expected_tx_samples != 0:
+ if run_results['num_tx_samples'] != -1:
+ run_results['rel_tx_samples_error'] = 1.0 * abs(
+ run_results['num_tx_samples']
+ - test_args.get('tx_buffer', 0)
+ - expected_tx_samples
+ ) / expected_tx_samples
+ else:
+ run_results['rel_tx_samples_error'] = 100
else:
- run_results['rel_tx_samples_error'] = 100
+ run_results['rel_tx_samples_error'] = 0 \
+ if run_results['num_tx_samples'] == 0 else 1
match = re.search(r'(Num sequence errors \(Tx\)):\s*(.*)', app.stdout)
run_results['num_tx_seqerrs'] = int(match.group(2)) if match else -1
match = re.search(r'(Num underruns detected):\s*(.*)', app.stdout)
@@ -107,4 +116,3 @@ class uhd_benchmark_rate_test(uhd_example_test_case):
])
self.report_example_results(test_name, run_results)
return run_results
-