-
Notifications
You must be signed in to change notification settings - Fork 164
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
Determine Cypht's lifecycle #982
Comments
It sounds like that doc is a new scheme not yet in use. And it looks like it's leaning toward scheduled releases where the numbers changed based on time, not features. Semantic versioning is different in that the numbers communicate compatability between releases. For example you may introduce a dB schema change that will not gracefully work from one version to the next. The version number will communicate that. But in both of the above schemes every specific version number represents a single point of time in the repo. This means if you are at v1.2 and you have fix a bug you would probably release 1.3 or perhaps 1.2.1. You would not backport into version 1.2. This is because when someone has an issue with 1.2 you don't know exactly which 1.2 they are talking about. If you are concerned that when using an x.y.z pattern someone will just want the latest 1.2.? That can be handled by a package manager or using certain tagging conventions in docker. I can give more details if interested. |
Correct. |
Right. I see what you mean. But if there are always major features every 6-8 months. And there is always one of these major features that lead to incompatibility, do we not end up with semantic versioning by accident? |
Some context: I have been involved in Tiki for over 20 years, so I have a Tiki-centric view of things. So I am glad to learn about how we can do things differently. Tiki has been using a time-based release process for 15 years now, and it has worked really well: https://tiki.org/Lifecycle Here is what I project for the future, to help pick the best model:
|
Ok. Good info on the context. Still, what you are describing it not semantic versioning. It violates points: 2, 3, 6, 7, 8 in the spec: https://semver.org/ That being said you certainly dont need to use semantic versioning. I tend to use since it is a common standard many devs know. Time based releases can be fine, but I dont think you should try to adhere to both schemes at the same time. But point 3 of the semantic versioning spec I think is important across versioning systems: I believe this conflicts with the backporting mention in your doc: Though maybe I am not understanding what that means. Also the tiki lifecycle does not mention backporting. Since it looks like you are leading toward time based with x.y numbers, I recommend:
For example, lets say the latest version is 4.1. If you do a monthly release, you up the minor version: 4.2 If you think mixing feature releases with bug fix releases is confusing to users, then introduce another digit (x.y.z) into your scheme. |
Covered here: https://dev.tiki.org/Where-to-commit |
I agree 100%. This is how we've always been doing for Tiki and Cypht. I didn't specify it because I don't remember ever seeing a project that violates point 3. That would be quite chaotic. |
ok, I clarified https://github.com/cypht-org/cypht/wiki/Lifecycle Please just edit it further to make it clearer. Thanks! |
To clarify, what is a "stable" branch? Is that everything after 1.0? |
Yes |
Ah, I missed that. But I could use a concrete example. In cypht, lets say the latest version is 4.3 and we find a bug that was introduced 6 releases ago. What exact versions would that fix get 'backported' to? And what new versions would that create? |
It is fixed in master, and then backported to 4.x for a release of 4.4 3.x is EoL at this point so we don't backport there. |
While releasing Cypht 2.0, @kroky decided to keep x.y.z format: So after 2.0.0, we have the choice of 2.0.1 or 2.1.0 I updated: https://github.com/cypht-org/cypht/wiki/Lifecycle |
I updated https://github.com/cypht-org/cypht/wiki/Lifecycle some more but it still needs some fixes to clarify that 2.0.x is no longer supported once 2.1.0 is released. Chronologically: We will do normally do: Exceptionally, we may do: But we will not do: |
OK. My only recommendation here is to always use 3 digits. So instead of 2.1 you use 2.1.0 |
I added some clarification about releases. |
@jonocodes How does https://github.com/cypht-org/cypht/wiki/Lifecycle diverge from https://semver.org now? |
Its certainly closer to semantic but not quite there. Mostly because the major number is strictly time based. I would not try to do both schemes. What you are using now seems pretty common (see Firefox, Thunderbird, Ubuntu...) I can think of a way of doing both schemes but it would weaken the time based part and would disrupt the LTS scheme, so its probably not worth it. |
I had removed the time-based part: |
Ah, I missed that. Sounds good. |
One thing I am wondering about SemVer: Does increasing the minimum required PHP version provoke a major release? Sooner or later, we will drop PHP 7.4, and require 8.1, 8.2 or 8.3: Say we are at Cypht 2.2.0, and the next release should be 2.3.0 (new features but no breaking changes), and for whatever reason, we decide to bump the PHP requirements from PHP 7.4 to 8.1, does this mean we should release as 3.0.0 instead? This is a bit theoretical because we would normally bump the requirements early in the cycle so developers can take advantage of PHP 8.x. And we may leverage https://github.com/symfony/polyfill to use the latest and greatest while maintaining support for older PHP versions. And in doing all this, we'll likely make big enough changes to justify a major revision. |
Good question. |
Makes sense to me.
Yes, it could be. But it could just be a basic bug because 2.0.0 is buggy: https://github.com/cypht-org/cypht/releases/tag/v2.0.0 |
Our lifecycle will likely change (to determine time span for LTS versions) but in general that page describes well how things will work for the coming months/years. So I am closing this task. @jonocodes I restored Semver with a warning: |
I also added an LTS: https://github.com/cypht-org/cypht/wiki/Lifecycle |
Dropping major PHP version support is worth releasing a new major cypht version. Otherwise, it might be confusing as people usually add composer dependencies in a form of ^2.0 to depend on any cypht v2 and if we drop php 7.4 support from 2.2 to 2.3, their upgrade will fail (or keep them at 2.2 which might be confusing). |
Related:
The text was updated successfully, but these errors were encountered: