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

Version commit hash #191

Merged
merged 29 commits into from
Aug 26, 2024
Merged

Version commit hash #191

merged 29 commits into from
Aug 26, 2024

Conversation

ehearneRedHat
Copy link
Contributor

@ehearneRedHat ehearneRedHat commented Jul 15, 2024

What:

Added version commit hash implementation similar to authorino and limitador-operator

How:

  • Check Dirty script checks to see if branch has uncomitted changes and reports dirty if so .
  • Target level vars for specific targets that require ldflags in Makefile.
  • Dockerfile and workflow now reference new vars

Verify:

  • make build (requires kind create cluster be ran first)
  • make docker-build (load image into cluster)
  • make run (requires kind create cluster be ran first)

Specified make targets should run fine with new information in their logs when checked such as the version, whether the branch had changes (i.e. dirty) and also the commit hash. Below is an example of what that may look like.

2024-07-22T13:48:24+01:00       INFO    setup   dns-operator 0.4.0-dev (96475e401ed30c233419dc31632e2ed6729f708a)

Workflow runs successfully --> https://github.com/Kuadrant/dns-operator/actions/runs/10055959082

Image, bundle image and catalog image from workflow install fine and image/bundle image displays new changes.

@ehearneRedHat ehearneRedHat added the enhancement New feature or request label Jul 15, 2024
@ehearneRedHat ehearneRedHat self-assigned this Jul 23, 2024
@ehearneRedHat ehearneRedHat marked this pull request as ready for review July 23, 2024 12:53
@ehearneRedHat ehearneRedHat requested a review from mikenairn July 23, 2024 12:53
@ehearneRedHat ehearneRedHat changed the title [WIP] Version commit hash Version commit hash Jul 23, 2024
Copy link
Member

@mikenairn mikenairn left a comment

Choose a reason for hiding this comment

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

Adding version info the the dns operator and exposing it in the runtime logs is a good idea and something we intended to do at some point, so thanks for starting that.

However, I'm looking through the other repos and issues you linked and nothing about the way we are doing it in each repo is aligned, each is doing it differently still from what i can gather. Looks like we are also in each PR changing it based on whatever feedback your are getting on each PR which won't really work if we are trying to go for a common approach across all repos. Do you have a repo that has been updated with the changes we intend to make in them all?

Would it be worth picking a repo, implementing version info changes in it(on a branch), and getting agreement that all four main golang based operator repos follow the same setup? I agree in most part with what is said here, but i would expect to see automation in place that ensures that version file is as expected on each branch.

The dirty flag also, while i can see the need for it, doesn't really make much sense in a semantic version string. I prefer how this operator has done it making it explicitly about the state of the git repo which it is https://github.com/hashicorp/vault-secrets-operator/blob/dcfee8e513e198aafad467ae71ec5cdd39269282/scripts/ldflags-version.sh#L51-L53

Makefile Outdated Show resolved Hide resolved
cmd/main.go Outdated Show resolved Hide resolved
@ehearneRedHat
Copy link
Contributor Author

ehearneRedHat commented Jul 23, 2024

Do you have a repo that has been updated with the changes we intend to make in them all?

No, there isn't a particular repo in which a universal implementation is made. As you mentioned, I have been implementing each one by one.

Would it be worth picking a repo, implementing version info changes in it(on a branch), and getting agreement that all four main golang based operator repos follow the same setup?

That makes sense. That way, the implementation can remain the same.

The dirty flag also, while i can see the need for it, doesn't really make much sense in a semantic version string. I prefer how this operator has done it making it explicitly about the state of the git repo which it is

I can see where you're coming from... I anticipate some changes will be needed for this implementation to be universal.

Okay, so your suggestions are to determine a universal implementation strategy across all four operators, to be done through a PR so that anyone who make suggestions can so that we can come to an agreement, and then within that agreement, ensure the suggestion of how the aformentioned operator repo implemented "dirty" ? Also, to have a separate version file for version.

