From b0abc69f36cab664bebe785699cb533db31e6a70 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=A9r=C3=A9my=20Neveu?= Date: Fri, 13 Sep 2019 18:46:52 +0200 Subject: [PATCH] increase coverage and add unit tests --- spectractor/simulation/atmosphere.py | 36 +++++++++++++++++++++++++--- tests/test_simulator.py | 1 + 2 files changed, 34 insertions(+), 3 deletions(-) diff --git a/spectractor/simulation/atmosphere.py b/spectractor/simulation/atmosphere.py index d47e8d90a..c5d7cffab 100644 --- a/spectractor/simulation/atmosphere.py +++ b/spectractor/simulation/atmosphere.py @@ -127,10 +127,10 @@ def plot_transmission(self): >>> a.plot_transmission() """ - plt.figure() + fig = plt.figure() plot_transmission_simple(plt.gca(), parameters.LAMBDAS, self.transmission(parameters.LAMBDAS), title=self.title, label=self.label) - if parameters.DISPLAY: + if parameters.DISPLAY: # pragma: no cover plt.show() @@ -261,6 +261,13 @@ def compute(self): >>> a = AtmosphereGrid(image_filename='tests/data/reduc_20170605_028.fits', ... pwv_grid=[5, 5, 1], ozone_grid=[400, 400, 1], aerosol_grid=[0.0, 0.1, 2]) >>> atmospheric_grid = a.compute() + >>> atmospheric_grid + array([[0.000000e+00, 0.000000e+00, 0.000000e+00, ..., 1.099400e+03, + 1.099600e+03, 1.099800e+03], + [1.000000e+00, 0.000000e+00, 5.000000e+00, ..., 9.520733e-01, + 9.520733e-01, 9.520733e-01], + [2.000000e+00, 1.000000e-01, 5.000000e+00, ..., 9.213718e-01, + 9.213718e-01, 9.213718e-01]]) >>> assert np.all(np.isclose(a.atmgrid[0, a.index_atm_data:], parameters.LAMBDAS)) >>> assert not np.any(np.isclose(a.atmgrid[1, a.index_atm_data:], np.zeros_like(parameters.LAMBDAS), rtol=1e-6)) >>> assert a.atmgrid.shape == (3, a.index_atm_data+len(parameters.LAMBDAS)) @@ -304,7 +311,7 @@ def plot_transmission(self): f'VAOD={self.atmgrid[int(count), self.index_atm_aer]}' plot_transmission_simple(plt.gca(), self.lambdas, self.atmgrid[int(count), self.index_atm_data:], title="Atmospheric grid", label=label) - if parameters.DISPLAY: + if parameters.DISPLAY: # pragma: no cover plt.show() def plot_transmission_image(self): @@ -333,6 +340,14 @@ def save_file(self, filename=""): ---------- filename: str The output file name. + + Examples + -------- + >>> a = AtmosphereGrid(image_filename='tests/data/reduc_20170605_028.fits', + ... pwv_grid=[5, 5, 1], ozone_grid=[400, 400, 1], aerosol_grid=[0.0, 0.1, 2]) + >>> atmospheric_grid = a.compute() + >>> a.save_file(a.image_filename.replace('.fits', '_atmsim.fits')) + >>> assert os.path.isfile('tests/data/reduc_20170605_028_atmsim.fits') """ hdr = fits.Header() @@ -390,6 +405,21 @@ def load_file(self, filename): ---------- filename: str The input file name. + + Examples + -------- + >>> a = AtmosphereGrid(image_filename='tests/data/reduc_20170605_028.fits', + ... pwv_grid=[5, 5, 1], ozone_grid=[400, 400, 1], aerosol_grid=[0.0, 0.1, 2]) + >>> atmospheric_grid = a.compute() + >>> a.save_file(a.image_filename.replace('.fits', '_atmsim.fits')) + >>> assert os.path.isfile('tests/data/reduc_20170605_028_atmsim.fits') + >>> a.load_file(a.image_filename.replace('.fits', '_atmsim.fits')) + >>> a.AER_Points + array([0. , 0.1]) + >>> a.PWV_Points + array([5.]) + >>> a.OZ_Points + array([400.]) """ if filename != "": diff --git a/tests/test_simulator.py b/tests/test_simulator.py index 4726f9537..ee74ebbd1 100644 --- a/tests/test_simulator.py +++ b/tests/test_simulator.py @@ -28,6 +28,7 @@ def test_simulator(): aerosol_grid=[0, 0.1, 2]) atmgrid = AtmosphereGrid(file_name, file_name.replace('spectrum', 'atmsim')) atm = Atmosphere(atmgrid.airmass, atmgrid.pressure, atmgrid.temperature) + assert os.path.isfile('./tests/data/' + tag.replace('_spectrum.fits', '_atmsim.fits')) is True assert image_simulation.data is not None # assert spectrum_simulation.data is not None assert spectrogram_simulation.data is not None