From Fedora Project Wiki

No edit summary
No edit summary
(16 intermediate revisions by 5 users not shown)
Line 2: Line 2:
-->
-->


== Feature Freeze Policy ==
{{admon/tip|Ignoring Feature Freeze|Introducing significant changes to Official Features after Feature Freeze can result in your package being reverted or reduce the chances of receiving an exception}}


Features are accounted for at two different levels:
Features are accounted for at two different levels:
# Feature page promotion and distro coordination--see [[Features/Policy| Fedora Feature Process]]
# Feature page promotion and distro coordination -- see [[Changes/Policy| Fedora Release Planning Process]]
# Package level (continue reading)  
# Package level (continue reading)  


After the ''Feature Freeze'' milestone, no new features or major version bumps are allowed for packages already in the Fedora collection (new packages can still be reviewed, added in CVS and built). 
Once the ''Feature Freeze'' milestone is reached, all new features for the release should be:
* substantially complete and in a ''testable'' state
* ''enabled by default'' -- if so specified by the feature


At ''Feature Freeze'' all new features for the release should be substantially complete and in a ''testable'' state, including ''enabled by default'' if so specified by the feature.  In the Fedora development process, all new feature work is completed by ''Feature Freeze'' and tested during the test releases: Alpha and Beta.
In the Fedora development process, all new feature work is completed by ''Feature Freeze'' and tested during the test releases: Alpha and Beta.


== Some Example Do's and Don't's ==
== Some Example Do's and Don't's ==
Line 22: Line 24:
* Do: submit bugfixes
* Do: submit bugfixes
* '''Do not''': Continue to add new enhancements
* '''Do not''': Continue to add new enhancements
* '''Do not''': Enable the feature by default
* '''Do not''': Enable the feature by default (if not already default at Feature Freeze)
* '''Do not''': Make changes that require other (dependent) software packages to make changes as well
* '''Do not''': Make changes that require other (dependent) software packages to make changes as well


== Exception Process ==
== Exception Process ==
If you believe you have a good reason to ''break feature freeze.'' file a ticket with [https://fedorahosted.org/rel-eng/new-ticket Release Engineering].  
 
{{admon/caution|Ask First|Before checking in changes and building new packages, please request an exception first.  This saves everyone the time and mess of reverting a change if Release Engineering disagrees with the request.}}
 
If you believe you have a good reason to ''break Feature Freeze.'' file a ticket with [https://fedorahosted.org/fesco/newtplticket FESCo]. Breaking ''Feature Freeze'' means making changes to your package other than simple bug fixes. 
 
Please include the following information:  
Please include the following information:  
# A description of what you want to change
# A description of what you want to change
# Rationale for why the change is important enough to be allowed in after the feature freeze.
# Rationale for why the change is important enough to be allowed in after the Feature Freeze.
# Impact of '''not''' accepting the the new package(s) at this point in the schedule.
# Impact of '''not''' accepting the the new package(s) at this point in the schedule.
# Information on what testing you've performed to mitgate risks introduced by replacing the existing package(s)
# Information on what testing you've performed to mitigate risks introduced by replacing the existing package(s)
 
{{Admon/note | Don't forget to login, or you will not get email notifications of ticket changes}}
 
== What Happens Next? ==
The [[ReleaseEngineering| release engineering team]] will evaluate your request and provide feedback.  If your request is rejected, you will have to wait for the next development cycle to add your package to Fedora.  Disputes over rejected changes can be escalated to [[PackageMaintainers/MainPageFesco| FESCo]].
 
Approval comes in the form of +1's.  Two +1's (without any negative feedback) are necessary to build.  If there is negative feedback, conversation will ensue and a new vote will take place.


{{Admon/caution | Ignoring the freeze process and introducing new features (packages) anyway may lead to your package being reverted and a reduction of the chances of an exception being made.}}
== Exception Evaluation ==
FESCo will evaluate your request and provide feedback.  This will generally be done in the ticket, and/or in a regular FESCo meeting.


[[Category:Release Engineering]]
[[Category:Release Engineering]]

Revision as of 20:11, 27 May 2014


Idea.png
Ignoring Feature Freeze
Introducing significant changes to Official Features after Feature Freeze can result in your package being reverted or reduce the chances of receiving an exception

Features are accounted for at two different levels:

  1. Feature page promotion and distro coordination -- see Fedora Release Planning Process
  2. Package level (continue reading)

Once the Feature Freeze milestone is reached, all new features for the release should be:

  • substantially complete and in a testable state
  • enabled by default -- if so specified by the feature

In the Fedora development process, all new feature work is completed by Feature Freeze and tested during the test releases: Alpha and Beta.

Some Example Do's and Don't's

After Feature Freeze, Fedora has certain expectations about what will be happening with your feature. These expectations are based on needing to test your feature (package), test how other pieces of the distribution interact with your feature, and test the overall stability, look, and feel of the distribution.

This what we all expect post-Feature Freeze:

  • Do: Have something testable
  • Do: Have the the feature significantly complete
  • Do: submit bugfixes
  • Do not: Continue to add new enhancements
  • Do not: Enable the feature by default (if not already default at Feature Freeze)
  • Do not: Make changes that require other (dependent) software packages to make changes as well

Exception Process

Stop (medium size).png
Ask First
Before checking in changes and building new packages, please request an exception first. This saves everyone the time and mess of reverting a change if Release Engineering disagrees with the request.

If you believe you have a good reason to break Feature Freeze. file a ticket with FESCo. Breaking Feature Freeze means making changes to your package other than simple bug fixes.

Please include the following information:

  1. A description of what you want to change
  2. Rationale for why the change is important enough to be allowed in after the Feature Freeze.
  3. Impact of not accepting the the new package(s) at this point in the schedule.
  4. Information on what testing you've performed to mitigate risks introduced by replacing the existing package(s)

Exception Evaluation

FESCo will evaluate your request and provide feedback. This will generally be done in the ticket, and/or in a regular FESCo meeting.