-
Notifications
You must be signed in to change notification settings - Fork 426
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
The order of the CRDs version are processed is not deterministic #1068
Comments
The latest is hard to define, since technically the version string can be anything and doesn't have to follow the v1alpha1, v1beta1, v1 pattern we typically see in Kube. However, perhaps pinning this to the storage version would make sense, since that always has to be present and gives a singular answer to the version without having to write some complex logic internally to guess which is the latest |
I wonder if we should simpy return an error if the |
I like the idea of using the storage version to that.
If we do that, won't we miss the v1alpha2 definition in the final CRDs spec? I mean, if I want to keep both version in the CRD definition, which afaics is the current behavior, won't this change prevent users from doing that? |
No, if you define the resouce marker only on one of your Go types all versions are still included in the CRD. The entire resource marker ( controller-tools/pkg/crd/markers/crd.go Line 256 in e079927
So I don't think it makes sense to allow it to be configured multiple times and then pick one of the markers that is then used for the CRD. Just like storage version it should be only defined once |
I'm trying to add the
shortNames
configuration to some CRDs. These CRDs have two versions:v1
andv1alpha2
. I have changed the// +kubebuilder:resource:scope=Cluster,shortName=cap
by adding theshortName
field in thev1
CRDs. However, each time I runcontroller-gen
, the resulting CRD definitions are different. On each run, theshortNames
configuration is added to some CRDs but not to others.After downloading the
controller-tools
repository, adding some debug messages, and buildingcontroller-gen
locally, I found the issue. It turns out that every timecontroller-gen
runs, the order in which it processes the CRD versions changes. Therefore, when thev1alpha2
CRD is the last one to be processed, the generated CRD definition misses theshortNames
configuration. To fix this, I need to define theshortName
field in the kubebuilder marker for both versions.Is this behavior expected? Shouldn't
controller-gen
consider this marker only for the latest version?The text was updated successfully, but these errors were encountered: