<div dir="ltr"><div dir="ltr">On Sat, Apr 20, 2024 at 4:39 AM Kevin Ottens <<a href="mailto:ervin@kde.org">ervin@kde.org</a>> wrote:<br></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hello,<br></blockquote><div><br></div><div>Hi all,</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
Unsurprisingly I'll be pretty much aligned with Luigi, Sune and Volker here I <br>
think. I'll try to add a couple of extra aspects to feed the thinking on this <br>
topic. </blockquote><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
On Friday 19 April 2024 11:04:33 CEST Carl Schwan wrote:<br>
> I know this might be a controversial idea, but I would like to propose<br>
> reunify our release schedules. I feel like splitting our releases schedules<br>
> between Frameworks, Plasma and Gear is not working as well as we intended<br>
> it to be when we split the releases schedules for Plasma 5. This is for<br>
> multiple reasons:<br>
> <br>
> * We end up with 3 different products which are released at different times<br>
> but are connected together. Apps and Plasma both need Framework, Plasma<br>
> needs some packages from gear like kio-extra, Gear needs some package from<br>
> Plasma like Breeze. Coordinating all these inter-groups dependencies is<br>
> complex and was one the reason we had to do a megarelease for Plasma 6.<br>
> Also for the end user, one product is a lot easier to understand.<br>
<br>
This is an engineering topic in this case.<br>
<br>
And, to me, this is an excellent reason not to reunify release schedules! <br>
Because what it tells me is that we're still having dependency issues which <br>
need to be solved.<br>
<br>
The example you give shows Plasma depending on Gear, this shouldn't happen, so <br>
I'd argue: let's fix that instead.<br></blockquote><div><br></div><div>Further cutting these links would be quite beneficial from a CI perspective, so i'm definitely in favour of this.</div><div>Some of the most complicated bits of maintaining the system involve the interconnections between Gear / Plasma / Independent.</div><div><br></div><div>Unfortunately libplasma / kpipewire / plasma-activities will be fairly hard to avoid if you're targeting certain types of integration.</div><div> <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
Aligning the release schedules would only hide such structural issues.<br>
<br>
This was one of the main engineering motives to split things up: when it <br>
wasn't splitted this would stay hidden much longer everyone being comfy with <br>
it.<br>
<br>
Now it's creating pain: perfect, that makes the issue obvious, but it should <br>
be addressed not masked.<br>
<br>
This is in part what Volker highlighted pointing out this should be less of a <br>
problem with key components being moved to Plasma. Again, if there are more, <br>
let's just address them.<br>
<br>
So as pointed out by Sune and Volker: this is a feature (at least in the <br>
Frameworks case) not a bug.<br>
<br>
> * This results in very frequent releases which creates a lot of work for<br>
> distros and talking with some distro maintainers they seems to agree that<br>
> having a big releases every 4 months is better than having constantly a new<br>
> minor or major release from either Framework, Gear or Plasma.<br>
<br>
This is a downstream relationship topic in this case.<br>
<br>
I'm honestly unsure where the problem is though. They could decide to pick a <br>
set of version for the three and focus on that. They don't have and never had <br>
to package every single version of KDE Frameworks.<br>
<br>
That being said it indicates to me that we're not good at communicating which <br>
KDE Frameworks version a given Plasma or Gear release targets. More <br>
coordination and communication here would make sense.</blockquote><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
> * We currently don't have a stable branch for Framework and it takes often<br>
> up to one month for fixes to be deployed. The Framework releases is also<br>
> not in sync with either Gear nor Plasma while these two modules heavily<br>
> make use of Framework and contribute to Framework.<br></blockquote><div><br></div><div>Changing the Frameworks release cadence away from monthly isn't going to get fixes out any faster - as if you are using distribution packages it still has to be packaged.</div><div>If anything it will make them take longer as the Frameworks release would end up being every couple of months instead of monthly? (you can always build Frameworks locally if you need the fixes now)</div><div><br></div><div>I should note that due to a combination of Gitlab configuration and various projects essentially having a hard dependency on Frameworks master (Plasma, Dolphin, looking at both of you) the CI system always supplies Frameworks master regardless of what is being built (the Gitlab configuration is fixable, but there isn't much motivation to do so when it will just cause issues and not be used)</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
This is a QA and testing topic in this case.<br>
<br>
The intent is that master is the stable branch (as Luigi pointed out). If it's <br>
not stable in practice we're failing on testing on QA. So extra automated <br>
tests, more QA and so on should be provided. Yes this is work but it has a <br>
chance of increasing quality, changing the release cadence won't do anything <br>
about it. </blockquote><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
> * We could have an unified LTS release including more than just Plasma. This<br>
> is something that distros have been asking for some time already because<br>
> having just Plasma receiving bug-fixes but not Framework nor the apps is<br>
> not that helpful.<br>
<br>
This is a downstream relationship topic in this case.<br>
<br>
I'm not sure we need to go full steam on the LTS promise though. See above: <br>
better communication about the expected and QA'd versions of KDE Frameworks <br>
needed by Plasma for instance might be enough.<br>
<br>
> * In term of promotion, it is very difficult to advertise the 3 releases<br>
> because combined we have an important release of either Gear, Plasma or<br>
> Framework every few weeks. This is too frequent and often while a combined<br>
> announcement would have enough content to be published in a tech newspaper.<br>
> When splitting the content accross 2 announcements (Gear and Plasma), we<br>
> reduce the content per announcement and this makes it less interesting for<br>
> the journalists to write about us. This doesn't come from me, this is that<br>
> some journalists directly told me.<br>
<br>
This is a marketing topic in this case.<br>
<br>
I've never been really involved in the KDE marketing effort. Still, looking <br>
back at it years after I joined the community, and knowing what I know <br>
nowadays from seeing other projects and products, one thing which surprises me <br>
is that we're still on the mindset of hard coupling engineering releases and <br>
marketing announcements.<br>
<br>
I think we passed the point where it was viable a long time ago.<br>
<br>
I honestly wouldn't be shocked if there were engineering releases of KDE <br>
Frameworks and those would have just a changelog email, same thing for Plasma <br>
x.y.0 with no marketing announcement. And then have a single big marketing <br>
announcement for a Plasma x.y.2 per year with its own marketing name.<br>
<br>
I'm not saying the paragraph above is exactly what we should do in terms of <br>
numbers, I'm just giving a rough example of how decoupling could look like. <br>
There are several different strategies to achieve this.<br>
<br>
> * We won't have 3 different release teams but instead have a bigger one with<br>
> a bigger bus factor. We could also unify the tooling for doing this mass<br>
> releases a bit.<br>
<br>
This is an engineering topic in this case (to be more accurate release <br>
engineering).<br>
<br>
There are two aspects here: the number of people and the tooling. Getting more <br>
people would be good but if not, indeed that could be the same people pulling <br>
the trigger for rolling out the releases.<br>
<br>
The tooling should indeed be unified as much as possible if that's not already <br>
the case. Executing a release should be the least work possible (if we don't <br>
consider the QA efforts, this is hard to compress).<br>
<br>
> I do understand that there was valid reasons for splitting KDE Software<br>
> Collection for Plasma 5 but I don't think this worked out. These were as<br>
> far as I know the main arguments used for splitting the Software<br>
> Collection.<br>
> <br>
> * Trying to move away from "KDE" being recognized as the software instead of<br>
> the community. This unfortunately didn't really work out, everyone is still<br>
> using KDE to refer to the desktop. Even distros call their edition "KDE"<br>
> and I don't blame them, it's difficult to find a better term than that as<br>
> for example "Fedora KDE Spin" not only contains Plasma but also a lot of<br>
> KDE apps. Splitting the releases won't help with that, we need to find a<br>
> better approach or just let it go and accept that people will keep using<br>
> KDE to describe the desktop/software.<br>
<br>
This is incorrect in my humble opinion. My memory could fail me of course, but <br>
to me the splitting didn't happen "to move away from KDE being recognized as <br>
the software". This marketing move actually happened before. It just so happen <br>
that the splitting made it easier on the marketing side to identify the <br>
products.<br>
<br>
The motive for splitting was mainly to a) be able to cater to different <br>
contributors and users needs and b) make structural problems more obvious.<br>
<br>
> * Better promotion of our apps outside of Plasma. This is a valid point but<br>
> I think pursuing our current strategy of putting our apps in many app store<br>
> to be more effective. We could also show the platforms support of each<br>
> applications more prominently in our releases announcements like we already<br>
> do on <a href="http://apps.kde.org" rel="noreferrer" target="_blank">apps.kde.org</a> (e.g. <a href="https://apps.kde.org/okular/" rel="noreferrer" target="_blank">https://apps.kde.org/okular/</a>). Generally Plasma<br>
> releases fare a lot better in term of promotion than the gear announcements<br>
> and showing the applications on an unified announcement would likely help<br>
> spread the words about our applications better.<br>
<br>
Again, nothing to do with the split in my opinion. Like I mentioned before if <br>
marketing prefers to do a single announcement for Plasma + Gear when they see <br>
fit, this could totally happen today without a change on the engineering side.<br>
<br>
> * Helps with outside usage of our frameworks. These didn't get as much<br>
> success as we were hoping when splitting. I think having a stable branch<br>
> for Framework might help but this is only a guess. It would be interesting<br>
> to know of cases where people considered using some Framework and to know<br>
> why they decided against or for it and if this proposal would helps or not.<br>
<br>
Did KDE Frameworks take the Qt/C++ ecosystem by storm being used everywhere? <br>
No, indeed. We were not delusional though it wasn't the goal. We wanted to <br>
move from kdelibs is unusable outside of the KDE community to making it usable <br>
by third parties.<br>
<br>
We can agree to disagree on the threshold at which this is considered a <br>
success. But to me it's definitely a success.<br>
<br>
We moved to unused to some use both in other communities and in company <br>
projects we don't hear about on those lists (but they do exist). As Volker <br>
mentioned it's the dependencies and build system which are the limiting factor <br>
here (no wonder the most reused outside of KDE tend to be Tier 1 frameworks).<br>
<br>
<br>
At this point, I think this highlights quite a bit the problems I have with <br>
this proposal. It is based on fragile premises conflating many different <br>
aspects. Also, instead of really addressing the issues, it's a proposal to <br>
move back to some "golden age of when we released everything in sync" which <br>
wouldn't solve all of the issues but only some of them (maybe)... and rub the <br>
rest under the carpet.<br>
<br>
To me the most likely outcome is old and tough issues creeping back up. Give <br>
it enough time and entropy will run its course getting us back to the kdelibs <br>
big ball of mud and high coupling of all apps Plasma and otherwise to this <br>
kdelibs-ng. We spent years trying to get out of this particular mess, I'd <br>
appreciate if we don't jump back into it.<br>
<br>
It'd also mean that the progress made on third parties using KDE Frameworks <br>
would completely go away. And in "fool me once, not twice" fashion we'd hardly <br>
get a chance of attracting them again.<br>
<br>
> In effect this proposal would mean:<br>
><br>
> * We do one major release every 4 months and then minor releases with a<br>
> frequency based on the Fibonacci numbers as this releases cycle works very<br>
> well for Plasma. Naming could be either <a href="http://YY.MM" rel="noreferrer" target="_blank">YY.MM</a> or Major.Minor.Path. We could<br>
> unify that for one or the other one. Or let each component keep their<br>
> current versioning scheme depending whether we want to merge Plama and Gear<br>
> as product or keep it separate. I'm a bit undecided about this.<br>
<br>
Indeed, the Fibonacci approach seems to work well for stabilizing minor <br>
releases of apps. Still, between minor releases the cadence should be <br>
constant.<br>
<br>
I think Gear and Plasma should be separate products. Which doesn't exclude <br>
moving some apps from Gear to Plasma. To me this both strengthen Plasma and <br>
Gear if we're clear where things stand.<br>
<br>
If an application is in Plasma it is expected to have a mandatory deep <br>
integration with Plasma sessions. If it's in Gear it is expected to be <br>
portable, maybe it does more under a Plasma session, but it shouldn't be <br>
crippled by running outside of a Plasma session.<br>
<br>
Also, on the Plasma and Gear products I think it should be clearer which KDE <br>
Frameworks version is targeted.<br>
<br>
> * "KDE Framework" will still exists as an entity and its ABI and API <br>
> compatibility requirement. Only change is the release frequency and the <br>
> introduction of a stable branch in sync with the other components.<br>
<br>
I hope by now I made the case clear that the release cadence of this one is an <br>
intended feature and not a bug. In my opinion, any pain KDE Frameworks being <br>
on its own cadence creates somewhere else should be treated as a symptom of a <br>
structural problem and addressed for what it is (decoupling required, some <br>
component in the wrong product being an issue in the dependency chain, missing <br>
QA or automated tests to catch regressions, etc.).<br>
<br>
Fun fact: "back then" we even toyed with the idea of an even faster cadence, <br>
it'd require quite some more automated QA and so was left on the side.<br>
I still think it would be a possibility for a subset of frameworks for go on a <br>
faster cadence, but let's not open that can of worms.<br>
<br>
> * Only have one release announcement on our website. We can call it<br>
> Megarelease 6.XX like we did for Plasma 6/Gear 24.02 or find a better name.<br>
> I would avoid reusing Software Collection first because the name is quite<br>
> technical and second because these was already used in the past.<br>
<br>
Sure, why not. This is not engineering I'm less opinionated about it. Apart <br>
from decoupling more between engineering effort and marketing announcements <br>
that is.<br>
<br>
Maybe reconsider the "Megarelease" term though... I've literally been laughed <br>
at for the use of that term outside of our community. Also, I think it was a <br>
fine term for a one off when moving on a major new version of Qt, but it'll <br>
get old quickly for the "business as usual".<br>
<br>
Again no strong opinion there, but I thought I'd mention what I've seen around <br>
me.<br>
<br>
Regards.<br>
--<br>
Kevin Ottens, <a href="http://ervin.ipsquad.net" rel="noreferrer" target="_blank">http://ervin.ipsquad.net</a><br>
<br>
enioka Haute Couture - proud supporting member of KDE<br>
<a href="https://hc.enioka.com/en" rel="noreferrer" target="_blank">https://hc.enioka.com/en</a></blockquote><div><br></div><div>Cheers,</div><div>Ben </div></div></div>