-
Notifications
You must be signed in to change notification settings - Fork 62
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
Wireformat checks
property as object, not array, keyed by check name
#110
Comments
In other words, the only benefit of This request implies that not specifying a check name is an error. It also opens a question about what to do if there are non-unique check names. |
If I understand you correctly, you are suggesting to turn the
|
Yes, something like that. Then external check scripts that hit the |
Although, I might wonder about waiting until 1.1 to make this change. Technically, this would be a breaking change for endpoint consumers and health checks that lacked names, so maybe a minor version increment may be deceiving. |
You can easily do this without impacting backwards compatibility. I just pushed up this commit to hammock - hammock-project/hammock@399566b - where I add support for array and map output formats. array is the default for MP, but I may switch the default to be map. Using a configuration setting a user can switch between the two. Note that there's a unit test checking that the new format works, as well as the TCK still passing that the old format works. |
I'd rather prefer a consistent way that works across implementations, instead of feature flags that introduce divergence. The whole point of having a spec behind this is that users can rely on uniformity across implementations. And if there is a good argument for breaking compatibility, then let's do it. |
I assume #34 must be addressed before this... |
@emattheis -- Yes, the uniqueness requested by #34 "Ensure distinct health procedure names" would be required to present the checks as a keyed object or map. This is hard to enforce outside of runtime exceptions, so maybe automatic disambiguation could take place instead via the health check classes's I use Hammock, so I have this already via @johnament's "workaround." |
@derekm are you ok to restart discussion on that ticket? |
I’m not opposed. The other ticket is more far reaching and calls for more breaking changes in order to improve uniqueness checking. This ticket doesn’t necessarily request any breaking changes, unless the default output format is changed. There are some interesting ideas in the other ticket, but I don’t know that it needs to come first. If it came second it would only improve the situation while breaking people’s code. This ticket could be satisfied with an optional mode and with runtime exceptions at request time (or automatic disambiguation of check names at request time). Depends more on how spec leads want to address these requests, I figure. I’d probably do this ticket first, like Hammock has already done. Let people experiment, and then bring in the breaking changes that improve things by being able to check for errors earlier. |
If MP Health 2.0 is now being matured in the Since the time of his last comment, the format has presumably changed to:
where One rationale given for the outcome/state to status/status rename was alignment with Spring. This breaking change to abandon "outcome" & "state" coincidentally begins to put us in compatibility with a twice-renewed Internet-Draft RFC at the IETF called "Health Check Response Format for HTTP APIs": I've contacted @inadarei, the author of the RFC, and he wants to rename the RFC's This puts MP Health in pretty good compatibility with the RFC already, being able to extract overall health state and check names in common. |
…, keyed by check name
…, keyed by check name Signed-off-by: xstefank <[email protected]>
Any movement on this issue? It will be really useful, even simply as an optionally configured feature |
@ivangreene unfortunately this missed the breaking change release in 3.0 because of other priorities. It can be added as an optional feature. I will implement that in our implementation for experimentation first approach. |
checks
property as an array has limited use-cases for efficient retrieval of specific checks.If I'm writing, say, a Nagios check for specific data points, I want to address directly into those data points by check name rather that iterate over the list looking for exactly the check name I'm interested in.
The text was updated successfully, but these errors were encountered: