-
Notifications
You must be signed in to change notification settings - Fork 352
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(trait): add support for multiple ingress paths #5996
Conversation
✔️ Unit test coverage report - coverage increased from 47.2% to 47.3% (+0.1%) |
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.
Nice stuff, thanks! As mentioned in the issue, to avoid breaking compatibility you can keep the path
logic and additionally include a paths
with the logic you're willing to implement.
23532bd
to
8d2f4f5
Compare
@squakez - I've now added
|
|
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.
Nice work, thanks! If you can give another shot and add a deprecation warning notice in the Integration condition it would be great.
I forgot to add a link to some example you can use for the warning notice: Line 96 in 023e658
|
Excellent - thank you for the example. I'll work to get this added in the coming days. |
@squakez, I added this into the configure function: if t.Path != "" {
if e.IntegrationInPhase(v1.IntegrationPhaseRunning) {
m := "The path parameter is deprecated and may be removed in future releases. Use the paths parameter instead."
t.L.Info(m)
condition := NewIntegrationCondition(
"Ingress",
v1.IntegrationConditionTraitInfo,
corev1.ConditionTrue,
TraitConfigurationReason,
m,
)
return true, condition, nil
}
} Questions:
|
I don't see this in any commit. Have you committed it yet? The condition looks fine, but you don't need to add a log (the operator will log the condition message by default) and probably you won't need to check either the phase. It is possible that any trait runs multiple time, so, that's something you should not generally worry about. |
@squakez, please see latest commit. I have done as you've mentioned, by removing the log line and phases, however, I do not see the message in the operator log now. Please let me know the proper way to handle/resolve. |
LGTM. You were right, the log was required if we want to notify in the operator log. Feel free to include it as you were doing before. |
@squakez I've committed back in the info log line, however, this does make me question the purpose of including the condition and return statement? Maybe the sole purpose of adding the condition is to allow for tests to evaluate the result (which I've now added too...)? FYI: The It almost seems like there should be a package for throwing depreciation notices to keep better consistency and to provide better awareness (for those not following docs/commits), in some way? Nonetheless, this should now be complete/ready. |
Thanks @cfitzw. The log line would add a trace in the operator. The condition is instead set into the Integration custom resource, and, in general, that is the one you really want to monitor to understand how things are about the resource. It's fine to have it both though, so, once the checks are green we can merge it. |
Related to issue #5981.
ingress.path
.Determine if the IngressTrait should be migrated towards adopting K8s API IngressSpec hierarchy.Can be reviewed again at a later point in time/in a separate PR.
ingress.path
.Example usage:
... generates:
Output of ingress (
kubectl get ingress multi-path -o yaml
):Curl Output: