Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

change scos-actions, scos-tekrsa versions, don't check usb if using m… #272

Merged
merged 20 commits into from
May 21, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
b467fb9
change scos-actions, scos-tekrsa versions, don't check usb if using m…
jhazentia Feb 20, 2024
370625d
include scos-actions in plugins, use scos_actions test actions for te…
jhazentia Feb 29, 2024
dbcfbfb
Merge branch 'master' of https://github.com/NTIA/scos-sensor into SEA…
jhazentia Feb 29, 2024
15fb770
add GPS to env.template
jhazentia Feb 29, 2024
d3e6926
switch plugin to scos-tekrsa, autoformat files
jhazentia Mar 5, 2024
832c4e3
Merge branch 'master' of https://github.com/NTIA/scos-sensor into SEA…
jhazentia Mar 7, 2024
9409fa0
fix scos_sigan_plugin software version
jhazentia Mar 11, 2024
a3e41ea
fix double import of scos_actions
jhazentia Mar 15, 2024
554a090
remove sigan from gps constructor
jhazentia Apr 4, 2024
0a0a150
Merge branch 'master' of https://github.com/NTIA/scos-sensor into SEA…
jhazentia Apr 4, 2024
903750d
formatting, always load scos_actions test actions when using mock, lo…
jhazentia Apr 8, 2024
6c73123
separate gps loading from sigan loading in sensor_loader
jhazentia Apr 8, 2024
0e82379
remove "clock_rate_lookup_by_sample_rate" from readme example
jhazentia Apr 11, 2024
0ac1f8e
fix bug in action loader
jhazentia Apr 16, 2024
039aa4a
In tests replace logger action with test_monitor_sigan, update scos-a…
jhazentia Apr 26, 2024
ba07fe1
update requirements
jhazentia Apr 29, 2024
30d3296
remove oauthlib packages from requirements
jhazentia May 1, 2024
e817ddc
update scos-tekrsa version
jhazentia May 9, 2024
39d6c81
update scos-tekrsa to 7.0.1, scos-actions to 10.0.2
jhazentia May 15, 2024
bbda375
merge "master" into "SEA-178_test_actions_loading"
jhazentia May 15, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -477,7 +477,6 @@ level setting of -25.
"frequency",
"reference_level"
],
"clock_rate_lookup_by_sample_rate": [],
"calibration_data": {
"14000000.0": {
"3545000000.0": {
Expand Down
2 changes: 2 additions & 0 deletions compose.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,8 @@ services:
- ENCRYPTION_KEY
- FQDN
- GIT_BRANCH
- GPS_MODULE
- GPS_CLASS
- GUNICORN_LOG_LEVEL
- IN_DOCKER=1
- IPS
Expand Down
3 changes: 1 addition & 2 deletions docs/openapi.json
Original file line number Diff line number Diff line change
Expand Up @@ -1644,10 +1644,9 @@
"description": "[Required] The name of the action to be scheduled",
"type": "string",
"enum": [
"logger",
"test_SEA_CBRS_Measure_Baseline",
"test_monitor_sigan",
"test_multi_frequency_iq_action",
"test_nasctn_sea_data_product",
"test_single_frequency_iq_action",
"test_single_frequency_m4s_action",
"test_survey_iq_action",
Expand Down
2 changes: 2 additions & 0 deletions env.template
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,8 @@ ENCRYPTION_KEY="$(python3 -c 'import secrets; import base64; print(base64.b64enc
FQDN="$(hostname -f)"

GIT_BRANCH="git:$(git rev-parse --abbrev-ref HEAD)@$(git rev-parse --short HEAD)"
GPS_MODULE=""
GPS_CLASS=""

IPS="$(hostname -I) 127.0.0.1"

Expand Down
20 changes: 16 additions & 4 deletions src/initialization/action_loader.py
Original file line number Diff line number Diff line change
Expand Up @@ -95,14 +95,22 @@ def load_actions(
}
logger.debug(discovered_plugins)
actions = {}
if mock_sigan or running_tests:
if running_tests:
logger.debug(f"Loading {len(test_actions)} test actions.")
actions.update(test_actions)
else:
# load scos-actions test_actions
if mock_sigan:
logger.debug(f"Loading {len(test_actions)} test actions.")
actions.update(test_actions)
# load other plugin actions
for name, module in discovered_plugins.items():
logger.debug("Looking for actions in " + name + ": " + str(module))
discover = importlib.import_module(name + ".discover")
if hasattr(discover, "actions"):
if mock_sigan and hasattr(discover, "test_actions"):
logger.debug(f"loading {len(discover.test_actions)} test actions.")
actions.update(discover.test_actions)
elif hasattr(discover, "actions"):
logger.debug(f"loading {len(discover.actions)} actions.")
actions.update(discover.actions)
if (
Expand All @@ -111,10 +119,14 @@ def load_actions(
):
action_classes.update(discover.action_classes)

# load scos-sensor configs/actions
logger.debug(f"Loading actions in {action_dir}")
yaml_actions, yaml_test_actions = init(
action_classes=action_classes, yaml_dir=action_dir
)
actions.update(yaml_actions)
logger.debug("Finished loading and registering actions")
if mock_sigan:
actions.update(yaml_test_actions)
else:
actions.update(yaml_actions)
logger.debug("Finished loading and registering actions")
return actions
16 changes: 16 additions & 0 deletions src/initialization/sensor_loader.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ def load_sensor(
)

sigan = None
gps = None
try:
if not settings.RUNNING_MIGRATIONS:
if get_usb_device_exists():
Expand All @@ -77,6 +78,20 @@ def load_sensor(
logger.warning(f"unable to create signal analyzer: {ex}")
set_container_unhealthy()

try:
if settings.GPS_MODULE and settings.GPS_CLASS:
gps_module_setting = settings.GPS_MODULE
gps_module = importlib.import_module(gps_module_setting)
logger.info(
"Creating " + settings.GPS_CLASS + " from " + settings.GPS_MODULE
)
gps_constructor = getattr(gps_module, settings.GPS_CLASS)
gps = gps_constructor()
else:
logger.info("GPS_MODULE and/or GPS_CLASS not specified. Not loading GPS.")
except BaseException as ex:
logger.warning(f"unable to create GPS: {ex}")

# Create sensor before handling calibrations
sensor = Sensor(
signal_analyzer=sigan,
Expand All @@ -85,6 +100,7 @@ def load_sensor(
preselector=preselector,
switches=switches,
location=location,
gps=gps,
sensor_cal=None,
differential_cal=None,
)
Expand Down
13 changes: 3 additions & 10 deletions src/requirements-dev.txt
Original file line number Diff line number Diff line change
Expand Up @@ -184,10 +184,6 @@ numpy==1.24.4
# tekrsa-api-wrap
nvidia-ml-py==12.535.133
# via gpustat
oauthlib==3.2.2
# via
# -r requirements.txt
# requests-oauthlib
opencensus==0.11.3
# via ray
opencensus-context==0.1.3
Expand Down Expand Up @@ -292,11 +288,8 @@ requests==2.31.0
# its-preselector
# ray
# requests-mock
# requests-oauthlib
requests-mock==1.11.0
# via -r requirements.txt
requests-oauthlib==1.3.1
# via -r requirements.txt
rpds-py==0.13.2
# via
# -r requirements.txt
Expand All @@ -316,11 +309,11 @@ scipy==1.10.1
# via
# -r requirements.txt
# scos-actions
scos-actions @ git+https://github.com/NTIA/scos-actions@9.0.0
scos-actions @ git+https://github.com/NTIA/scos-actions@10.0.2
# via
# -r requirements.txt
# scos-tekrsa
scos-tekrsa @ git+https://github.com/NTIA/scos-tekrsa@6.0.0
scos-tekrsa @ git+https://github.com/NTIA/scos-tekrsa@7.0.1
# via -r requirements.txt
sigmf @ git+https://github.com/NTIA/SigMF@multi-recording-archive
# via
Expand All @@ -340,7 +333,7 @@ sqlparse==0.5.0
# via
# -r requirements.txt
# django
tekrsa-api-wrap==1.3.2
tekrsa-api-wrap==1.3.3
# via
# -r requirements.txt
# scos-tekrsa
Expand Down
3 changes: 1 addition & 2 deletions src/requirements.in
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,7 @@ jsonfield>=3.0, <4.0
packaging>=23.0, <24.0
psycopg2-binary>=2.0, <3.0
requests-mock>=1.0, <2.0
requests_oauthlib>=1.0, <2.0
scos_tekrsa @ git+https://github.com/NTIA/[email protected]
scos_tekrsa @ git+https://github.com/NTIA/[email protected]

# The following are sub-dependencies for which SCOS Sensor enforces a
# higher minimum patch version than the dependencies which require them.
Expand Down
11 changes: 3 additions & 8 deletions src/requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -93,8 +93,6 @@ numpy==1.24.4
# scos-actions
# sigmf
# tekrsa-api-wrap
oauthlib==3.2.2
# via requests-oauthlib
packaging==23.2
# via
# -r requirements.in
Expand Down Expand Up @@ -137,11 +135,8 @@ requests==2.31.0
# its-preselector
# ray
# requests-mock
# requests-oauthlib
requests-mock==1.11.0
# via -r requirements.in
requests-oauthlib==1.3.1
# via -r requirements.in
rpds-py==0.13.2
# via
# jsonschema
Expand All @@ -152,9 +147,9 @@ ruamel-yaml-clib==0.2.8
# via ruamel-yaml
scipy==1.10.1
# via scos-actions
scos-actions @ git+https://github.com/NTIA/scos-actions@9.0.0
scos-actions @ git+https://github.com/NTIA/scos-actions@10.0.2
# via scos-tekrsa
scos-tekrsa @ git+https://github.com/NTIA/scos-tekrsa@6.0.0
scos-tekrsa @ git+https://github.com/NTIA/scos-tekrsa@7.0.1
# via -r requirements.in
sigmf @ git+https://github.com/NTIA/SigMF@multi-recording-archive
# via scos-actions
Expand All @@ -168,7 +163,7 @@ sqlparse==0.5.0
# via
# -r requirements.in
# django
tekrsa-api-wrap==1.3.2
tekrsa-api-wrap==1.3.3
# via scos-tekrsa
typing-extensions==4.8.0
# via asgiref
Expand Down
42 changes: 24 additions & 18 deletions src/schedule/tests/test_models.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
def test_take_until(test_input, future_t, expected):
start, stop, interval = test_input
entry = ScheduleEntry(
name="t", start=start, stop=stop, interval=interval, action="logger"
name="t", start=start, stop=stop, interval=interval, action="test_monitor_sigan"
)
initial_times = list(entry.get_remaining_times())
r = []
Expand All @@ -32,32 +32,36 @@ def test_take_until(test_input, future_t, expected):


def test_undefined_start_is_now():
entry = ScheduleEntry(name="t", action="logger")
entry = ScheduleEntry(name="t", action="test_monitor_sigan")
now = utils.timefn()
assert entry.start in (now - 1, now, now + 1)


def test_undefined_stop_is_never():
entry = ScheduleEntry(name="t", action="logger", interval=1)
entry = ScheduleEntry(name="t", action="test_monitor_sigan", interval=1)
assert entry.stop is None
assert type(entry.get_remaining_times()) is itertools.count


def test_relative_stop_becomes_absolute():
e = ScheduleEntry(name="t", start=20, relative_stop=10, interval=1, action="logger")
e = ScheduleEntry(
name="t", start=20, relative_stop=10, interval=1, action="test_monitor_sigan"
)
assert e.start == 20
assert e.stop == 30
assert list(e.get_remaining_times()) == list(range(20, 30, 1))


def test_stop_before_start():
e = ScheduleEntry(name="t", start=20, stop=10, interval=1, action="logger")
e = ScheduleEntry(
name="t", start=20, stop=10, interval=1, action="test_monitor_sigan"
)
assert list(e.get_remaining_times()) == list(range(0))


def test_no_interval_is_one_shot():
"""Leaving `interval` blank should indicate "one-shot" entry."""
e = ScheduleEntry(name="t", action="logger")
e = ScheduleEntry(name="t", action="test_monitor_sigan")
remaining_times = list(e.get_remaining_times())
assert len(remaining_times) == 1

Expand All @@ -72,7 +76,7 @@ def test_no_interval_is_one_shot():

def test_no_interval_with_start_is_one_shot():
"""Specifying start should not affect number of times."""
e = ScheduleEntry(name="t", action="logger", start=1)
e = ScheduleEntry(name="t", action="test_monitor_sigan", start=1)
remaining_times = list(e.get_remaining_times())
assert len(remaining_times) == 1

Expand All @@ -88,17 +92,19 @@ def test_no_interval_with_start_is_one_shot():
def test_no_interval_future_start(testclock):
"""One-shot entry should wait for start."""
# recall current t=0 so start=1 is 1 second in the future
e = ScheduleEntry(name="t", action="logger", start=1)
e = ScheduleEntry(name="t", action="test_monitor_sigan", start=1)
assert not e.take_pending()


def test_bad_interval_raises():
with pytest.raises(ValidationError):
ScheduleEntry(name="t", interval=-1, action="logger").clean_fields()
ScheduleEntry(name="t", interval=-1, action="test_monitor_sigan").clean_fields()
with pytest.raises(ValidationError):
ScheduleEntry(name="t", interval=0, action="logger").clean_fields()
ScheduleEntry(name="t", interval=0, action="test_monitor_sigan").clean_fields()
with pytest.raises(ValidationError):
ScheduleEntry(name="t", interval=0.1, action="logger").clean_fields()
ScheduleEntry(
name="t", interval=0.1, action="test_monitor_sigan"
).clean_fields()


def test_bad_action_raises():
Expand All @@ -108,22 +114,22 @@ def test_bad_action_raises():

def test_bad_name_raises():
with pytest.raises(ValidationError): # whitespace
ScheduleEntry(name="test 1", action="logger").clean_fields()
ScheduleEntry(name="test 1", action="test_monitor_sigan").clean_fields()
with pytest.raises(ValidationError): # punctuation other than "_-"
ScheduleEntry(name="test1!", action="logger").clean_fields()
ScheduleEntry(name="test1!", action="test_monitor_sigan").clean_fields()

# ok
ScheduleEntry(name="_test-Stuff123", action="logger").clean_fields()
ScheduleEntry(name="_test-Stuff123", action="test_monitor_sigan").clean_fields()


def test_non_unique_name_raises(user):
ScheduleEntry(name="t", action="logger", owner=user).save()
ScheduleEntry(name="t", action="test_monitor_sigan", owner=user).save()
with pytest.raises(ValidationError):
ScheduleEntry(name="t", action="logger", owner=user).full_clean()
ScheduleEntry(name="t", action="test_monitor_sigan", owner=user).full_clean()


def test_defaults():
entry = ScheduleEntry(name="t", action="logger")
entry = ScheduleEntry(name="t", action="test_monitor_sigan")
assert entry.priority == DEFAULT_PRIORITY
assert entry.start is not None
assert entry.stop is None
Expand All @@ -132,4 +138,4 @@ def test_defaults():


def test_str():
str(ScheduleEntry(name="t", action="logger"))
str(ScheduleEntry(name="t", action="test_monitor_sigan"))
Loading
Loading