Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: consider version when getting CRDs for validating descriptors #6784

Merged
merged 1 commit into from
Oct 16, 2024

Conversation

tthvo
Copy link
Contributor

@tthvo tthvo commented Jul 15, 2024

Description of the change:

An additional condition is included for matching apiVersion of example CRs with CRD version when searching for the CRD in the CSV.

Motivation for the change:

Previously, the olm-spec-descriptors scorecard test failed when multiple versions of CRD are included in the CSV. The CRs specified in alm-examples annotations are validated only against the first matched CRD (by kind), which is incorrect. This ensures the CRD with correct kind and version is selected for descriptor scorecard test.

Checklist

If the pull request includes user-facing changes, extra documentation is required:

Fixes #6781

@openshift-ci openshift-ci bot requested review from acornett21 and oceanc80 July 15, 2024 10:12
@acornett21
Copy link
Contributor

@tthvo At face value I don't think this PR works, since this info only comes from the alm-examples, and those do not have a versions. The code to get the CR from the bundle is here, maybe I'm missing something.

@tthvo
Copy link
Contributor Author

tthvo commented Jul 15, 2024

@tthvo At face value I don't think this PR works, since this info only comes from the alm-examples, and those do not have a versions. The code to get the CR from the bundle is here, maybe I'm missing something.

Hi @acornett21, I guess what I meant is to compare the apiVersion of the object in alm-examples annotations with the owned CRD's version field.

This is a very similar issue/fix to:

@tthvo
Copy link
Contributor Author

tthvo commented Jul 15, 2024

Sorry I forgot to include a way to test these changes. You can try:

Run: operator-sdk scorecard -n default -s default quay.io/thvo/cryostat-operator-bundle:4.0.0-olm --selector=suite=olm. That should succeed. Previously, if you use the scorecard image on quay.io/operator-framework, it fails.

@ebaron
Copy link

ebaron commented Aug 15, 2024

Hi, any update on getting this fixed? Our workaround of removing the v1beta1 CRD from alm-examples is generating the following warning with each build/test:
Warning: Value operator.cryostat.io/v1beta1, Kind=Cryostat: provided API should have an example annotation

It would be nice to have clean test results, but that depends on this bug being fixed.

@acornett21
Copy link
Contributor

@tthvo Could you rebase your PR? thanks.

An additional condition is included for matching `apiVersion` of example CRs with CRD `version` when searching for the CRD in the CSV. This ensures the correct CRD version is selected for validations.

Closes operator-framework#6781

Signed-off-by: Thuan Vo <[email protected]>
@tthvo
Copy link
Contributor Author

tthvo commented Oct 15, 2024

@tthvo Could you rebase your PR? thanks.

Hey @acornett21, I rebased it now (with a small cleanup). Thanks :D

@acornett21
Copy link
Contributor

/override docs

Copy link

openshift-ci bot commented Oct 16, 2024

@acornett21: Overrode contexts on behalf of acornett21: docs

In response to this:

/override docs

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository.

@acornett21 acornett21 merged commit f542f5d into operator-framework:master Oct 16, 2024
23 of 24 checks passed
@tthvo tthvo deleted the alm-scorecard branch October 16, 2024 21:05
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

olm-spec-descriptors test validates alm-examples with the incorrect CRD
3 participants