mirror of
https://github.com/theupdateframework/python-tuf
synced 2026-05-24 10:08:28 +00:00
133 lines
3.1 KiB
Python
Executable file
133 lines
3.1 KiB
Python
Executable file
#!/usr/bin/env python
|
|
|
|
"""
|
|
<Program Name>
|
|
test_log.py
|
|
|
|
<Authors>
|
|
Vladimir Diaz <vladimir.v.diaz@gmail.com>
|
|
|
|
<Started>
|
|
May 1, 2014.
|
|
|
|
<Copyright>
|
|
See LICENSE for licensing information.
|
|
|
|
<Purpose>
|
|
Unit test for 'log.py'.
|
|
"""
|
|
|
|
import logging
|
|
import unittest
|
|
|
|
import tuf
|
|
import tuf.log
|
|
|
|
logger = logging.getLogger('tuf.test_log')
|
|
|
|
log_levels = [logging.CRITICAL, logging.ERROR, logging.WARNING,
|
|
logging.INFO, logging.DEBUG]
|
|
|
|
|
|
class TestLog(unittest.TestCase):
|
|
|
|
|
|
def tearDown(self):
|
|
tuf.log.remove_console_handler()
|
|
|
|
|
|
|
|
def test_set_log_level(self):
|
|
# Test normal case.
|
|
global log_levels
|
|
global logger
|
|
|
|
tuf.log.set_log_level()
|
|
self.assertTrue(logger.isEnabledFor(logging.DEBUG))
|
|
|
|
for level in log_levels:
|
|
tuf.log.set_log_level(level)
|
|
self.assertTrue(logger.isEnabledFor(level))
|
|
|
|
# Test for improperly formatted argument.
|
|
self.assertRaises(tuf.FormatError, tuf.log.set_log_level, '123')
|
|
|
|
# Test for invalid argument.
|
|
self.assertRaises(tuf.FormatError, tuf.log.set_log_level, 51)
|
|
|
|
|
|
|
|
def test_set_filehandler_log_level(self):
|
|
# Normal case. Default log level.
|
|
tuf.log.set_filehandler_log_level()
|
|
|
|
# Expected log levels.
|
|
for level in log_levels:
|
|
tuf.log.set_log_level(level)
|
|
|
|
# Test for improperly formatted argument.
|
|
self.assertRaises(tuf.FormatError, tuf.log.set_filehandler_log_level, '123')
|
|
|
|
# Test for invalid argument.
|
|
self.assertRaises(tuf.FormatError, tuf.log.set_filehandler_log_level, 51)
|
|
|
|
|
|
|
|
|
|
def test_set_console_log_level(self):
|
|
# Test setting a console log level without first adding one.
|
|
self.assertRaises(tuf.Error, tuf.log.set_console_log_level)
|
|
|
|
# Normal case. Default log level. Setting the console log level first
|
|
# requires adding a console logger.
|
|
tuf.log.add_console_handler()
|
|
tuf.log.set_console_log_level()
|
|
|
|
# Expected log levels.
|
|
for level in log_levels:
|
|
tuf.log.set_console_log_level(level)
|
|
|
|
# Test for improperly formatted argument.
|
|
self.assertRaises(tuf.FormatError, tuf.log.set_console_log_level, '123')
|
|
|
|
# Test for invalid argument.
|
|
self.assertRaises(tuf.FormatError, tuf.log.set_console_log_level, 51)
|
|
|
|
|
|
|
|
def test_add_console_handler(self):
|
|
# Normal case. Default log level.
|
|
tuf.log.add_console_handler()
|
|
|
|
# Adding a console handler when one has already been added.
|
|
tuf.log.add_console_handler()
|
|
|
|
# Expected log levels.
|
|
for level in log_levels:
|
|
tuf.log.set_console_log_level(level)
|
|
|
|
# Test for improperly formatted argument.
|
|
self.assertRaises(tuf.FormatError, tuf.log.add_console_handler, '123')
|
|
|
|
# Test for invalid argument.
|
|
self.assertRaises(tuf.FormatError, tuf.log.add_console_handler, 51)
|
|
|
|
try:
|
|
raise TypeError('Test exception output in the console.')
|
|
|
|
except TypeError as e:
|
|
logger.error(e)
|
|
|
|
|
|
def test_remove_console_handler(self):
|
|
# Normal case.
|
|
tuf.log.remove_console_handler()
|
|
|
|
# Removing a console handler that has not been added. Logs a warning.
|
|
tuf.log.remove_console_handler()
|
|
|
|
|
|
|
|
# Run unit test.
|
|
if __name__ == '__main__':
|
|
unittest.main()
|