Skip to main content

Plugin configuring handlers for loggers from Python logging module.

Project description

Pypi Package Version Supported Python Versions Documentation Status Coverage Status Travis-CI Build Status AppVeyor-CI Build Status

Pytest-logger is a pytest plugin configuring handlers for loggers from Python logging module.

You can install pytest-logger via pip from PyPI:

$ [sudo] pip install pytest-logger

Plugin puts logs on per-logger basis to:

  • standard output,

  • files within log-specific directory under pytest’s tmpdir_factory session directory.

You can setup plugin using hooks:

#conftest.py
import os

def pytest_logger_stdoutloggers(item):
    return ['foo', 'bar']

def pytest_logger_fileloggers(item):
    return ['foo', 'bar']

def pytest_logger_logdirlink(config):
    return os.path.join(os.path.dirname(__file__), 'mylogs')

have logging tests or libraries (including fixtures):

#test_something.py
import pytest
import logging

foo = logging.getLogger('foo')
foo.setLevel(logging.INFO)

bar = logging.getLogger('bar')

@pytest.yield_fixture(scope='session')
def session_thing():
    foo.info('constructing session thing')
    yield
    foo.info('destroying session thing')

@pytest.yield_fixture
def testcase_thing():
    foo.info('constructing testcase thing')
    yield
    foo.info('destroying testcase thing')

def test_one(session_thing, testcase_thing):
    foo.info('one executes')
    bar.warning('this test does nothing aside from logging')

def test_two(session_thing, testcase_thing):
    foo.info('two executes')
    bar.warning('neither does this')

and expect output in terminal (if not captured):

$ py.test -s -v
(...)
test_something.py::test_one
00:00.001 inf foo: constructing session thing
00:00.001 inf foo: constructing testcase thing
00:00.002 inf foo: one executes
00:00.002 wrn bar: this test does nothing aside from logging
PASSED
00:00.002 inf foo: destroying testcase thing

test_something.py::test_two
00:00.000 inf foo: constructing testcase thing
00:00.000 inf foo: two executes
00:00.000 wrn bar: neither does this
PASSED
00:00.001 inf foo: destroying testcase thing
00:00.001 inf foo: destroying session thing
(...)

and - the same - in filesystem:

$ file mylogs
mylogs: symbolic link to `/tmp/pytest-of-aurzenligl/pytest-48/logs'

$ tree mylogs
mylogs
`-- test_something.py
    |-- test_one
    |   |-- bar
    |   `-- foo
    `-- test_two
        |-- bar
        `-- foo

Distributed under the terms of the MIT license, pytest-logger is free and open source software.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pytest-logger-0.1.4.tar.gz (20.3 kB view details)

Uploaded Source

Built Distribution

pytest_logger-0.1.4-py2.py3-none-any.whl (8.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pytest-logger-0.1.4.tar.gz.

File metadata

  • Download URL: pytest-logger-0.1.4.tar.gz
  • Upload date:
  • Size: 20.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for pytest-logger-0.1.4.tar.gz
Algorithm Hash digest
SHA256 6b841e1c60c3cc5a94de28f7b4cd8b22cd1380793a15a9b60b94d8e31e49793a
MD5 d57e2760b0f70ec00eaf985428850b26
BLAKE2b-256 1a338313031c2ce1fd14423bbab010cab69c2ab10bd56d1640d6eeb416a81b21

See more details on using hashes here.

File details

Details for the file pytest_logger-0.1.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_logger-0.1.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 ec79b45630214f7879d46467c3969f79f6170ed078ddc16786ccb42f016656c4
MD5 6738e8f05dbb43424f33696212c97fc9
BLAKE2b-256 0b5cbb04776062f07e9183741c052b3da1a10004338f07a2711a2089a1f90e8a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page