debian:qa-results

Category debian:qa-results

This collection can host all the QA results for all the packages in a given suite. We thus have different kind of items for each QA task.

Common features across all QA results

The name of the collection item is always {task_name}_{package}_{version}_{architecture}_{work_request_id} substituting values from the per-item data described below.

  • Variables when adding items: see “Per-item data” below

  • Data:

    • suite_collection (Single lookup, required): the debian:suite collection for which the collection is storing the QA results.

    • old_items_to_keep: number of old items to keep. Defaults to 5. For each task/package/architecture combination, the collection always keeps the given number of most recent entries (based on the timestamp field). The cleanup is automatically done when adding new items.

      Note

      At some point, we may need more advanced logic than this, for instance to clean up QA results about packages that are gone from the corresponding suite.

  • Per-item data:

    • task_name (inferred from work request when adding item): the name of the task that generated the QA result (so autopkgtest, lintian, piuparts, blhc)

    • package: the name of the source package being analyzed, or the source package from which the binary package being analyzed was built

    • version: the version of the source package being analyzed, or the source package from which the binary package being analyzed was built

    • architecture: source for a source analysis, or the appropriate architecture name for a binary analysis

    • timestamp: a Unix timestamp (cf. date +%s) used to estimate the freshness of the QA result, can often be usefully tied to the Date field of the package repository in which the analysis was performed.

    • work_request_id: the ID of the WorkRequest that generated the QA result

    • result (inferred from work request when adding item): duplicates the string value of the result field of the associated WorkRequest

  • Lookup names:

    • latest:TASKNAME_PACKAGE_ARCHITECTURE: the latest QA result for tasks named TASKNAME for the source package named PACKAGE on ARCHITECTURE.

Specification for lintian

The collection item is a debian:lintian artifact. The collection contains items for the source and for all architectures.

A lintian analysis is outdated if:

  • either the underlying source or binary packages are outdated (i.e. have different version numbers) compared to what’s available in the debian:suite collection

  • or the lintian version used to perform the analysis is older than the version available in the debian:suite collection

Specification for autopkgtest

The collection item is a debian:autopkgtest artifact. The collection contains items for all architectures (but not for the source).

An autopkgtest analysis is outdated if:

  • either the underlying source or binary packages are outdated (i.e. have different version numbers) compared to what’s available in the debian:suite collection

  • or the timestamp of the analysis is older than 30 days compared to the Date timestamp of the debian:suite collection

Specification for piuparts

The collection item is a bare data item of category debian:qa-result with all the common per-item data described above. The collection contains items for all architectures (but not for the source).

A piuparts analysis is outdated if the underlying binary packages are outdated (i.e. have different version numbers) compared to what’s available in the debian:suite collection.

Note

The lack of piuparts artifact means that we don’t have any information about the binary packages that were analyzed except if we lookup the details of the WorkRequest. That’s probably going too far so instead we will likely compare based on the source version documented in the per-item data.

Filed #805 to think about introducing a proper artifact at some point.

Specification for blhc

The collection item is a debian:blhc artifact. The collection contains items for all architectures (but not for the source).

A blhc analysis is outdated if the underlying source package is outdated (i.e. has a different version number) compared to what’s available in the debian:suite collection. The comparison needs to be performed based on the metadata of the linked debian:package-build-log artifact.

Specification for debdiff

The DebDiff QA task does not contribute any item to the debian:qa-results because it does not provide any validation of a single target artifact.

By its nature, the task already performs a comparison between the original version and the new version. And the result of the comparison can’t easily be used to draw any conclusion about the update, it is up to human reviewers to decide of that.