Skip to main content

Create a local cache of openQA job log files

Project description

openQA log local

Library and cli to locally collect and inspect logs from openQA

File will be locally cached on disk, downloaded and read transparently.

Dependency

This package internally depend on openQA-python-client: please refer to documentation about openQA autentication.

Installation

pip install openqa_log_local

To install the package from the source code you can use uv:

uv pip install -e .

Usage

Library

To use the library in your Python project, you first need to import the openQA_log_local class:

from openqa_log_local import openQA_log_local

Then, you can create an instance of the class, providing the openQA host URL:

oll = openQA_log_local(host='http://openqa.opensuse.org')

# Get job details
log_details = oll.get_details(job_id=1234)

# Get a list of log files associated to an openQA job.
# No download any log file yet.
log_list = oll.get_log_list(job_id=1234)
log_txt_list = oll.get_log_list(job_id=4567, name_pattern=r".*\\.txt")

# Get content of a single log file. The file is downloaded to the cache
# if not already available locally.
# All the log file content is returned in `log_data`
log_data = oll.get_log_data(job_id=1234, filename=log_list[3])

# Get absolute path with filename of a single log file from the cache.
# The file is downloaded to the cache if not already available locally.
log_filename = oll.get_log_filename(job_id=1234, filename=log_list[3])

Cache can be configured:

oll = openQA_log_local(
    host='http://openqa.opensuse.org',
    cache_location='/home/user/.openqa_cache',
    max_size=100000,
    time_to_live=3600)

... but also ignored and always refreshed :

oll = openQA_log_local(host='http://openqa.opensuse.org', time_to_live=0)

CLI

The package also provides a command-line interface (CLI) for interacting with openQA logs.

To see INFO and DEBUG messages, you can use the --log-level option:

uv run openqa-log-local --log-level INFO get-log-list --host http://openqaworker15.qa.suse.cz --job-id 353681

This will show messages indicating whether there was a cache hit or miss.

Get Job Details

openqa-log-local get-details --host http://openqa.opensuse.org --job-id 1234

Run via uv if you have used uv to install it

uv run openqa-log-local get-details --host http://openqa.opensuse.org --job-id 1234

Get Log List

openqa-log-local get-log-list --host http://openqa.opensuse.org --job-id 1234

Get Log Data

openqa-log-local get-log-data --host http://openqa.opensuse.org --job-id 1234 --filename autoinst-log.txt

Get Log Filename

openqa-log-local get-log-filename --host http://openqa.opensuse.org --job-id 1234 --filename autoinst-log.txt

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

openqa_log_local-0.1.0.tar.gz (6.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

openqa_log_local-0.1.0-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file openqa_log_local-0.1.0.tar.gz.

File metadata

  • Download URL: openqa_log_local-0.1.0.tar.gz
  • Upload date:
  • Size: 6.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for openqa_log_local-0.1.0.tar.gz
Algorithm Hash digest
SHA256 62717196be1377363cead8c802c61de3f3cf7e3772fe2a1ddd40240dc1cc9886
MD5 6d98708a7e275a70526e425e242d8718
BLAKE2b-256 8a837ddd5f8e15995caf57aa088cf1a01a88ba7a08160f01404e57e8a924f93c

See more details on using hashes here.

Provenance

The following attestation bundles were made for openqa_log_local-0.1.0.tar.gz:

Publisher: publish.yml on mpagot/openqa_log_local

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file openqa_log_local-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for openqa_log_local-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 17aafffa58a21e5ff7973f4f4a288224db837d59607748241d0413f7b02c1c32
MD5 4ca8c19289c37f27ca0b334a43c6c801
BLAKE2b-256 7c80c8cc90f432894ad9b9e654375cecdae64bc753b649b81d22843774bfdc83

See more details on using hashes here.

Provenance

The following attestation bundles were made for openqa_log_local-0.1.0-py3-none-any.whl:

Publisher: publish.yml on mpagot/openqa_log_local

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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