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='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 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='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='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 openqa.opensuse.org --job-id 1234

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

Get Job Details

openqa-log-local get-details --host 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 openqa.opensuse.org --job-id 1234

Get Log List

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

To filter log files by name pattern:

openqa-log-local get-log-list --host openqa.opensuse.org --job-id 1234 --name-pattern ".*txt"

Get Log Filename

openqa-log-local get-log-filename --host 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.4.0.tar.gz (9.3 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.4.0-py3-none-any.whl (12.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for openqa_log_local-0.4.0.tar.gz
Algorithm Hash digest
SHA256 a90a297155f98f0b94caf1a258f21f958bfa5923c0e99a8be8570ffc372bbd3e
MD5 88c9365f0decc083e6fa5441db0b76f5
BLAKE2b-256 1c08a3eb4aa0d550c01fc00de4dba3782e0475b7594a499492571e38f95af2ae

See more details on using hashes here.

Provenance

The following attestation bundles were made for openqa_log_local-0.4.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.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for openqa_log_local-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 dc2deb16cf591db843cccdd1463d75026b1948ccd72a610e5f8ec14f6c7302c4
MD5 484fdc43540dff3d25b6d2223ea100b5
BLAKE2b-256 2e722493e637f5b28a9b67a9de732285733be70c36769a75e611713a30c16df1

See more details on using hashes here.

Provenance

The following attestation bundles were made for openqa_log_local-0.4.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