Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

robotbackgroundlogger

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

robotbackgroundlogger

A helper module for logging to Robot Framework log from background threads.

  • 1.2
  • PyPI
  • Socket score

Maintainers
1

.. default-role:: code

Background logging support to test libraries

This helper module is indented to be used by Robot Framework test libraries that run keywords in background using threads and that want those threads to be able to log. By default, as explained in Robot Framework User Guide__, messages logged by threads using the programmatic APIs are ignored, and results of logging using the standard output are undefined.

This module provides a custom logger that works mostly like the standard robot.api.logger__, but also stores messages logged by background threads. It also provides a method the main thread can use to forward the logged messages to Robot Framework's log.

Robot Background Logger is hosted in Github__ and downloads can be found from PYPI__. Installation is easiest done with pip::

pip install robotbackgroundlogger

Starting from version 1.2 this module support both Python 2 and Python 3.

__ http://robotframework.org/robotframework/latest/RobotFrameworkUserGuide.html#communication-when-using-threads __ https://robot-framework.readthedocs.org/en/latest/autodoc/robot.api.html#module-robot.api.logger __ https://github.com/robotframework/robotbackgroundlogger __ https://pypi.python.org/pypi/robotbackgroundlogger

Usage

The logger can be taken into use like this:

.. sourcecode:: python

from robotbackgroundlogger import BackgroundLogger
logger = BackgroundLogger()

After that logger can be used mostly like robot.api.logger:

.. sourcecode:: python

logger.debug('Hello, world!')
logger.info('<b>HTML</b> example', html=True)

When used by the main thread, messages will be logged immediately exactly like with robot.api.logger. When used by other threads, messages will be stored internally. They can be later logged by the main thread by running:

.. sourcecode:: python

logger.log_background_messages()

If you want to log only messages logged by a certain thread, you can use pass the name of the thread as an argument:

.. sourcecode:: python

logger.log_background_messages('Example thread')

Logged messages are also removed from the internal message storage. It is possible to do that also without logging:

.. sourcecode:: python

# Remove all messages
logger.reset_background_messages()
# Remove messages logged by the named thread
logger.reset_background_messages('Another thread')

Example

example.py__ library that is used by example.robot__ shows how this module can be used in practice. You can run the example like::

pybot example.robot

__ https://github.com/robotframework/robotbackgroundlogger/blob/master/example.py __ https://github.com/robotframework/robotbackgroundlogger/blob/master/example.robot

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc