BW3-Core/test/test_timer.py

97 lines
3.1 KiB
Python
Raw Normal View History

2018-09-21 13:30:41 +02:00
#!/usr/bin/python
# -*- coding: utf-8 -*-
"""!
____ ____ ______ __ __ __ _____
/ __ )/ __ \/ ___/ | / /___ _/ /______/ /_ |__ /
/ __ / / / /\__ \| | /| / / __ `/ __/ ___/ __ \ /_ <
/ /_/ / /_/ /___/ /| |/ |/ / /_/ / /_/ /__/ / / / ___/ /
/_____/\____//____/ |__/|__/\__,_/\__/\___/_/ /_/ /____/
German BOS Information Script
by Bastian Schroll
@file: test_timer.py
2018-09-24 20:39:25 +02:00
@date: 21.09.2018
2018-09-21 13:30:41 +02:00
@author: Bastian Schroll
@description: Unittests for BOSWatch. File must be _run as "pytest" unittest
"""
import logging
import time
import pytest
from boswatch.utils.timer import RepeatedTimer
2018-09-21 14:30:20 +02:00
2018-09-21 13:30:41 +02:00
class Test_Timer:
"""!Unittest for the timer class"""
def setup_method(self, method):
logging.debug("[TEST] %s.%s", type(self).__name__, method.__name__)
@staticmethod
2018-09-21 14:21:33 +02:00
def testTargetFast():
2018-09-23 21:08:44 +02:00
"""!Fast worker thread"""
2018-09-21 14:21:33 +02:00
logging.debug("run testTargetFast")
@staticmethod
def testTargetSlow():
2018-09-23 21:08:44 +02:00
"""!Slow worker thread"""
2018-09-21 14:21:33 +02:00
logging.debug("run testTargetSlow start")
2018-09-23 21:08:44 +02:00
time.sleep(0.51)
2018-09-21 14:21:33 +02:00
logging.debug("run testTargetSlow end")
2018-09-21 13:30:41 +02:00
@pytest.fixture(scope="function")
2018-09-23 21:08:44 +02:00
def useTimerFast(self):
"""!Server a RepeatedTimer instance with fast worker"""
self.testTimer = RepeatedTimer(0.1, Test_Timer.testTargetFast)
yield 1 # server the timer instance
2018-09-23 21:15:37 +02:00
if self.testTimer.isRunning:
2018-09-25 10:08:00 +02:00
assert self.testTimer.stop()
2018-09-23 21:08:44 +02:00
@pytest.fixture(scope="function")
def useTimerSlow(self):
"""!Server a RepeatedTimer instance slow worker"""
self.testTimer = RepeatedTimer(0.1, Test_Timer.testTargetSlow)
2018-09-21 14:21:33 +02:00
yield 1 # server the timer instance
2018-09-23 21:15:37 +02:00
if self.testTimer.isRunning:
2018-09-25 10:08:00 +02:00
assert self.testTimer.stop()
2018-09-21 13:30:41 +02:00
2018-09-23 21:08:44 +02:00
# test cases starts here
def test_timerStartStop(self, useTimerFast):
2018-09-21 13:30:41 +02:00
assert self.testTimer.start()
assert self.testTimer.stop()
2018-09-25 10:08:00 +02:00
def test_timerDoubleStart(self, useTimerFast):
2018-09-23 21:08:44 +02:00
assert self.testTimer.start()
assert self.testTimer.start()
assert self.testTimer.stop()
def test_timerStopNotStarted(self, useTimerFast):
2018-09-25 10:08:00 +02:00
assert self.testTimer.stop()
2018-09-21 13:30:41 +02:00
2018-09-23 21:15:37 +02:00
def test_timerIsRunning(self, useTimerFast):
assert self.testTimer.start()
assert self.testTimer.isRunning
assert self.testTimer.stop()
2018-09-23 21:08:44 +02:00
def test_timerRun(self, useTimerFast):
assert self.testTimer.start()
time.sleep(0.2)
assert self.testTimer.stop()
assert self.testTimer.overdueCount == 0
assert self.testTimer.lostEvents == 0
def test_timerOverdue(self, useTimerSlow):
2018-09-21 13:30:41 +02:00
assert self.testTimer.start()
2018-09-23 21:08:44 +02:00
time.sleep(0.2)
assert self.testTimer.stop()
assert self.testTimer.overdueCount == 1
assert self.testTimer.lostEvents == 5
def test_timerOverdueLong(self, useTimerSlow):
assert self.testTimer.start()
time.sleep(1)
2018-09-21 13:30:41 +02:00
assert self.testTimer.stop()
2018-09-23 21:08:44 +02:00
assert self.testTimer.overdueCount == 2
assert self.testTimer.lostEvents == 10