From Fedora Project Wiki
No edit summary
 
(21 intermediate revisions by 4 users not shown)
Line 55: Line 55:
CLOSED as NEXTRELEASE -> change is completed and verified and will be delivered in next release under development
CLOSED as NEXTRELEASE -> change is completed and verified and will be delivered in next release under development
-->
-->
* Tracker bug: <will be assigned by the Wrangler>
* Tracker bug: [https://bugzilla.redhat.com/show_bug.cgi?id=1432874 #1432874]


== Detailed Description ==
== Detailed Description ==


<!-- Expand on the summary, if appropriate.  A couple sentences suffices to explain the goal, but the more details you can provide the better. -->
By gating Rawhide builds from landing in the compose and gating the publication of composes on automated test results, we will ensure Rawhide will always be at Alpha quality. This gating will make it more generally useful to people as a daily driver and development platform, and means we no longer need to go through the process of building, testing and shipping Alpha releases. The initial testing will be ensuring that a package is can be installed and that it does not break existing package installations. Over time, we can enable extra testing to gate the build going into rawhide.  Builds will land in the buildroot immediately after the build has completed in order to be built against, and before they make it to the compose. We will run the gating testing only to gate builds to the compose and not in order to make the buildroot.
By adding CI and gating on Rawhide we will enable rawhide to be more stable and generally useful to people as a daily driver. As a result rawhide should always be at alpha quality, by keeping Rawhide always at Alpha quality we will be no longer need to do Alpha releases.


== Benefit to Fedora ==
== Benefit to Fedora ==


A Rawhide that is always at least Alpha quality is a more compelling product and may attract more target users (developers) to Fedora. Removing the process overhead of Alpha releases from the cycle frees up release engineering, quality engineering, development and project management resources for other work. It potentially offers more flexibility for the Change development and branching parts of the release cycle. Preventing broken changes from reaching the official Rawhide repository means we are not stuck with fundamentally problematic changes, (bar doing epoch bumps and rebuilds of dependent packages) but can more easily revert them.
 
<!-- What is the benefit to the platform?  If this is a major capability update, what has changed?  If this is a new functionality, what capabilities does it bring? Why will Fedora become a better distribution or project because of this proposal?-->


== Scope ==
== Scope ==
* Proposal owners:
* Proposal owners: rearrange the koji tag and target structure, have the testing in place, setup processes to move builds into koji when they meet gating criteria. The changes would start to be implemented in rawhide shortly after branching Fedora 26
<!-- What work do the feature owners have to accomplish to complete the feature in time for release?  Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?-->


* Other developers: N/A (not a System Wide Change) <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Other developers: Pay attention to new notifications and act when necessary
<!-- What work do other developers have to accomplish to complete the feature in time for release?  Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?-->


* Release engineering: [https://pagure.io/releng/issue/6621 #6621]  
* Release engineering: [https://pagure.io/releng/issue/6621 #6621]  


** [[Fedora_Program_Management/ReleaseBlocking/Fedora{{FedoraVersionNumber|next}}|List of deliverables]]: This change removes a milestone and all associated deliverables <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
** [[Fedora_Program_Management/ReleaseBlocking/Fedora{{FedoraVersionNumber|next}}|List of deliverables]]: This change removes a milestone and all associated deliverables  
<!-- Please check the list of Fedora release deliverables and list all the differences the feature brings -->


* Policies and guidelines: As there is no more Alpha we will need to update the guidelines to have changes be completed for Beta.  We may want to add a new checkpoint for basic testability of changes <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Policies and guidelines: As there is no more Alpha, we will need to update the guidelines to indicate changes are to be completed for Beta.  We will likely want to add a new checkpoint for change implementation that was followed for Alpha
<!-- Do the packaging guidelines or other documents need to be updated for this feature?  If so, does it need to happen before or after the implementation is done?  If a FPC ticket exists, add a link here. -->


* Trademark approval: N/A (not needed for this Change)
* Trademark approval: N/A (not needed for this Change)
<!-- If your Change may require trademark approval (for example, if it is a new Spin), file a ticket ( https://fedorahosted.org/council/ ) requesting trademark approval from the Fedora Council. This approval will be done via the Council's consensus-based process. -->


== Upgrade/compatibility impact ==
== Upgrade/compatibility impact ==
Line 95: Line 87:


== User Experience ==
== User Experience ==
<!-- If this change proposal is noticeable by its target audience, how will their experiences change as a result?  Describe what they will see or notice. -->
Rawhide will be more stable and be suitable for use on a daily basis by all developers and tech enthusiasts.
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
Rawhide will be more stable


== Dependencies ==
== Dependencies ==
<!-- What other packages (RPMs) depend on this package?  Are there changes outside the developers' control on which completion of this change depends?  In other words, completion of another change owned by someone else and might cause you to not be able to finish on time or that you would need to coordinate?  Other upstream projects like the kernel (if this is not a kernel change)? -->
<!-- What other packages (RPMs) depend on this package?  Are there changes outside the developers' control on which completion of this change depends?  In other words, completion of another change owned by someone else and might cause you to not be able to finish on time or that you would need to coordinate?  Other upstream projects like the kernel (if this is not a kernel change)? -->


<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
QA to have tests to detect when a new build breaks dependencies.
N/A (not a System Wide Change)
releng to make changes to tagging in koji
a tool to move builds from -pending into rawhide when it passes its tests
notifications on test failures and delays in getting packages into rawhide


== Contingency Plan ==
== Contingency Plan ==


<!-- If you cannot complete your feature by the final development freeze, what is the backup plan?  This might be as simple as "Revert the shipped configuration".  Or it might not (e.g. rebuilding a number of dependent packages).  If you feature is not completed in time we want to assure others that other parts of Fedora will not be in jeopardy.  -->
 
* Contingency mechanism: (What to do?  Who will do it?) N/A (not a System Wide Change)  <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Contingency mechanism: Reinstate Alpha milestone and release. We will know if we are on target a few weeks before as when Alpha would have been.
<!-- When is the last time the contingency mechanism can be put in place?  This will typically be the beta freeze. -->
* Contingency deadline: a month before alpha would have occurred (that would have been August 22nd, so, July 22nd is this deadline)
* Contingency deadline: N/A (not a System Wide Change)  <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Blocks release? No
<!-- Does finishing this feature block the release, or can we ship with the feature in incomplete state? -->
* Blocks product? None
* Blocks release? N/A (not a System Wide Change), Yes/No <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Blocks product? product <!-- Applicable for Changes that blocks specific product release/Fedora.next -->
Reinstate Alpha milestone and release. we will know if we are on target a few weeks before when Alpha would have been.


== Documentation ==
== Documentation ==
<!-- Is there upstream documentation on this change, or notes you have written yourself?  Link to that material here so other interested developers can get involved. -->
<!-- Is there upstream documentation on this change, or notes you have written yourself?  Link to that material here so other interested developers can get involved. -->


<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* [https://www.youtube.com/watch?v=gQskU7P1CKk&t=447s Dennis' Moving everyone to rawhide talk at DevConf]
N/A (not a System Wide Change)
* [https://www.youtube.com/watch?v=5gqccjyjwFk&t=3s Ralph's Factory 2.0 Talk at DevConf]


== Release Notes ==
== Release Notes ==
Line 129: Line 118:
-->
-->


[[Category:ChangePageIncomplete]]
[[Category:ChangeAcceptedF27]]
<!-- When your change proposal page is completed and ready for review and announcement -->
<!-- When your change proposal page is completed and ready for review and announcement -->
<!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler -->
<!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler -->
Line 135: Line 124:
<!-- After review, the Wrangler will move your page to Category:ChangeReadyForFesco... if it still needs more work it will move back to Category:ChangePageIncomplete-->
<!-- After review, the Wrangler will move your page to Category:ChangeReadyForFesco... if it still needs more work it will move back to Category:ChangePageIncomplete-->


<!-- Select proper category, default is Self Contained Change -->
[[Category:SystemWideChange]]
[[Category:SelfContainedChange]]
<!-- [[Category:SystemWideChange]] -->

Latest revision as of 02:38, 14 November 2017


No More Alphas

Summary

Fedora will no longer produce Alpha releases.

Owner

Current status

Detailed Description

By gating Rawhide builds from landing in the compose and gating the publication of composes on automated test results, we will ensure Rawhide will always be at Alpha quality. This gating will make it more generally useful to people as a daily driver and development platform, and means we no longer need to go through the process of building, testing and shipping Alpha releases. The initial testing will be ensuring that a package is can be installed and that it does not break existing package installations. Over time, we can enable extra testing to gate the build going into rawhide. Builds will land in the buildroot immediately after the build has completed in order to be built against, and before they make it to the compose. We will run the gating testing only to gate builds to the compose and not in order to make the buildroot.

Benefit to Fedora

A Rawhide that is always at least Alpha quality is a more compelling product and may attract more target users (developers) to Fedora. Removing the process overhead of Alpha releases from the cycle frees up release engineering, quality engineering, development and project management resources for other work. It potentially offers more flexibility for the Change development and branching parts of the release cycle. Preventing broken changes from reaching the official Rawhide repository means we are not stuck with fundamentally problematic changes, (bar doing epoch bumps and rebuilds of dependent packages) but can more easily revert them.

Scope

  • Proposal owners: rearrange the koji tag and target structure, have the testing in place, setup processes to move builds into koji when they meet gating criteria. The changes would start to be implemented in rawhide shortly after branching Fedora 26
  • Other developers: Pay attention to new notifications and act when necessary
  • Release engineering: #6621
  • Policies and guidelines: As there is no more Alpha, we will need to update the guidelines to indicate changes are to be completed for Beta. We will likely want to add a new checkpoint for change implementation that was followed for Alpha
  • Trademark approval: N/A (not needed for this Change)

Upgrade/compatibility impact

There will be no change to existing systems.

How To Test

See that there is no Alpha release any longer

User Experience

Rawhide will be more stable and be suitable for use on a daily basis by all developers and tech enthusiasts.

Dependencies

QA to have tests to detect when a new build breaks dependencies. releng to make changes to tagging in koji a tool to move builds from -pending into rawhide when it passes its tests notifications on test failures and delays in getting packages into rawhide

Contingency Plan

  • Contingency mechanism: Reinstate Alpha milestone and release. We will know if we are on target a few weeks before as when Alpha would have been.
  • Contingency deadline: a month before alpha would have occurred (that would have been August 22nd, so, July 22nd is this deadline)
  • Blocks release? No
  • Blocks product? None

Documentation

Release Notes