Skip to main content

No project description provided

Project description

pytest db plugin

What

  • uploading test stdout & stderr to a DB

Why

  • keeping all stdout & stderr ready in a DB for easy debugging and comparison

How

Flow

  1. pytest test ends
  2. pytest test teardown starts
  3. plugin starts
  4. plugin connects to DB
  5. plugin collects all sources
  6. plugin uploads all sources
  7. plugin ends DB connection
  8. plugin ends

Installtion

  • for default db client: pip install pytest-db
  • for es db client: pip install pytest-db[es]
Hosting
  • the package will be hosted on global pypi

Invocation

  • pytest ...
    • as long as the plugin is installed, and the url is provided, the plugin will attempt to upload
    • if the plugin is installed but a config file is not present / malformed / missing url, a warning will be displayed in the end of the test

Configuration

  • minimal
  • optional
    • not having one will not break the test
    • not having one will mean nothing is uploaded UNLESS the url param is passed in the invocation command
      • a default db client will be used in such cases and the data will be written into "/tmp"
  • will be located in invocation directory
  • name: ".config.toml"
  • allows for additionalizing:
    1. DB url and authentication
    2. DB interaction failure should fail test [default: false]
    3. sources to upload [default: stdout, stderr]
  • toml format
type = <type>
url = <url>
index = <index>
must-upload = false

Compitability

Supported DB

  • local file system (local)
  • Elasticsearch (es)

Additional data

  • each upload can include additional keys and values
  • the key will be defined in the config file
  • the value will be defined as a either
    • const
    • function that will be invoked in after collecting the doc
    • supported function languages:
      • bash
      • python
    • config file example:
...
[additional-data]
[additional-data.consts]
name = 'my-name'

[additional-data.bash]
os = 'lsb_release -sr'

[additional-data.python]
current directory = 'import os; print(os.getcwd())' 
  • python functions will be called using exec
  • bash functions will be called using subprocess.check_output

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-db-plugin-0.0.0.0.0.1.tar.gz (4.6 kB view hashes)

Uploaded Source

Built Distribution

pytest_db_plugin-0.0.0.0.0.1-py3-none-any.whl (7.0 kB view hashes)

Uploaded Python 3

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