better detection
This commit is contained in:
parent
07b3388cef
commit
f34c796ee8
2 changed files with 21 additions and 8 deletions
|
@ -18,14 +18,18 @@ def get_logger():
|
||||||
return logging.getLogger('bluemaestro')
|
return logging.getLogger('bluemaestro')
|
||||||
|
|
||||||
|
|
||||||
def get_temperature():
|
def get_temperature(all_=False):
|
||||||
logger = get_logger()
|
logger = get_logger()
|
||||||
merged: Dict[datetime, Any] = {}
|
|
||||||
|
|
||||||
for f in list(sorted(chain(
|
backups = list(sorted(chain(
|
||||||
DIR.glob('*.db'),
|
DIR.glob('*.db'),
|
||||||
DIR2.glob('*.db'),
|
DIR2.glob('*.db'),
|
||||||
))):
|
)))
|
||||||
|
if not all_:
|
||||||
|
backups = [backups[-1]]
|
||||||
|
|
||||||
|
merged: Dict[datetime, Any] = {}
|
||||||
|
for f in backups:
|
||||||
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:
|
||||||
|
@ -68,6 +72,9 @@ def get_temperature():
|
||||||
# print(k, v)
|
# print(k, v)
|
||||||
return merged
|
return merged
|
||||||
|
|
||||||
|
def test():
|
||||||
|
get_temperature(all_=False)
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
setup_logzero(get_logger(), level=logging.DEBUG)
|
setup_logzero(get_logger(), level=logging.DEBUG)
|
||||||
get_temperature()
|
get_temperature()
|
||||||
|
|
|
@ -8,17 +8,23 @@ from my.bluemaestro import get_temperature, get_logger
|
||||||
def main():
|
def main():
|
||||||
setup_logzero(get_logger(), level=logging.DEBUG)
|
setup_logzero(get_logger(), level=logging.DEBUG)
|
||||||
|
|
||||||
temps = get_temperature()
|
temps = get_temperature(all_=False)
|
||||||
latest = sorted(temps.items())[:-2]
|
latest = sorted(temps.items())[:-2]
|
||||||
|
|
||||||
prev, _ = latest[-2]
|
prev, _ = latest[-2]
|
||||||
last, _ = latest[-1]
|
last, _ = latest[-1]
|
||||||
|
|
||||||
|
POINTS_STORED = 6000
|
||||||
|
FREQ_SEC = 60
|
||||||
|
SECS_STORED = POINTS_STORED * FREQ_SEC
|
||||||
|
HOURS_STORED = POINTS_STORED / (60 * 60 / FREQ_SEC) # around 4 days
|
||||||
|
NOW = datetime.now()
|
||||||
|
assert NOW - last < timedelta(hours=HOURS_STORED / 2), f'old backup! {last}'
|
||||||
|
|
||||||
|
|
||||||
assert last - prev < timedelta(minutes=3), f'bad interval! {last - prev}'
|
assert last - prev < timedelta(minutes=3), f'bad interval! {last - prev}'
|
||||||
single = (last - prev).seconds
|
single = (last - prev).seconds
|
||||||
|
|
||||||
NOW = datetime.now()
|
|
||||||
assert NOW - last < timedelta(days=2), f'old backup! {last}'
|
|
||||||
# TODO change to 1 later?
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
Loading…
Add table
Reference in a new issue