-
Notifications
You must be signed in to change notification settings - Fork 23
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Showing
7 changed files
with
90 additions
and
34 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,47 +1,66 @@ | ||
from __future__ import annotations | ||
|
||
from datetime import datetime, timedelta | ||
from typing import Final, Any | ||
|
||
from HABApp.openhab.definitions.helpers import OpenhabPersistenceData | ||
from HABApp.openhab.items import NumberItem | ||
from HABAppTests import TestBaseRule | ||
|
||
|
||
class TestPersistence(TestBaseRule): | ||
|
||
def __init__(self): | ||
class TestPersistenceBase(TestBaseRule): | ||
def __init__(self, service_name: str, item_name: str): | ||
super().__init__() | ||
self.item = 'RRD4J_Item' | ||
|
||
self.add_test('RRD4J configured', self.test_configured) | ||
self.add_test('RRD4J get', self.test_get) | ||
self.config.skip_on_failure = True | ||
self.item_name: Final = item_name | ||
self.service_name: Final = service_name | ||
|
||
self.add_test(f'Persistence {service_name} available', self.test_service_available) | ||
|
||
def set_up(self): | ||
i = NumberItem.get_item(self.item) | ||
i.oh_post_update(i.value + 1 if i.value < 10 else 0) | ||
i = NumberItem.get_item(self.item_name) | ||
i.oh_post_update(int(i.value) + 1 if i.value < 10 else 0) | ||
|
||
def test_configured(self): | ||
def test_service_available(self): | ||
for cfg in self.oh.get_persistence_services(): | ||
if cfg.id == 'rrd4j': | ||
if cfg.id == self.service_name: | ||
break | ||
else: | ||
raise ValueError('rrd4j not found!') | ||
raise ValueError(f'Persistence service "{self.service_name}" not found!') | ||
|
||
def set_persistence_data(self, time: datetime, state: Any): | ||
return self.openhab.set_persistence_data(self.item_name, self.service_name, time, state) | ||
|
||
def get_persistence_data(self, start_time: datetime | None, end_time: datetime | None) -> OpenhabPersistenceData: | ||
return self.openhab.get_persistence_data(self.item_name, self.service_name, start_time, end_time) | ||
|
||
|
||
class TestRRD4j(TestPersistenceBase): | ||
|
||
def __init__(self): | ||
super().__init__('rrd4j', 'RRD4J_Item') | ||
self.add_test('RRD4J get', self.test_get) | ||
|
||
def test_get(self): | ||
now = datetime.now() | ||
d = self.openhab.get_persistence_data(self.item, 'rrd4j', now - timedelta(seconds=60), now) | ||
d = self.get_persistence_data(now - timedelta(seconds=60), now) | ||
assert d.get_data() | ||
|
||
# def test_set(self): | ||
# now = datetime.now() | ||
# d = self.openhab.get_persistence_data(self.item, 'mapdb', now - timedelta(seconds=5), now) | ||
# was = d.get_data() | ||
# | ||
# assert list(was.values()) == [1] | ||
# | ||
# self.openhab.set_persistence_data(self.item, 'mapdb', now, 2) | ||
# | ||
# d = self.openhab.get_persistence_data(self.item, 'mapdb', now - timedelta(seconds=5), | ||
# now + timedelta(seconds=5)) | ||
# ist = d.get_data() | ||
# assert list(ist.values()) == [2], ist | ||
|
||
|
||
TestPersistence() | ||
|
||
TestRRD4j() | ||
|
||
|
||
class TestMapDB(TestPersistenceBase): | ||
|
||
def __init__(self): | ||
super().__init__('mapdb', 'RRD4J_Item') | ||
self.add_test('MapDB get', self.test_get) | ||
|
||
def test_get(self): | ||
now = datetime.now() | ||
d = self.get_persistence_data(now - timedelta(seconds=60), now) | ||
assert d.get_data() | ||
|
||
|
||
TestMapDB() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
from HABApp.openhab.connection.handler import convert_to_oh_type | ||
|
||
|
||
def test_convert_to_oh_type(): | ||
assert convert_to_oh_type(1 / 10 ** 3) == '0.001' | ||
assert convert_to_oh_type(1 / 10 ** 6) == '0.000001' | ||
assert convert_to_oh_type(1 / 10 ** 9) == '0.000000001' | ||
|
||
assert convert_to_oh_type(1.234 / 10 ** 3) == '0.001234' | ||
assert convert_to_oh_type(1.234 / 10 ** 6) == '0.000001234' | ||
assert convert_to_oh_type(1.234 / 10 ** 9) == '0.000000001234' |