From f015314f3637258a3e9323533e1d12ee38d3e92d Mon Sep 17 00:00:00 2001 From: pcain <pcain@usgs.gov> Date: Wed, 1 Sep 2021 10:19:17 -0600 Subject: [PATCH] Add mock client fixture for mseed test --- test/edge_test/conftest.py | 65 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 test/edge_test/conftest.py diff --git a/test/edge_test/conftest.py b/test/edge_test/conftest.py new file mode 100644 index 000000000..4801e6ab8 --- /dev/null +++ b/test/edge_test/conftest.py @@ -0,0 +1,65 @@ +import numpy +from obspy import Stream, UTCDateTime +from obspy.clients.neic.client import Client +import pytest + +from geomagio import TimeseriesUtility + + +@pytest.fixture(scope="class") +def MockMiniSeedClient() -> Client: + """replaces default obspy miniseed client's get_waveforms method to return trace of ones""" + + class MockMiniSeedClient(Client): + def get_waveforms( + self, + network: str, + station: str, + location: str, + channel: str, + starttime: UTCDateTime, + endtime: UTCDateTime, + ): + trace = TimeseriesUtility.create_empty_trace( + starttime=starttime, + endtime=endtime, + observatory=station, + channel=channel, + type=self._get_data_type(location=location), + interval=self._get_interval(channel=channel), + network=network, + station=station, + location=location, + ) + trace.data = numpy.ones(trace.stats.npts) + return Stream([trace]) + + def _get_interval(self, channel: str) -> str: + channel_start = channel[0] + if channel_start == "B": + return "tenhertz" + elif channel_start == "L": + return "second" + elif channel_start == "U": + return "minute" + elif channel_start == "R": + return "hour" + elif channel_start == "P": + return "day" + else: + raise ValueError(f"Unexpected channel start: {channel_start}") + + def _get_data_type(self, location: str) -> str: + location_start = location[0] + if location_start == "R": + return "variation" + elif location_start == "A": + return "adjusted" + elif location_start == "Q": + return "quasi-definitive" + elif location_start == "D": + return "definitive" + else: + raise ValueError(f"Unexpected location start: {location_start}") + + yield MockMiniSeedClient -- GitLab