From 60d663facd36b32436bb71d1ca21d1a470e9981a Mon Sep 17 00:00:00 2001 From: Brett Date: Mon, 2 Dec 2024 09:35:02 -0500 Subject: [PATCH] add test to check ami and wcsinfo match --- .../jwst/datamodels/tests/test_models.py | 2 +- .../jwst/datamodels/tests/test_schema.py | 18 ++++++++++++++++++ 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/src/stdatamodels/jwst/datamodels/tests/test_models.py b/src/stdatamodels/jwst/datamodels/tests/test_models.py index 9abccfb6..83e65ff8 100644 --- a/src/stdatamodels/jwst/datamodels/tests/test_models.py +++ b/src/stdatamodels/jwst/datamodels/tests/test_models.py @@ -574,7 +574,7 @@ def test_amioi_model_oifits_extra_columns(tmp_path, oifits_ami_model, table_name def test_amioi_model_extra_meta(tmp_path, oifits_ami_model): - oifits_ami_model.meta.calibrator_object_id = "foo" + oifits_ami_model.meta.ami.calibrator_object_id = "foo" fn = tmp_path / "test.fits" oifits_ami_model.save(fn) diff --git a/src/stdatamodels/jwst/datamodels/tests/test_schema.py b/src/stdatamodels/jwst/datamodels/tests/test_schema.py index 1bf642a6..7c331d77 100644 --- a/src/stdatamodels/jwst/datamodels/tests/test_schema.py +++ b/src/stdatamodels/jwst/datamodels/tests/test_schema.py @@ -92,3 +92,21 @@ def test_data_array(tmp_path): assert x == set( [('FOO', 2), ('FOO', 1), ('ASDF', None), ('DQ', 2), (None, None)]) + + +def test_ami_wcsinfo(): + """ + The ami and wcsinfo schemas contain duplicate information + since ami products don't otherwise contain a SCI extension. + This test checks that the schema entries for the duplicated + information stays in sync. + """ + wcsinfo_schema = mschema.load_schema("http://stsci.edu/schemas/jwst_datamodel/wcsinfo.schema") + ami_schema = mschema.load_schema("http://stsci.edu/schemas/jwst_datamodel/ami.schema") + ami_def = ami_schema["allOf"][1]["properties"]["meta"]["properties"]["ami"]["properties"] + wcsinfo_def = wcsinfo_schema["properties"]["meta"]["properties"]["wcsinfo"]["properties"] + for keyword in ("roll_ref", "v3yangle", "vparity"): + ami = ami_def[keyword] + wcsinfo = wcsinfo_def[keyword] + for key in set(ami.keys()) | set(wcsinfo.keys()) - {"fits_hdu"}: + assert ami[key] == wcsinfo[key]