-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtest_whisper_pandas.py
103 lines (74 loc) · 3.04 KB
/
test_whisper_pandas.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
"""Tests for whisper_pandas package."""
import pytest
import pandas as pd
from numpy.testing import assert_allclose
from whisper_pandas import WhisperFile, WhisperFileMeta, WhisperArchiveMeta
@pytest.fixture(scope="session")
def wsp() -> WhisperFile:
return WhisperFile.read("data/example.wsp")
@pytest.fixture(scope="session")
def meta(wsp) -> WhisperFileMeta:
return wsp.meta
def test_meta(meta):
"""Test if meta data is read OK."""
assert meta.path == "data/example.wsp"
assert meta.aggregation_method == "average"
assert meta.max_retention == 315363600
assert_allclose(meta.x_files_factor, 0.5)
assert meta.header_size == 52
assert meta.file_size == 82785664
assert meta.file_size_actual == 82785664
assert meta.file_size_mismatch is False
assert len(meta.archives) == 3
assert meta.archives[0] == WhisperArchiveMeta(
index=0, offset=52, seconds_per_point=10, points=1555200
)
assert meta.archives[1] == WhisperArchiveMeta(
index=1, offset=18662452, seconds_per_point=60, points=5256000,
)
assert meta.archives[2] == WhisperArchiveMeta(
index=2, offset=81734452, seconds_per_point=3600, points=87601,
)
def test_data_archive_0(wsp):
df = wsp.archives[0].to_frame()
assert len(df) == 1555200
assert df.index[0] == 43687
assert df["timestamp"].iloc[0] == pd.Timestamp("2020-07-29 08:28:10+0000")
assert df.index[-1] == 10995
assert df["timestamp"].iloc[-1] == pd.Timestamp("2021-07-20 13:39:30+0000")
assert_allclose(df["value"].iloc[-1], 4.081736, atol=1e-5)
def test_data_archive_1(wsp):
"""Test if data is read and converted to pandas OK."""
s = wsp.archives[1].to_frame().set_index("timestamp")["value"]
assert len(s) == 2331015
assert s.dtype == "float64"
assert s.index.is_monotonic
assert s.index.is_unique
assert str(s.index.tz) == "UTC"
assert s.index[0] == pd.Timestamp("2017-02-10 07:07:00+0000")
assert s.index[-1] == pd.Timestamp("2021-07-20 13:39:00+0000")
assert_allclose(s.iloc[-1], 4.099854, atol=1e-5)
def test_data_archive_2(wsp):
s = wsp.archives[2].to_frame().set_index("timestamp")["value"]
assert len(s) == 38855
assert s.index[0] == pd.Timestamp("2017-02-10 07:00:00+0000")
assert s.index[-1] == pd.Timestamp("2021-07-20 13:00:00+0000")
assert_allclose(s.iloc[-1], 4.099754, atol=1e-5)
def test_archive_as_dataframe(wsp):
df = wsp.archives[1].to_frame(to_datetime=False)
assert df.shape == (2331015, 2)
assert df["timestamp"].dtype == "int32"
assert df["value"].dtype == "float64"
def test_print_info(wsp):
wsp.print_info()
def test_read_gzip():
wsp = WhisperFile.read("data/example.wsp.gz")
assert type(wsp.bytes) is bytes
assert len(wsp.bytes) == 82785664
assert wsp.meta.file_size == 82785664
assert wsp.meta.file_size_actual == 21696528
wsp.print_info()
def test_truncated():
wsp = WhisperFile.read("data/example_truncated.wsp")
assert wsp.meta.file_size == 82785664
assert wsp.meta.file_size_actual == 100000