Signed-off-by: ehearneredhat <[email protected]>
Signed-off-by: ehearneredhat <[email protected]>
Signed-off-by: ehearneredhat <[email protected]>
Signed-off-by: ehearneredhat <[email protected]>
@ehearneRedHat ehearneRedHat force-pushed the version-commit-hash branch 2 times, most recently from 5ddfe75 to e11cb96 Compare July 23, 2024 15:36
Signed-off-by: ehearneredhat <[email protected]>
Signed-off-by: ehearneredhat <[email protected]>
@eguzki
Copy link
Contributor

eguzki commented Jul 26, 2024

Adding version info the the dns operator and exposing it in the runtime logs is a good idea and something we intended to do at some point, so thanks for starting that.

However, I'm looking through the other repos and issues you linked and nothing about the way we are doing it in each repo is aligned, each is doing it differently still from what i can gather. Looks like we are also in each PR changing it based on whatever feedback your are getting on each PR which won't really work if we are trying to go for a common approach across all repos. Do you have a repo that has been updated with the changes we intend to make in them all?

Would it be worth picking a repo, implementing version info changes in it(on a branch), and getting agreement that all four main golang based operator repos follow the same setup? I agree in most part with what is said here, but i would expect to see automation in place that ensures that version file is as expected on each branch.

The dirty flag also, while i can see the need for it, doesn't really make much sense in a semantic version string. I prefer how this operator has done it making it explicitly about the state of the git repo which it is https://github.com/hashicorp/vault-secrets-operator/blob/dcfee8e513e198aafad467ae71ec5cdd39269282/scripts/ldflags-version.sh#L51-L53

I also wish we had the same implementation in all the operators. But each operator has it's owners and preferences. It's been hard to have a common implementation. Fortunately, even though the how differs (slightly), the what (what matters) is pretty much the same.. specified in here. And TBH, that is good enough for me. All operators will log a line with the versioning based on version, commitID and dirtyness.

Operators and CLI based components differ in the sense that CLI have a version or help command where this information is made available. Whereas the controllers only have the log line at boot time.

I am happy if we do a second iteration on all four operators, kuadrant, authorino, limitador and dns and converge on implementation details.

Copy link
Contributor

@eguzki eguzki left a comment

Choose a reason for hiding this comment

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

some changes pointed out

.github/workflows/build-images.yaml Outdated Show resolved Hide resolved
.github/workflows/build-images.yaml Outdated Show resolved Hide resolved
Dockerfile Outdated Show resolved Hide resolved
cmd/main.go Outdated Show resolved Hide resolved
cmd/main.go Outdated Show resolved Hide resolved
@ehearneRedHat ehearneRedHat requested a review from mikenairn July 29, 2024 11:58
@ehearneRedHat
Copy link
Contributor Author

@mikenairn pinging for review since @eguzki is on PTO for 3 weeks. 😄

version/version.go Outdated Show resolved Hide resolved
Dockerfile Outdated Show resolved Hide resolved
Makefile Show resolved Hide resolved
Makefile Show resolved Hide resolved
cmd/main.go Outdated Show resolved Hide resolved
Signed-off-by: ehearneredhat <[email protected]>
Signed-off-by: ehearneredhat <[email protected]>
Signed-off-by: ehearneredhat <[email protected]>
Signed-off-by: ehearneredhat <[email protected]>
@ehearneRedHat
Copy link
Contributor Author

@mikenairn sorry for taking a while to get back to this PR... I was PTO last week and have been catching up with another PR previous .

I've amended changes where there wasn't any questions I had for the suggestions. As for the rest, I'll await your response first :)

Copy link
Contributor

@eguzki eguzki left a comment

Choose a reason for hiding this comment

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

overall LGTM

I left one nit, though

cmd/main.go Outdated Show resolved Hide resolved
Copy link
Member

@mikenairn mikenairn left a comment

Choose a reason for hiding this comment

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

Changes look fine. As discussed offline, consider looking into using rebase to bring your dev branch up to date with the base(main) to avoid unnecessary merge commits.

I'll force a squash merge on this one.

@mikenairn mikenairn merged commit 6e5fced into main Aug 26, 2024
14 checks passed
@mikenairn mikenairn deleted the version-commit-hash branch August 26, 2024 16:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

3 participants