-
Notifications
You must be signed in to change notification settings - Fork 2.6k
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
feat(Gateway API): improve annotations support #4870
base: master
Are you sure you want to change the base?
feat(Gateway API): improve annotations support #4870
Conversation
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: The full list of commands accepted by this bot can be found here.
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
Welcome @Dadeos-Menlo! |
Hi @Dadeos-Menlo. Thanks for your PR. I'm waiting for a kubernetes-sigs member to verify that this patch is reasonable to test. If it is, they should reply with Once the patch is verified, the new status will be reflected by the I understand the commands that are listed here. 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. |
/ok-to-test |
@abursavich do you think you can do a first review on this PR ? |
4a62691
to
b632a81
Compare
b632a81
to
cc10e6d
Compare
What additional documentation do you feel would add clarity? In my opinion the proposed changes merely bring the implementation in line with the existing documentation.
|
In current documentation, the behavior when there are annotations on both Gateway & HTTPRoute is not detailed: no explanation and no example. |
/retitle feat(Gateway API): improve annotations support |
Hi @Dadeos-Menlo . Nice work. Would it be possible to extract the refactoring into a separate pull-request to simplify a review and reduce blast radius?
You could add tests as well that highlights current/incorrect behaviour to it. |
Hi Ivan, In the interests of easing any review I separated the proposed changes into stand-alone commits. The sequence of which were broadly described by the bullet points provided in the initial description. My intention with these stand-alone commits was to mutate the pre-existing implementation, step-by-step, into one that exhibits what I consider to be more desirable behaviour (i.e. the consistent honouring of annotations assigned to Gateway resources). The initial commit seeks to introduce additional unit-tests/expectations, regarding the The second commit seeks to refactor the existing implementation into a form conducive to tracking the relationship between …Route and Gateway resources throughout the processing required to generate the The third commit builds upon the refactored implementation in order to provide the intended additional functionality; namely the consistent honouring of annotations assigned to Gateway resources. This commit introduces new unit-test scenarios, associated with annotations being assigned to Gateway resources and in support of the proposed new behaviours, whilst avoiding modification of existing unit-test scenarios, thus demonstrating no regressions with respect to pre-existing asserted behaviours (NB: The essence of the "DualStack" tests were incorporated into the Gateway annotation orientated unit-test scenarios introduced). The forth, and final, commit modifies the documentation as requested. In direct response to your questions:
Whilst this would be possible, I consider that the proposed changes belong together in a single pull-request, and have made efforts to separate the mutations applied as outlined above.
I consider that unit-test scenarios asserting the intended behaviour of annotations assigned to Gateway resources have been introduced, as part of the behavioural modifications proposed in commit three. I hope that the explanation offered above aids your understanding and consideration. Thank you for your interest in these proposed changes. Regards, Peter |
Thanks for the explanation. I agree with the overall direction of this change, so I won't raise any objections. However, given the complexity of the changes, (I do not possess maintainer access), I will be unable to formally approve this pull request, which is not an issue anyway.
This make sense. To potentially accelerate the approval process, consider splitting the refactoring from the new functionality in the next pull request. This would allow community members to contribute more easily by focusing on smaller, more manageable changes. |
hosts[host] = struct{}{} | ||
} | ||
} | ||
// TODO: The ignore-hostname-annotation flag help says "valid only when using fqdn-template" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The help is valid.
This option has been introduced with PR #745.
As you can see, it's still checked:
https://github.com/kubernetes-sigs/external-dns/blob/master/pkg/apis/externaldns/validation/validation.go#L84
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This comment was merely relocated from the pre-existing sources…
I suspect that the observation being made by its original author is that the referenced help states that:
"Ignore hostname annotation when generating DNS names, valid only when --fqdn-template is set (default: false)"
and yet various implementations, including this one, do not check that the value of FQDNTemplate
has been specified. However, they may not have appreciated the additional validation to which you refer that appears to preclude the IgnoreHostnameAnnotation
value being true
whilst the FQDNTemplate
is empty.
Would you like me to eliminate the "TODO: …" comment?
Description
The generation of DNS records from Gateway API resources involves combining information from a …Route resource and a Gateway resource. The current implementation, for the most part, only considers annotations from the Route resource. There are potential scenarios whereby it may be more convenient to assign annotations to the Gateway resource, thus ensuring that all DNS records associated with the given Gateway are similarly effected. An extreme example of such a scenario being when no Hostname information is specified (i.e. the given Gateway should accept any communication, irrespective of the DNS name used to establish it) but that a DNS record is desired to cover all Routes associated with the Gateway; in which case it would be convenient to apply an
external-dns.alpha.kubernetes.io/hostname
annotation to the Gateway itself, rather than having to apply annotations to every associated Route and having to deal with the potential confusion arising from precisely which Route owns the shared DNS record.The proposed changes include:
resource
endpoint label ownership to all of the Gateway related unit-testsEndpoint
generation in order to preserve the relationship between Route and Gateway resourcesEndpoint
external-dns.alpha.kubernetes.io/ttl
annotations are merged to yield the lowest specified valueexternal-dns.alpha.kubernetes.io/hostname
is specified on a Gateway and that Gateway is the only Gateway contributing to anEndpoint
the resource label is recorded as referring to the Gateway rather than the RouteNo changes to the documentation are proposed because it currently implies that annotations on Gateway resources are supported, whereas in reality such annotations are only honoured when specified on Route resources.
Checklist