mirror of
https://github.com/undera/pylgbst.git
synced 2020-11-18 19:37:26 -08:00
163 lines
5.5 KiB
Python
163 lines
5.5 KiB
Python
import unittest
|
|
|
|
from pylgbst import *
|
|
|
|
HANDLE = MOVE_HUB_HARDWARE_HANDLE
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
log = logging.getLogger('test')
|
|
|
|
|
|
class ConnectionMock(Connection):
|
|
"""
|
|
For unit testing purposes
|
|
"""
|
|
|
|
def __init__(self):
|
|
super(ConnectionMock, self).__init__()
|
|
self.writes = []
|
|
self.notifications = []
|
|
self.notification_handler = None
|
|
self.running = True
|
|
self.finished = False
|
|
|
|
def set_notify_handler(self, handler):
|
|
self.notification_handler = handler
|
|
thr = Thread(target=self.notifier)
|
|
thr.setDaemon(True)
|
|
thr.start()
|
|
|
|
def notifier(self):
|
|
while self.running:
|
|
if self.notification_handler:
|
|
while self.notifications:
|
|
handle, data = self.notifications.pop(0)
|
|
self.notification_handler(handle, unhexlify(data.replace(' ', '')))
|
|
time.sleep(0.1)
|
|
|
|
self.finished = True
|
|
|
|
def write(self, handle, data):
|
|
log.debug("Writing to %s: %s", handle, str2hex(data))
|
|
self.writes.append((handle, str2hex(data)))
|
|
|
|
|
|
class HubMock(MoveHub):
|
|
def __init__(self, connection=None):
|
|
super(HubMock, self).__init__(connection if connection else ConnectionMock())
|
|
|
|
def _wait_for_devices(self):
|
|
pass
|
|
|
|
|
|
class GeneralTest(unittest.TestCase):
|
|
def _wait_notifications_handled(self, hub):
|
|
hub.connection.running = False
|
|
for _ in range(1, 180):
|
|
time.sleep(1)
|
|
log.debug("Waiting for notifications to process...")
|
|
if hub.connection.finished:
|
|
log.debug("Done waiting")
|
|
break
|
|
|
|
def test_led(self):
|
|
hub = HubMock()
|
|
led = LED(hub, PORT_LED)
|
|
led.set_color(COLOR_RED)
|
|
self.assertEqual("0801813201510009", hub.connection.writes[0][1])
|
|
|
|
def test_tilt_sensor(self):
|
|
hub = HubMock()
|
|
hub.connection.notifications.append((HANDLE, '1b0e00 0f00 04 3a 0128000000000100000001'))
|
|
time.sleep(1)
|
|
|
|
def callback(param1, param2=None, param3=None):
|
|
if param2 is None:
|
|
log.debug("Tilt: %s", TILT_STATES[param1])
|
|
else:
|
|
log.debug("Tilt: %s %s %s", param1, param2, param3)
|
|
|
|
hub.tilt_sensor.subscribe(callback)
|
|
hub.connection.notifications.append((HANDLE, "1b0e000500453a05"))
|
|
hub.connection.notifications.append((HANDLE, "1b0e000a00473a010100000001"))
|
|
time.sleep(1)
|
|
hub.tilt_sensor.subscribe(callback, TILT_MODE_2AXIS_SIMPLE)
|
|
|
|
hub.connection.notifications.append((HANDLE, "1b0e000500453a09"))
|
|
time.sleep(1)
|
|
|
|
hub.tilt_sensor.subscribe(callback, TILT_MODE_2AXIS_FULL)
|
|
hub.connection.notifications.append((HANDLE, "1b0e000600453a04fe"))
|
|
time.sleep(1)
|
|
|
|
self._wait_notifications_handled(hub)
|
|
hub.tilt_sensor.unsubscribe(callback)
|
|
# TODO: assert
|
|
|
|
def test_motor(self):
|
|
conn = ConnectionMock()
|
|
conn.notifications.append((14, '1b0e00 0900 04 39 0227003738'))
|
|
hub = HubMock(conn)
|
|
time.sleep(0.1)
|
|
|
|
conn.notifications.append((14, '1b0e00050082390a'))
|
|
hub.motor_AB.timed(1.5)
|
|
self.assertEqual("0d018139110adc056464647f03", conn.writes[0][1])
|
|
|
|
conn.notifications.append((14, '1b0e00050082390a'))
|
|
hub.motor_AB.angled(90)
|
|
self.assertEqual("0f018139110c5a0000006464647f03", conn.writes[1][1])
|
|
|
|
def test_capabilities(self):
|
|
conn = ConnectionMock()
|
|
conn.notifications.append((14, '1b0e00 0f00 04 01 0125000000001000000010'))
|
|
conn.notifications.append((14, '1b0e00 0f00 04 02 0126000000001000000010'))
|
|
conn.notifications.append((14, '1b0e00 0f00 04 37 0127000100000001000000'))
|
|
conn.notifications.append((14, '1b0e00 0f00 04 38 0127000100000001000000'))
|
|
conn.notifications.append((14, '1b0e00 0900 04 39 0227003738'))
|
|
conn.notifications.append((14, '1b0e00 0f00 04 32 0117000100000001000000'))
|
|
conn.notifications.append((14, '1b0e00 0f00 04 3a 0128000000000100000001'))
|
|
conn.notifications.append((14, '1b0e00 0f00 04 3b 0115000200000002000000'))
|
|
conn.notifications.append((14, '1b0e00 0f00 04 3c 0114000200000002000000'))
|
|
conn.notifications.append((14, '1b0e00 0f00 8202 01'))
|
|
conn.notifications.append((14, '1b0e00 0f00 8202 0a'))
|
|
|
|
hub = MoveHub(conn)
|
|
# demo_all(hub)
|
|
self._wait_notifications_handled(hub)
|
|
|
|
def test_color_sensor(self):
|
|
#
|
|
hub = HubMock()
|
|
hub.connection.notifications.append((HANDLE, '1b0e000f0004010125000000001000000010'))
|
|
time.sleep(1)
|
|
|
|
def callback(color, unk1, unk2=None):
|
|
name = COLORS[color] if color is not None else 'NONE'
|
|
log.info("Color: %s %s %s", name, unk1, unk2)
|
|
|
|
hub.color_distance_sensor.subscribe(callback)
|
|
|
|
hub.connection.notifications.append((HANDLE, "1b0e0008004501ff0aff00"))
|
|
time.sleep(1)
|
|
# TODO: assert
|
|
self._wait_notifications_handled(hub)
|
|
hub.color_distance_sensor.unsubscribe(callback)
|
|
|
|
def test_button(self):
|
|
hub = HubMock()
|
|
time.sleep(1)
|
|
|
|
def callback(pressed):
|
|
log.info("Pressed: %s", pressed)
|
|
|
|
hub.button.subscribe(callback)
|
|
|
|
hub.connection.notifications.append((HANDLE, "1b0e00060001020601"))
|
|
hub.connection.notifications.append((HANDLE, "1b0e00060001020600"))
|
|
time.sleep(1)
|
|
# TODO: assert
|
|
self._wait_notifications_handled(hub)
|
|
hub.button.unsubscribe(callback)
|