2018-07-25 01:49:51 -04:00
|
|
|
from io import StringIO
|
2016-12-10 10:33:04 -08:00
|
|
|
import logging
|
|
|
|
|
2016-12-10 11:28:32 -08:00
|
|
|
import mock
|
2018-07-25 01:49:14 -04:00
|
|
|
import unittest
|
2016-12-10 10:33:04 -08:00
|
|
|
from twisted.internet import defer
|
2018-07-25 01:49:14 -04:00
|
|
|
from twisted import trial
|
2016-12-10 10:33:04 -08:00
|
|
|
|
2018-07-25 01:49:14 -04:00
|
|
|
from lbrynet import custom_logger
|
2018-07-25 01:49:51 -04:00
|
|
|
from tests.util import is_android
|
2016-12-10 10:33:04 -08:00
|
|
|
|
|
|
|
|
2018-07-25 01:49:14 -04:00
|
|
|
class TestLogger(trial.unittest.TestCase):
|
2016-12-10 10:33:04 -08:00
|
|
|
def raiseError(self):
|
|
|
|
raise Exception('terrible things happened')
|
|
|
|
|
2016-12-10 11:28:32 -08:00
|
|
|
def triggerErrback(self, callback=None):
|
2016-12-10 10:33:04 -08:00
|
|
|
d = defer.Deferred()
|
|
|
|
d.addCallback(lambda _: self.raiseError())
|
2016-12-10 11:28:32 -08:00
|
|
|
d.addErrback(self.log.fail(callback), 'My message')
|
2016-12-10 10:33:04 -08:00
|
|
|
d.callback(None)
|
|
|
|
return d
|
|
|
|
|
2016-12-10 11:28:32 -08:00
|
|
|
def setUp(self):
|
2018-07-25 01:49:14 -04:00
|
|
|
self.log = custom_logger.Logger('test')
|
2018-07-25 01:49:51 -04:00
|
|
|
self.stream = StringIO()
|
2016-12-10 11:28:32 -08:00
|
|
|
handler = logging.StreamHandler(self.stream)
|
|
|
|
handler.setFormatter(logging.Formatter("%(filename)s:%(lineno)d - %(message)s"))
|
|
|
|
self.log.addHandler(handler)
|
|
|
|
|
2018-07-25 01:49:14 -04:00
|
|
|
@unittest.skipIf(is_android(),
|
|
|
|
'Test cannot pass on Android because the tests package is compiled '
|
|
|
|
'which results in a different method call stack')
|
2016-12-10 10:33:04 -08:00
|
|
|
def test_can_log_failure(self):
|
|
|
|
def output_lines():
|
2016-12-10 11:28:32 -08:00
|
|
|
return self.stream.getvalue().split('\n')
|
2016-12-10 10:33:04 -08:00
|
|
|
|
|
|
|
# the line number could change if this file gets refactored
|
2018-07-25 01:49:14 -04:00
|
|
|
expected_first_line = 'test_customLogger.py:20 - My message: terrible things happened'
|
2016-12-10 10:33:04 -08:00
|
|
|
|
|
|
|
# testing the entirety of the message is futile as the
|
|
|
|
# traceback will depend on the system the test is being run on
|
|
|
|
# but hopefully these two tests are good enough
|
2016-12-10 11:28:32 -08:00
|
|
|
d = self.triggerErrback()
|
2018-07-25 01:49:14 -04:00
|
|
|
d.addCallback(lambda _: self.assertEquals(expected_first_line, output_lines()[0]))
|
2016-12-10 10:33:04 -08:00
|
|
|
d.addCallback(lambda _: self.assertEqual(10, len(output_lines())))
|
|
|
|
return d
|
2016-12-10 11:28:32 -08:00
|
|
|
|
|
|
|
def test_can_log_failure_with_callback(self):
|
|
|
|
callback = mock.Mock()
|
|
|
|
d = self.triggerErrback(callback)
|
|
|
|
d.addCallback(lambda _: callback.assert_called_once_with(mock.ANY))
|
|
|
|
return d
|