-
Notifications
You must be signed in to change notification settings - Fork 4.9k
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
Implement resource minor/patch version scheme in stable API versioning proposal #8416
Comments
Here's my off-the-cuff thought here, just to get discussion going: It's not entirely clear to me that it makes sense to bump the minor version whenever the protos change. WIth that approach, the minor version number will be constantly incrementing to the point where it will basically be meaningless, because no one will remember which feature corresponds to which version. I think client features are a lot easier to reason about and understand, and they can be applied only when needed (typically when a newer field replaces an older one, as opposed to adding something completely new). |
@markdroth I'm going to do a straw proposal in a doc and will send it around next week for discussion. Agree on your general sentiment above. |
@mattklein123 Sounds good -- I'll look forward to seeing it. |
Short straw proposal here: https://docs.google.com/document/d/1afQ9wthJxofwOMCAle8qF-ckEfNWUuWtxbmdhxji0sI/edit# cc @envoyproxy/api-shepherds @alyssawilk |
Doc has been heavily edited based on initial comments. I think it's ready now for wider review. PTAL. |
Hi all, The doc has been edited again to a hopefully near final statement. The salient points here are:
Thank you! |
I haven't received any further comments on this proposal so I think we can consider this approved. I will be working with @htuch to figure out when this will be implemented (likely Q4). |
Assigning to @adisuissa who is working on this. |
This PR adds the API_VERSION to Envoy, and the api version handling class to fetch the latest and oldest supported API versions by Envoy. This is the first step in implementing the proposal in: #8416. Risk Level: Low (no usage in the code). Testing: Unit tests. Docs Changes: None. Release Notes: None. Platform Specific Features: None. Signed-off-by: Adi Suissa-Peleg <[email protected]>
This issue has been automatically marked as stale because it has not had activity in the last 30 days. It will be closed in the next 7 days unless it is tagged "help wanted" or "no stalebot" or other activity occurs. Thank you for your contributions. |
This issue has been automatically closed because it has not had activity in the last 37 days. If this issue is still valid, please ping a maintainer and ask them to label it as "help wanted" or "no stalebot". Thank you for your contributions. |
The basic idea is we maintain an annotation in the protos specifying minor version and some semantic hash of the proto contents. A bump of the minor version is forced when the hash changes by presubmit tooling. The minor version will be provided in
DiscoveryRequest
s (while the major version is a part of the package/type name itself). See https://docs.google.com/document/d/1xeVvJ6KjFBkNjVspPbY_PwEDHC7XPi0J5p1SqUXcCl8/edit#heading=h.jlxlwbbptdag and https://docs.google.com/document/d/1xeVvJ6KjFBkNjVspPbY_PwEDHC7XPi0J5p1SqUXcCl8/edit#heading=h.9i8j2wwt08lg for further details.This issue tracks finalizing the design and implementation and updating
API_VERSIONING.md
to reflect.The text was updated successfully, but these errors were encountered: