Skip to content

Conversation

dtfranz
Copy link
Contributor

@dtfranz dtfranz commented Nov 2, 2024

Test Registry

Adds a bare-bones test registry and a folder tree for our test images.

This PR aims to improve our test infrastructure by removing scripts and external images for registry operations in favor of bare-bones tools built in golang using well-known libraries (go-containerregistry in particular).

Structure

The PR adds two tools:registry and push. It also aggregates all our image-related makefile targets into one: image-registry.

registry

Just about the simplest possible image registry that can be built using the go-containerregistry lib. See README here.

push

Utilizes crane within go-containerregistry to build and push our catalog and bundle images. It uses a directory walker which is intended to make adding future test bundles and catalogs easily. It also (IMO - totally subjective) makes our test image collection more WYSIWYG by clearly showing all the images and tags we use in the folder rather than hiding them in scripts or makefiles.

See README here for more info on the expected folder structure.

make image-registry

Builds the registry and push binaries, bundles them into one image, then deploys them both. registry is deployed essentially as before. push executes as a job, building all the images bundled inside of it then pushing them to the specified registry address.

TODOs / Follow-Ups

PR size is currently huge due to the amount of prometheus manifests being copied for each bundle tag... I'm open to suggestions on how we could address this. Maybe we could remove the prometheus-operator in favor of a test operator with fewer manifests? Addressed this, see below.

Remaining items to address:

  • Either: Done - going with option C for now.
  • A: Find a better way to organize tags such that we need not have many copies of the same manifests.
  • B: Keep the current folder structure for tags but simplify the manifests we're using in test to reduce file count/complexity.
  • C: Modify the catalog yaml so that every version of prometheus-operator uses the same bundle image (v1.0.0). We were previously doing this anyway essentially because each tag we created for this bundle had the exact same content.
  • Metadata reading for bundle images is using one path instead of reading dynamically (which we can get away with right now because all the bundles are identical). Done.
  • Configurable cert/key path for registry (not super critical right now). Done.
  • Use mounted secrets for push instead of crane.Insecure (also not critical). Done.

Description

Reviewer Checklist

  • API Go Documentation
  • Tests: Unit Tests (and E2E Tests, if appropriate)
  • Comprehensive Commit Messages
  • Links to related GitHub Issue(s)

@openshift-ci openshift-ci bot added the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Nov 2, 2024
Copy link

netlify bot commented Nov 2, 2024

Deploy Preview for olmv1 ready!

Name Link
🔨 Latest commit 2f2d220
🔍 Latest deploy log https://app.netlify.com/sites/olmv1/deploys/672bb2bd23a9f300081148f7
😎 Deploy Preview https://deploy-preview-1425--olmv1.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

@dtfranz dtfranz force-pushed the e2e-test-registry branch 3 times, most recently from fa691f6 to 2355c52 Compare November 4, 2024 18:36
Copy link

codecov bot commented Nov 4, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 73.45%. Comparing base (482a66d) to head (2f2d220).
Report is 4 commits behind head on main.

Additional details and impacted files
@@            Coverage Diff             @@
##             main    #1425      +/-   ##
==========================================
+ Coverage   73.42%   73.45%   +0.03%     
==========================================
  Files          42       42              
  Lines        3063     3063              
==========================================
+ Hits         2249     2250       +1     
+ Misses        641      640       -1     
  Partials      173      173              
