Skip to content
This repository has been archived by the owner on Jan 17, 2025. It is now read-only.

examples,tests: add new test_against_images_ref.py test #188

Merged
merged 5 commits into from
Sep 4, 2024

Conversation

mvo5
Copy link
Contributor

@mvo5 mvo5 commented Sep 4, 2024

This PR adds a new test that uses the images library to generate reference manifests and then compares the output of an otk run against the reference image. This allows us to refactor the otk images and always be confident that the result matches what "images" produces.

It also converts all the examples to be just "verbatim" versions of the images library result so that it can be a useful starting point to refactor them.

Note that currently the reference manifests are part of the repository for convenience. It would be nicer to generate them on the fly but that is hard(er), see the comments in the code.

Note also that we most likely will have to do something about the "{boot,root}_fs_uuid" in the reference images as they will not match with the ones generated by otk-gen-partition-table as the calls into rand are in a different order yielding predictable but different result between the two. We can cross this bridge when we reach it though and it's fairly simple (or exclude at the diff level).

When we add the dnfjson external we will need to teach it to generate fake urls/shas just like gen-manifests so that we can compare the results of a real run.

The next steps should be to extract the common pieces into a nice structure (i.e. build #169 on top of this one) and integrate the externals (i.e. start with partition, c.f. #186)

[clean split out from https://github.com//pull/186]

@mvo5 mvo5 requested review from achilleas-k and supakeen September 4, 2024 15:33
supakeen
supakeen previously approved these changes Sep 4, 2024
Copy link
Member

@supakeen supakeen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

<3 seems like some of the manifest names don't match what's expected in the testcase but that should be a minor fix.

@mvo5
Copy link
Contributor Author

mvo5 commented Sep 4, 2024

<3 seems like some of the manifest names don't match what's expected in the testcase but that should be a minor fix.

Thank you! Yeah, it also looks like "yaml.dump()" is not generating yamllint clean yaml :(

[edit: https://github.com/yaml/pyyaml/issues/234#issuecomment-765894586 is a workaround but we still run into yamllint errors because the lines are too long]

mvo5 added 3 commits September 4, 2024 18:49
This commit adds the infrastructure to test that a manifest generated
by the `images` library is identical to the equivalent version generated
via otk.

As a first step it adds the centos-9-x86_64-qcow2 manifest.
This commit adds otk manifests based on the "images" library
reference images.
This commit adds otk manifests based on the "images" library
reference images.
@mvo5 mvo5 force-pushed the have-images-reference-test branch from a45d665 to a84b65c Compare September 4, 2024 16:50
@mvo5 mvo5 force-pushed the have-images-reference-test branch from a84b65c to 33a616e Compare September 4, 2024 16:53
@supakeen supakeen added this pull request to the merge queue Sep 4, 2024
Merged via the queue into osbuild:main with commit 92f344c Sep 4, 2024
3 checks passed
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants