|
1 | 1 | """Tests for pystac.extensions.sat."""
|
2 | 2 |
|
3 | 3 | import datetime
|
| 4 | +from pystac.summaries import RangeSummary |
4 | 5 | from typing import Any, Dict
|
5 | 6 | import unittest
|
6 | 7 |
|
7 | 8 | import pystac
|
8 |
| -from pystac.utils import str_to_datetime |
| 9 | +from pystac.utils import str_to_datetime, datetime_to_str |
9 | 10 | from pystac import ExtensionTypeError
|
10 | 11 | from pystac.extensions import sat
|
11 |
| -from pystac.extensions.sat import SatExtension |
| 12 | +from pystac.extensions.sat import OrbitState, SatExtension |
12 | 13 | from tests.utils import TestCases
|
13 | 14 |
|
14 | 15 |
|
@@ -216,3 +217,108 @@ def test_should_raise_exception_when_passing_invalid_extension_object(
|
216 | 217 | SatExtension.ext,
|
217 | 218 | object(),
|
218 | 219 | )
|
| 220 | + |
| 221 | + |
| 222 | +class SatSummariesTest(unittest.TestCase): |
| 223 | + def setUp(self) -> None: |
| 224 | + self.maxDiff = None |
| 225 | + |
| 226 | + self.collection = pystac.Collection.from_file( |
| 227 | + TestCases.get_path("data-files/collections/multi-extent.json") |
| 228 | + ) |
| 229 | + |
| 230 | + def test_platform_international_designation(self) -> None: |
| 231 | + summaries_ext = SatExtension.summaries(self.collection) |
| 232 | + platform_international_designator_list = ["2018-080A"] |
| 233 | + |
| 234 | + summaries_ext.platform_international_designator = ["2018-080A"] |
| 235 | + |
| 236 | + self.assertEqual( |
| 237 | + summaries_ext.platform_international_designator, |
| 238 | + platform_international_designator_list, |
| 239 | + ) |
| 240 | + |
| 241 | + summaries_dict = self.collection.to_dict()["summaries"] |
| 242 | + |
| 243 | + self.assertEqual( |
| 244 | + summaries_dict["sat:platform_international_designator"], |
| 245 | + platform_international_designator_list, |
| 246 | + ) |
| 247 | + |
| 248 | + def test_orbit_state(self) -> None: |
| 249 | + summaries_ext = SatExtension.summaries(self.collection) |
| 250 | + orbit_state_list = [OrbitState.ASCENDING] |
| 251 | + |
| 252 | + summaries_ext.orbit_state = orbit_state_list |
| 253 | + |
| 254 | + self.assertEqual( |
| 255 | + summaries_ext.orbit_state, |
| 256 | + orbit_state_list, |
| 257 | + ) |
| 258 | + |
| 259 | + summaries_dict = self.collection.to_dict()["summaries"] |
| 260 | + |
| 261 | + self.assertEqual( |
| 262 | + summaries_dict["sat:orbit_state"], |
| 263 | + orbit_state_list, |
| 264 | + ) |
| 265 | + |
| 266 | + def test_absolute_orbit(self) -> None: |
| 267 | + summaries_ext = SatExtension.summaries(self.collection) |
| 268 | + absolute_orbit_range = RangeSummary(2000, 3000) |
| 269 | + |
| 270 | + summaries_ext.absolute_orbit = absolute_orbit_range |
| 271 | + |
| 272 | + self.assertEqual( |
| 273 | + summaries_ext.absolute_orbit, |
| 274 | + absolute_orbit_range, |
| 275 | + ) |
| 276 | + |
| 277 | + summaries_dict = self.collection.to_dict()["summaries"] |
| 278 | + |
| 279 | + self.assertEqual( |
| 280 | + summaries_dict["sat:absolute_orbit"], |
| 281 | + absolute_orbit_range.to_dict(), |
| 282 | + ) |
| 283 | + |
| 284 | + def test_relative_orbit(self) -> None: |
| 285 | + summaries_ext = SatExtension.summaries(self.collection) |
| 286 | + relative_orbit_range = RangeSummary(50, 100) |
| 287 | + |
| 288 | + summaries_ext.relative_orbit = relative_orbit_range |
| 289 | + |
| 290 | + self.assertEqual( |
| 291 | + summaries_ext.relative_orbit, |
| 292 | + relative_orbit_range, |
| 293 | + ) |
| 294 | + |
| 295 | + summaries_dict = self.collection.to_dict()["summaries"] |
| 296 | + |
| 297 | + self.assertEqual( |
| 298 | + summaries_dict["sat:relative_orbit"], |
| 299 | + relative_orbit_range.to_dict(), |
| 300 | + ) |
| 301 | + |
| 302 | + def test_anx_datetime(self) -> None: |
| 303 | + summaries_ext = SatExtension.summaries(self.collection) |
| 304 | + anx_datetime_range = RangeSummary( |
| 305 | + str_to_datetime("2020-01-01T00:00:00.000Z"), |
| 306 | + str_to_datetime("2020-01-02T00:00:00.000Z"), |
| 307 | + ) |
| 308 | + |
| 309 | + summaries_ext.anx_datetime = anx_datetime_range |
| 310 | + |
| 311 | + self.assertEqual( |
| 312 | + summaries_ext.anx_datetime, |
| 313 | + anx_datetime_range, |
| 314 | + ) |
| 315 | + |
| 316 | + summaries_dict = self.collection.to_dict()["summaries"] |
| 317 | + |
| 318 | + self.assertDictEqual( |
| 319 | + summaries_dict["sat:anx_datetime"], |
| 320 | + { |
| 321 | + "minimum": datetime_to_str(anx_datetime_range.minimum), |
| 322 | + "maximum": datetime_to_str(anx_datetime_range.maximum), |
| 323 | + }, |
| 324 | + ) |
0 commit comments