checking script
This commit is contained in:
parent
1e20420ce5
commit
bce5fd99b6
2 changed files with 35 additions and 9 deletions
|
@ -1,6 +1,7 @@
|
||||||
#!/usr/bin/python3
|
#!/usr/bin/python3
|
||||||
import sqlite3
|
import sqlite3
|
||||||
# ugh, dataset stumpled over date format
|
# ugh, dataset stumpled over date format
|
||||||
|
from itertools import islice
|
||||||
|
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
import logging
|
import logging
|
||||||
|
@ -12,12 +13,12 @@ def get_logger():
|
||||||
return logging.getLogger('bluemaestro')
|
return logging.getLogger('bluemaestro')
|
||||||
|
|
||||||
|
|
||||||
def get_data():
|
def get_temperature():
|
||||||
logger = get_logger()
|
logger = get_logger()
|
||||||
merged = {}
|
merged = {}
|
||||||
# TODO could get pretty big ?
|
|
||||||
|
|
||||||
for f in sorted(DIR.glob('*.db')):
|
# TODO how to trigger data download manually?
|
||||||
|
for f in list(sorted(DIR.glob('*.db'))):
|
||||||
def reg(dt: datetime, value):
|
def reg(dt: datetime, value):
|
||||||
v = merged.get(dt, None)
|
v = merged.get(dt, None)
|
||||||
if v is None:
|
if v is None:
|
||||||
|
@ -53,15 +54,16 @@ def get_data():
|
||||||
|
|
||||||
logger.info('total items: %d', len(merged))
|
logger.info('total items: %d', len(merged))
|
||||||
# TODO assert frequency?
|
# TODO assert frequency?
|
||||||
for k, v in merged.items():
|
# for k, v in merged.items():
|
||||||
# TODO shit. quite a few of them have varying values... how is that freaking possible????
|
# # TODO shit. quite a few of them have varying values... how is that freaking possible????
|
||||||
# most of them are withing 0.5 degree though... so just ignore?
|
# # most of them are withing 0.5 degree though... so just ignore?
|
||||||
if isinstance(v, set) and len(v) > 1:
|
# if isinstance(v, set) and len(v) > 1:
|
||||||
print(k, v)
|
# print(k, v)
|
||||||
|
return merged
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
setup_logzero(get_logger(), level=logging.DEBUG)
|
setup_logzero(get_logger(), level=logging.DEBUG)
|
||||||
get_data()
|
get_temperature()
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
24
bluemaestro/check.py
Normal file
24
bluemaestro/check.py
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
#!/usr/bin/python3
|
||||||
|
import logging
|
||||||
|
from datetime import timedelta, datetime
|
||||||
|
from kython import setup_logzero
|
||||||
|
|
||||||
|
from my.bluemaestro import get_temperature, get_logger
|
||||||
|
|
||||||
|
def main():
|
||||||
|
setup_logzero(get_logger(), level=logging.DEBUG)
|
||||||
|
|
||||||
|
temps = get_temperature()
|
||||||
|
latest = sorted(temps.items())[:-2]
|
||||||
|
|
||||||
|
prev, _ = latest[-2]
|
||||||
|
last, _ = latest[-1]
|
||||||
|
assert last - prev < timedelta(minutes=3), f'bad interval! {last - prev}'
|
||||||
|
single = (last - prev).seconds
|
||||||
|
|
||||||
|
NOW = datetime.now()
|
||||||
|
assert NOW - last < timedelta(days=5), f'old backup! {last}'
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
Loading…
Add table
Reference in a new issue