Skip to content

Commit

Permalink
Adding error handling, missing filters.
Browse files Browse the repository at this point in the history
  • Loading branch information
astronomerritt committed May 9, 2024
1 parent 5c25e67 commit 9fc14f6
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 21 deletions.
28 changes: 25 additions & 3 deletions src/adler/dataclasses/AdlerPlanetoid.py
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,12 @@ def construct_from_SQL(
cls, ssObjectId, filter_list, date_range, sql_filename=sql_filename, schema=schema
)

if len(observations_by_filter) == 0:
raise Exception("No observations found for this object in the given filter(s). Check SSOID and try again.")

# redo the filter list based on the available filters in observations_by_filter
filter_list = [obs_object.filter_name for obs_object in observations_by_filter]

mpcorb = cls.populate_MPCORB(cls, ssObjectId, sql_filename=sql_filename, schema=schema)
ssobject = cls.populate_SSObject(
cls, ssObjectId, filter_list, sql_filename=sql_filename, schema=schema
Expand Down Expand Up @@ -122,6 +128,13 @@ def construct_from_RSP(
observations_by_filter = cls.populate_observations(
cls, ssObjectId, filter_list, date_range, service=service
)

if len(observations_by_filter) == 0:
raise Exception("No observations found for this object in the given filter(s). Check SSOID and try again.")

# redo the filter list based on the available filters in observations_by_filter
filter_list = [obs_object.filter_name for obs_object in observations_by_filter]

mpcorb = cls.populate_MPCORB(cls, ssObjectId, service=service)
ssobject = cls.populate_SSObject(cls, ssObjectId, filter_list, service=service)

Expand Down Expand Up @@ -185,9 +198,12 @@ def populate_observations(

data_table = get_data_table(observations_sql_query, service=service, sql_filename=sql_filename)

observations_by_filter.append(
Observations.construct_from_data_table(ssObjectId, filter_name, data_table)
)
if len(data_table) == 0:
print("WARNING: No observations found in {} filter for this object. Skipping this filter.".format(filter_name))
else:
observations_by_filter.append(
Observations.construct_from_data_table(ssObjectId, filter_name, data_table)
)

return observations_by_filter

Expand Down Expand Up @@ -228,6 +244,9 @@ def populate_MPCORB(self, ssObjectId, service=None, sql_filename=None, schema="d

data_table = get_data_table(MPCORB_sql_query, service=service, sql_filename=sql_filename)

if len(data_table) == 0:
raise Exception("No MPCORB data for this object could be found for this SSObjectId.")

return MPCORB.construct_from_data_table(ssObjectId, data_table)

def populate_SSObject(
Expand Down Expand Up @@ -282,6 +301,9 @@ def populate_SSObject(

data_table = get_data_table(SSObject_sql_query, service=service, sql_filename=sql_filename)

if len(data_table) == 0:
raise Exception("No SSObject data for this object could be found for this SSObjectId.")

return SSObject.construct_from_data_table(ssObjectId, filter_list, data_table)

def observations_in_filter(self, filter_name):
Expand Down
52 changes: 34 additions & 18 deletions tests/adler/dataclasses/test_AdlerPlanetoid.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,13 +11,13 @@


def test_construct_from_SQL():
test_planetoid = AdlerPlanetoid.construct_from_SQL(ssoid, test_db_path)
test_planetoid = AdlerPlanetoid.construct_from_SQL(ssoid, test_db_path, filter_list=["u", "g", "r", "i", "z", "y"])

# testing just a few values here to ensure correct setup: these objects have their own unit tests
assert test_planetoid.MPCORB.mpcH == 19.8799991607666
assert test_planetoid.SSObject.discoverySubmissionDate == 60218.0
assert_almost_equal(
test_planetoid.observations_by_filter[1].mag,
test_planetoid.observations_by_filter[0].mag,
[
21.33099937,
22.67099953,
Expand All @@ -31,10 +31,10 @@ def test_construct_from_SQL():
],
)

# did we pick up all the filters?
assert len(test_planetoid.observations_by_filter) == 6
assert len(test_planetoid.SSObject.filter_dependent_values) == 6
assert test_planetoid.filter_list == ["u", "g", "r", "i", "z", "y"]
# did we pick up all the filters? note we ask for ugrizy but u and y are unpopulated in DP0.3, so the code should eliminate them
assert len(test_planetoid.observations_by_filter) == 4
assert len(test_planetoid.SSObject.filter_dependent_values) == 4
assert test_planetoid.filter_list == ["g", "r", "i", "z"]

# checking the date range to ensure it's the default
assert test_planetoid.date_range == [60000.0, 67300.0]
Expand Down Expand Up @@ -100,12 +100,10 @@ def test_observations_in_filter():
test_planetoid = AdlerPlanetoid.construct_from_SQL(ssoid, test_db_path)

# Python dataclasses create an __eq__ for you so object-to-object comparison just works, isn't that nice?
assert test_planetoid.observations_in_filter("u") == test_planetoid.observations_by_filter[0]
assert test_planetoid.observations_in_filter("g") == test_planetoid.observations_by_filter[1]
assert test_planetoid.observations_in_filter("r") == test_planetoid.observations_by_filter[2]
assert test_planetoid.observations_in_filter("i") == test_planetoid.observations_by_filter[3]
assert test_planetoid.observations_in_filter("z") == test_planetoid.observations_by_filter[4]
assert test_planetoid.observations_in_filter("y") == test_planetoid.observations_by_filter[5]
assert test_planetoid.observations_in_filter("g") == test_planetoid.observations_by_filter[0]
assert test_planetoid.observations_in_filter("r") == test_planetoid.observations_by_filter[1]
assert test_planetoid.observations_in_filter("i") == test_planetoid.observations_by_filter[2]
assert test_planetoid.observations_in_filter("z") == test_planetoid.observations_by_filter[3]

with pytest.raises(ValueError) as error_info_1:
test_planetoid.observations_in_filter("f")
Expand All @@ -116,14 +114,32 @@ def test_observations_in_filter():
def test_SSObject_in_filter():
test_planetoid = AdlerPlanetoid.construct_from_SQL(ssoid, test_db_path)

assert test_planetoid.SSObject_in_filter("u") == test_planetoid.SSObject.filter_dependent_values[0]
assert test_planetoid.SSObject_in_filter("g") == test_planetoid.SSObject.filter_dependent_values[1]
assert test_planetoid.SSObject_in_filter("r") == test_planetoid.SSObject.filter_dependent_values[2]
assert test_planetoid.SSObject_in_filter("i") == test_planetoid.SSObject.filter_dependent_values[3]
assert test_planetoid.SSObject_in_filter("z") == test_planetoid.SSObject.filter_dependent_values[4]
assert test_planetoid.SSObject_in_filter("y") == test_planetoid.SSObject.filter_dependent_values[5]
assert test_planetoid.SSObject_in_filter("g") == test_planetoid.SSObject.filter_dependent_values[0]
assert test_planetoid.SSObject_in_filter("r") == test_planetoid.SSObject.filter_dependent_values[1]
assert test_planetoid.SSObject_in_filter("i") == test_planetoid.SSObject.filter_dependent_values[2]
assert test_planetoid.SSObject_in_filter("z") == test_planetoid.SSObject.filter_dependent_values[3]

with pytest.raises(ValueError) as error_info_1:
test_planetoid.SSObject_in_filter("f")

assert error_info_1.value.args[0] == "Filter f is not in AdlerPlanetoid.filter_list."


def test_no_observations():
with pytest.raises(Exception) as error_info:
test_planetoid = AdlerPlanetoid.construct_from_SQL(826857066833589477, test_db_path)

assert error_info.value.args[0] == "No observations found for this object in the given filter(s). Check SSOID and try again."


def test_for_warnings(capsys):

test_planetoid = AdlerPlanetoid.construct_from_SQL(ssoid, test_db_path, filter_list=["u", "g"])
captured = capsys.readouterr()

expected = ("WARNING: No observations found in u filter for this object. Skipping this filter.\n"
+ "WARNING: n unpopulated in MPCORB table for this object. Storing NaN instead.\n"
+ "WARNING: uncertaintyParameter unpopulated in MPCORB table for this object. Storing NaN instead.\n")

assert captured.out == expected

0 comments on commit 9fc14f6

Please sign in to comment.