sanic/tests/test_logging.py

58 lines
1.3 KiB
Python
Raw Permalink Normal View History

import uuid
2017-07-24 11:21:15 +01:00
from importlib import reload
from sanic.config import LOGGING
2016-12-23 05:00:57 +00:00
from sanic.response import text
from sanic import Sanic
from io import StringIO
import logging
logging_format = '''module: %(module)s; \
function: %(funcName)s(); \
message: %(message)s'''
2017-07-24 11:21:15 +01:00
def reset_logging():
logging.shutdown()
reload(logging)
2016-12-23 05:00:57 +00:00
def test_log():
log_stream = StringIO()
for handler in logging.root.handlers[:]:
logging.root.removeHandler(handler)
2016-12-23 05:00:57 +00:00
logging.basicConfig(
format=logging_format,
level=logging.DEBUG,
stream=log_stream
)
log = logging.getLogger()
2017-01-17 23:38:20 +00:00
app = Sanic('test_logging')
rand_string = str(uuid.uuid4())
2016-12-23 05:00:57 +00:00
@app.route('/')
def handler(request):
log.info(rand_string)
2016-12-23 05:00:57 +00:00
return text('hello')
2017-02-14 19:51:20 +00:00
request, response = app.test_client.get('/')
log_text = log_stream.getvalue()
assert rand_string in log_text
2016-12-23 05:00:57 +00:00
2017-07-24 11:21:15 +01:00
def test_default_log_fmt():
reset_logging()
Sanic()
for fmt in [h.formatter for h in logging.getLogger('sanic').handlers]:
assert fmt._fmt == LOGGING['formatters']['simple']['format']
reset_logging()
Sanic(log_config=None)
for fmt in [h.formatter for h in logging.getLogger('sanic').handlers]:
assert fmt._fmt == "%(asctime)s: %(levelname)s: %(message)s"
if __name__ == "__main__":
2016-12-23 05:00:57 +00:00
test_log()