Flag Coverage Δ
e2e 55.20% <ø> (-0.14%) ⬇️
unit 52.59% <ø> (+0.03%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@dtfranz dtfranz marked this pull request as ready for review November 4, 2024 18:59
@dtfranz dtfranz requested a review from a team as a code owner November 4, 2024 18:59
@openshift-ci openshift-ci bot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Nov 4, 2024
@dtfranz dtfranz changed the title 🌱 WIP: Test Registry 🌱 Test Registry Nov 4, 2024
@tmshort
Copy link
Contributor

tmshort commented Nov 4, 2024

verdiff is complaining about new go.mod files; we should be ok with that.

@tmshort
Copy link
Contributor

tmshort commented Nov 4, 2024

I have a wicked simple bundle that can be installed: https://github.com/tmshort/test-image
It consists of just a configmap

@dtfranz
Copy link
Contributor Author

dtfranz commented Nov 4, 2024

I have a wicked simple bundle that can be installed: https://github.com/tmshort/test-image It consists of just a configmap

If you're suggesting this to replace the prometheus-operator, I'm happy with that as long as we're OK with not having things like: crd, deployment with runtime, etc. in our test bundle. But I think that having at least a running pod as a result of the ClusterExtension is important for the e2e to check for installation success.

I did also just test that we can definitely get away with just having the test-catalog's bundles all point to the same prometheus-operator version.

@tmshort
Copy link
Contributor

tmshort commented Nov 4, 2024

It's a bundle, it can be installed... Not sure how critical it is to actually have something with a CRD or deployment. That being said, it's just an offer. Not making it a requirement.

./hack/test/build-push-e2e-catalog.sh $(E2E_REGISTRY_NAMESPACE) $(LOCAL_REGISTRY_HOST)/$(E2E_TEST_CATALOG_V2)
E2E_REGISTRY_IMAGE=localhost/e2e-test-registry:devel
image-registry: ## Build the testdata catalog used for e2e tests and push it to the image registry
go build $(GO_BUILD_FLAGS) -tags '$(GO_BUILD_TAGS)' -ldflags '$(GO_BUILD_LDFLAGS)' -gcflags '$(GO_BUILD_GCFLAGS)' -asmflags '$(GO_BUILD_ASMFLAGS)' -o ./testdata/registry/bin/registry ./testdata/registry/registry.go
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
go build $(GO_BUILD_FLAGS) -tags '$(GO_BUILD_TAGS)' -ldflags '$(GO_BUILD_LDFLAGS)' -gcflags '$(GO_BUILD_GCFLAGS)' -asmflags '$(GO_BUILD_ASMFLAGS)' -o ./testdata/registry/bin/registry ./testdata/registry/registry.go
GOOS=linux GOARCH=amd64 go build $(GO_BUILD_FLAGS) -tags '$(GO_BUILD_TAGS)' -ldflags '$(GO_BUILD_LDFLAGS)' -gcflags '$(GO_BUILD_GCFLAGS)' -asmflags '$(GO_BUILD_ASMFLAGS)' -o ./testdata/registry/bin/registry ./testdata/registry/registry.go

Copy link
Contributor

Choose a reason for hiding this comment

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

Since the test-e2e target has a dependency on the image-registry target, the GOOS and GOARCH variables should be set from the test-e2e target, and don't need to be set explicitly here. This way, you can build image-registry locally, and get the correct (local) images when no running the e2e.

Copy link
Contributor

Choose a reason for hiding this comment

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

Hi @tmshort and @bentito,

Would it make more sense to use GOOS=$(go env GOOS) GOARCH=$(go env GOARCH) instead?

This approach would make the target compatible with both macOS and Linux environments, allowing us to run it locally as well. If we explicitly set GOARCH=amd64, for example, it won’t run on macOS systems with a different architecture, where the expected result would be darwin/arm64. Is targeting linux/amd64 specifically what we're aiming for here?

Copy link
Contributor

Choose a reason for hiding this comment

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

yep. current changes take this into account.

Copy link
Contributor

Choose a reason for hiding this comment

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

Not sure that's the right approach. Doing the export should work when doing the image-target, and setting the variable equal to the go env ought to be a noop.

Copy link
Contributor

Choose a reason for hiding this comment

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

Hi @tmshort,

Not sure that's the right approach. Doing the export should work when doing the image-target, and setting the variable equal to the go env ought to be a noop.

I’m not sure if I fully follow your comment here. The export has fixed values as well:

image-registry: export GOOS=linux
image-registry: export GOARCH=amd64

Either way, this suggests fixed values for go build.

So, how would GOOS=linux GOARCH=amd64 go build build a binary for darwin/arm64 (my local env, for example)?

Copy link
Contributor

Choose a reason for hiding this comment

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

Right, but doing this:

GOOS=$(go env GOOS)

Is basically setting the GOOS variable to the environment value that the go command already has available to it. It's equivalent to doing:

GOOS=${GOOS}

Which is a no-op.

Copy link
Contributor

@tmshort tmshort Nov 6, 2024

Choose a reason for hiding this comment

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

@camilamacedo86 I didn't answer your question.

So, how would GOOS=linux GOARCH=amd64 go build build a binary for darwin/arm64 (my local env, for example)?

It wouldn't. In this particular case, it's building executables for the docker container, which have to be linux/amd64. These two executables are never expected to run locally.

My point is that doing GOOS=$(go env GODS) is pointless.

Copy link
Contributor Author

@dtfranz dtfranz Nov 6, 2024

Choose a reason for hiding this comment

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

This build is specifically for the image-registry image to be run in kind; comparing to how we build the operator-controller's manager binary, we use the same GOOS=linux GOARCH=amd64 ENV when building (make run uses docker-build which then uses build-linux). I'm just following that same convention.

If you feel it's important, what we could potentially do is split up the image-registry target so that GOOS=linux GOARCH=amd64 is only set when actually building the image. But I think this is unnecessary or at least non-critical enough that we could address it later in a follow-up.

Copy link
Contributor

Choose a reason for hiding this comment

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

These two executables are never expected to run locally.

If that is the case, (we never run it locally and would not make sense run it locally) then I am OK with fixed values 👍

@dtfranz dtfranz force-pushed the e2e-test-registry branch 2 times, most recently from b0f71b4 to 1ec1910 Compare November 5, 2024 16:29
@dtfranz dtfranz force-pushed the e2e-test-registry branch 2 times, most recently from e5b06f3 to 8ef3a4c Compare November 5, 2024 20:14
Copy link
Contributor

@tmshort tmshort left a comment

Choose a reason for hiding this comment

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

/lgtm

@openshift-ci openshift-ci bot added the lgtm Indicates that a PR is ready to be merged. label Nov 6, 2024
Adds a bare-bones test registry and a folder tree for our test images.

Signed-off-by: dtfranz <[email protected]>
@openshift-ci openshift-ci bot removed the lgtm Indicates that a PR is ready to be merged. label Nov 6, 2024
Copy link
Contributor

@tmshort tmshort left a comment

Choose a reason for hiding this comment

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

/lgtm
After the squash, it's still the same.

@openshift-ci openshift-ci bot added the lgtm Indicates that a PR is ready to be merged. label Nov 6, 2024
@dtfranz dtfranz enabled auto-merge November 6, 2024 18:19
@dtfranz dtfranz added this pull request to the merge queue Nov 6, 2024
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to failed status checks Nov 6, 2024
@dtfranz dtfranz added this pull request to the merge queue Nov 6, 2024
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to failed status checks Nov 6, 2024
@dtfranz dtfranz added this pull request to the merge queue Nov 6, 2024
Merged via the queue into operator-framework:main with commit 66ecaac Nov 6, 2024
17 of 18 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

lgtm Indicates that a PR is ready to be merged.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants