2022-05-21 23:04:17 +00:00
|
|
|
"""
|
|
|
|
Tests a high signal-to-noise ratio path with codec2 data formats.
|
|
|
|
"""
|
|
|
|
|
|
|
|
# pylint: disable=global-statement, invalid-name, unused-import
|
|
|
|
|
2022-06-12 19:03:45 +00:00
|
|
|
import multiprocessing
|
2022-05-21 23:04:17 +00:00
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
import sys
|
2022-06-12 19:03:45 +00:00
|
|
|
import time
|
2022-05-21 23:04:17 +00:00
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
try:
|
|
|
|
BURSTS = int(os.environ["BURSTS"])
|
|
|
|
FRAMESPERBURST = int(os.environ["FRAMESPERBURST"])
|
|
|
|
TESTFRAMES = int(os.environ["TESTFRAMES"])
|
|
|
|
except KeyError:
|
|
|
|
BURSTS = 1
|
|
|
|
FRAMESPERBURST = 1
|
|
|
|
TESTFRAMES = 3
|
|
|
|
|
2022-05-29 13:03:25 +00:00
|
|
|
# For some reason, sometimes, this test requires the current directory to be `test`.
|
|
|
|
# Try to adapt dynamically. I still want to figure out why but as a workaround,
|
|
|
|
# I'm not completely dissatisfied.
|
|
|
|
if os.path.exists("test"):
|
|
|
|
os.chdir("test")
|
|
|
|
|
2022-05-21 23:04:17 +00:00
|
|
|
|
2022-06-12 19:03:45 +00:00
|
|
|
def t_HighSNR_P_P_DATACx(bursts: int, frames_per_burst: int, mode: str):
|
2022-05-21 23:04:17 +00:00
|
|
|
"""
|
|
|
|
Test a high signal-to-noise ratio path with Codec2 modes.
|
|
|
|
|
|
|
|
:param bursts: Number of bursts
|
|
|
|
:type bursts: str
|
|
|
|
:param frames_per_burst: Number of frames transmitted per burst
|
|
|
|
:type frames_per_burst: str
|
|
|
|
"""
|
|
|
|
# Facilitate running from main directory as well as inside test/
|
2022-05-20 20:31:42 +00:00
|
|
|
tx_side = "util_tx.py"
|
|
|
|
rx_side = "util_rx.py"
|
2022-05-21 23:04:17 +00:00
|
|
|
if os.path.exists("test") and os.path.exists(os.path.join("test", tx_side)):
|
|
|
|
tx_side = os.path.join("test", tx_side)
|
|
|
|
rx_side = os.path.join("test", rx_side)
|
|
|
|
os.environ["PYTHONPATH"] += ":."
|
|
|
|
|
2022-05-29 00:32:35 +00:00
|
|
|
print(f"{tx_side=} / {rx_side=}")
|
|
|
|
|
2022-05-21 23:04:17 +00:00
|
|
|
with subprocess.Popen(
|
|
|
|
args=[
|
|
|
|
"python3",
|
|
|
|
tx_side,
|
|
|
|
"--mode",
|
|
|
|
mode,
|
|
|
|
"--delay",
|
|
|
|
"500",
|
|
|
|
"--framesperburst",
|
|
|
|
str(frames_per_burst),
|
|
|
|
"--bursts",
|
|
|
|
str(bursts),
|
|
|
|
],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE,
|
|
|
|
) as transmit:
|
|
|
|
|
|
|
|
with subprocess.Popen(
|
|
|
|
args=[
|
|
|
|
"python3",
|
|
|
|
rx_side,
|
|
|
|
"--mode",
|
|
|
|
mode,
|
|
|
|
"--framesperburst",
|
|
|
|
str(frames_per_burst),
|
|
|
|
"--bursts",
|
|
|
|
str(bursts),
|
|
|
|
"--timeout",
|
|
|
|
"20",
|
|
|
|
],
|
|
|
|
stdin=transmit.stdout,
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.STDOUT,
|
|
|
|
) as receive:
|
|
|
|
assert receive.stdout
|
|
|
|
lastline = "".join(
|
|
|
|
[
|
|
|
|
str(line, "UTF-8")
|
|
|
|
for line in receive.stdout.readlines()
|
|
|
|
if "RECEIVED " in str(line, "UTF-8")
|
|
|
|
]
|
|
|
|
)
|
|
|
|
assert f"RECEIVED BURSTS: {bursts}" in lastline
|
|
|
|
assert f"RECEIVED FRAMES: {frames_per_burst * bursts}" in lastline
|
|
|
|
assert "RX_ERRORS: 0" in lastline
|
|
|
|
print(lastline)
|
|
|
|
|
|
|
|
|
2022-06-12 19:03:45 +00:00
|
|
|
@pytest.mark.parametrize("bursts", [BURSTS, 2, 3])
|
|
|
|
@pytest.mark.parametrize("frames_per_burst", [FRAMESPERBURST, 2, 3])
|
|
|
|
@pytest.mark.parametrize("mode", ["datac0", "datac1", "datac3"])
|
|
|
|
def test_HighSNR_P_P_DATACx(bursts: int, frames_per_burst: int, mode: str):
|
|
|
|
proc = multiprocessing.Process(
|
|
|
|
target=t_HighSNR_P_P_DATACx,
|
|
|
|
args=[bursts, frames_per_burst, mode],
|
|
|
|
daemon=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
proc.start()
|
|
|
|
|
|
|
|
# Set timeout
|
|
|
|
timeout = time.time() + 5
|
|
|
|
|
|
|
|
while time.time() < timeout:
|
|
|
|
time.sleep(0.1)
|
|
|
|
|
|
|
|
if proc.is_alive():
|
|
|
|
proc.terminate()
|
|
|
|
assert 0, "Timeout waiting for test to complete."
|
|
|
|
|
|
|
|
proc.join()
|
|
|
|
proc.terminate()
|
|
|
|
|
|
|
|
assert proc.exitcode == 0
|
|
|
|
proc.close()
|
|
|
|
|
|
|
|
|
2022-05-21 23:04:17 +00:00
|
|
|
if __name__ == "__main__":
|
|
|
|
# Run pytest with the current script as the filename.
|
|
|
|
ecode = pytest.main(["-v", "-s", sys.argv[0]])
|
|
|
|
if ecode == 0:
|
|
|
|
print("errors: 0")
|
|
|
|
else:
|
|
|
|
print(ecode)
|