-
Notifications
You must be signed in to change notification settings - Fork 120
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
Proper Version Control #224
Comments
Thanks for starting this discussion @DonghunLouisLee! Generally, client libraries should be backward compatible during a major version. And I can see that the I'd prefer to continue the version strategy that releasing the Except Pulsar bumps its major version, its protocol should keep backward compatible. Thus, we don't have to force the rust client to do simultaneous releases with the main repo. |
BTW, the Pulsar protocol has a protocol version property to help us determine what features are available in the target cluster. It helps us do version controlling, like throwing a meaningful error message when features aren't supported in the target cluster or switching different process modules based on different versions. And we don't need to force users to use the client of the correct version to connect to the target cluster. |
But yes, we can target the next release to be compatible (tested) with Pulsar 2.10.x only, and later extend its compatible matrix, while we may call it 4.2.0 or 5.0.0 :) |
Since pulsar-rs currently does not have proper version control policies, I suggest we move forward with following policies as below
For now, since pulsar-rs is INCOMPLETE as it does not support all the features, it would be a good idea to set a target pulsar version that this client library aims to match.
I propose 2.10.x as the target apache version and due date as 2022 Decemeber. Until then, all new features beyond 2.10.x should not be prioritized and PRs should be focused on solving existing bugs and features within 2.10.x.
Once our goal is satisfied, It would be a good idea to follow version control as mentined above though we would have to start from 4.10.x which would be compatible with apache pulsar 2.10.x since this crate has already reached version 4.1.2 as of 2022/08
Following is list of open issues that should be tackled for version fix(list will be updated continuously). Contributors for this crate are strongly encouraged to handle below issues.
The text was updated successfully, but these errors were encountered: