test for error on getUpdates and began to test webhook

This commit is contained in:
Jannes Höke 2015-11-21 21:22:58 +01:00
parent 7c9928c58f
commit 6a80a33aef

View file

@ -18,7 +18,7 @@
# along with this program. If not, see [http://www.gnu.org/licenses/]. # along with this program. If not, see [http://www.gnu.org/licenses/].
""" This module contains a object that represents Tests for BotEventHandler """ """ This module contains a object that represents Tests for BotEventHandler """
import logging
import unittest import unittest
import sys import sys
from time import sleep from time import sleep
@ -32,6 +32,16 @@ from telegram.broadcaster import run_async
from tests.base import BaseTest from tests.base import BaseTest
from threading import Lock from threading import Lock
# Enable logging
root = logging.getLogger()
root.setLevel(logging.INFO)
ch = logging.StreamHandler(sys.stdout)
ch.setLevel(logging.WARN)
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
ch.setFormatter(formatter)
root.addHandler(ch)
class BotEventHandlerTest(BaseTest, unittest.TestCase): class BotEventHandlerTest(BaseTest, unittest.TestCase):
"""This object represents Tests for Telegram Bot.""" """This object represents Tests for Telegram Bot."""
@ -153,6 +163,14 @@ class BotEventHandlerTest(BaseTest, unittest.TestCase):
sleep(.1) sleep(.1)
self.assertEqual(self.received_message, error) self.assertEqual(self.received_message, error)
def test_errorOnGetUpdates(self):
print('Testing errorOnGetUpdates')
self.beh.bot = MockBot('', raise_error=True)
self.beh.broadcaster.addErrorHandler(self.errorHandlerTest)
self.beh.start_polling(0.05)
sleep(.1)
self.assertEqual(self.received_message.message, "Test Error")
def test_addTypeHandler(self): def test_addTypeHandler(self):
print('Testing addTypeHandler') print('Testing addTypeHandler')
self.beh.bot = MockBot('') self.beh.bot = MockBot('')
@ -173,12 +191,31 @@ class BotEventHandlerTest(BaseTest, unittest.TestCase):
self.assertEqual(self.received_message, 'Test4') self.assertEqual(self.received_message, 'Test4')
self.assertEqual(self.message_count, 2) self.assertEqual(self.message_count, 2)
def test_webhook(self):
""" Work in progress """
print('Testing @run_async')
self.beh.bot = MockBot('Test4', messages=2)
self.beh.broadcaster.addTelegramMessageHandler(
self.telegramHandlerTest)
self.beh.start_webhook('127.0.0.1', 8000,
'./tests/test_boteventhandler.py',
'./tests/test_boteventhandler.py',
listen='127.0.0.1')
sleep(1)
# Error is logged - run self.beh.httpd.serve_forever() in a separate
# Thread here, then send a json-encrypted update via request.post()?
# self.assertEqual(self.received_message, 'Test4')
self.assertEqual(self.message_count, 0)
class MockBot: class MockBot:
def __init__(self, text, messages=1): def __init__(self, text, messages=1, raise_error=False):
self.text = text self.text = text
self.send_messages = messages self.send_messages = messages
self.raise_error = raise_error
self.token = "TOKEN"
pass pass
def mockUpdate(self, text): def mockUpdate(self, text):
@ -197,7 +234,9 @@ class MockBot:
timeout=0, timeout=0,
network_delay=2.): network_delay=2.):
if self.send_messages >= 2: if self.raise_error:
raise TelegramError('Test Error')
elif self.send_messages >= 2:
self.send_messages -= 2 self.send_messages -= 2
return self.mockUpdate(self.text), self.mockUpdate(self.text) return self.mockUpdate(self.text), self.mockUpdate(self.text)
elif self.send_messages == 1: elif self.send_messages == 1: