Skip to main content

Translate twisted error logs into OOPS error reports.

Project description

**********************************************************
python-oops-twisted: Error report integration with twisted
**********************************************************

Copyright (c) 2011, Canonical Ltd

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.

You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.

The oops_twisted package provides integration glue between logged twisted
errors (via the twisted.log api) and the oops error reporting system
(http://pypi.python.org/pypi/oops).

Dependencies
============

* Python 2.6+

* oops (http://pypi.python.org/pypi/oops)

* Twisted

Testing Dependencies
====================

* subunit (http://pypi.python.org/pypi/python-subunit) (optional)

* testtools (http://pypi.python.org/pypi/testtools)

Usage
=====

* Setup your configuration::

>>> from oops_twisted import Config
>>> config = Config()

Note that you will probably want at least one publisher, or your reports will
be silently discarded.

* When adding publishers, either wrap 'normal' OOPS publishers in deferToThread
or similar, or use native Twisted publishers. For instance::

>>> from functools import partial
>>> config.publishers.append(partial(deferToThread, blocking_publisher))

A helper 'defer_publisher' is supplied to do this for your convenience.

* create an OOPS log observer::

>>> from oops_twisted import OOPSObserver
>>> observer = OOPSObserver(config)

* And enable it::

>>> from twisted.log import addObserver
>>> addObserver(observer.emit)

* This is typically used to supplement regular logging, e.g. you might
initialize normal logging to a file first::

>>> twisted.log.startLogging(logfile)

The OOPSObserver will discard all non-error log messages, and convert error log
messages into OOPSes using the oops config.

Optionally, you can provide OOPSObserver with a second observer to delegate
too. Any event that is not converted into an OOPS is passed through unaltered.
Events that are converted to OOPSes have a new event second to the second
observer which provides the OOPS id and the failure name and value::

>>> observer = OOPSObserver(config, twisted.log.PythonLoggingObserver().emit)

For more information see pydoc oops_twisted.

Installation
============

Either run setup.py in an environment with all the dependencies available, or
add the working directory to your PYTHONPATH.

Development
===========

Upstream development takes place at https://launchpad.net/python-oops-twisted.
To setup a working area for development, if the dependencies are not
immediately available, you can use ./bootstrap.py to create bin/buildout, then
bin/py to get a python interpreter with the dependencies available.

To run the tests use the runner of your choice, the test suite is
oops_twisted.tests.test_suite.

For instance::

$ bin/py -m testtools.run oops_twisted.tests.test_suite

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

oops_twisted-0.0.1.tar.gz (4.6 kB view details)

Uploaded Source

File details

Details for the file oops_twisted-0.0.1.tar.gz.

File metadata

File hashes

Hashes for oops_twisted-0.0.1.tar.gz
Algorithm Hash digest
SHA256 8a043c1fce94e32bc41d9c7903a48d18e2c641d925fda98ac8cdbcb345ab0acb
MD5 ed3ea5dd815509846a4484bf801da5ca
BLAKE2b-256 aa776061886a13c400a278085314a6f4487303db64c5c84d9a0e5ffc06c3750b

See more details on using hashes here.

Supported by

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