From Fedora Project Wiki

(more cleanups - drop the first two 'specifics')
(make NoMoreAlphas changes (as proposed at https://lists.fedoraproject.org/archives/list/devel@lists.fedoraproject.org/message/KIVWSHFKRS4RJEFTCAWZBKDCCETKPI4F/ ))
 
(15 intermediate revisions by 9 users not shown)
Line 1: Line 1:
{| border="1px #222222" cellpadding="0" cellspacing="0" align="center" width="90%" style="background-color:#EEEEEE;"
{{autolang|en|es|base=yes}}
|-
 
| <div style="margin: 1ex 2em 1ex 2em;"><blockquote><div style="font-size:87%; color: #202020;">You can't know if you're ready to release unless you know what ''done'' means.<br>
{{Quote|You can't know if you're ready to release unless you know what ''done'' means.<br>
....<br>
....<br>
When you use release criteria to know when a project is done, you have taken potentially hidden decisions and made them public and clear.  Make your release criteria objective and measurable, so everyone on the project knows what they're working towards.  Use the criteria as you progress through the project and up to the final release.  Then you can say 'Release it!' with pride.
When you use release criteria to know when a project is done, you have taken potentially hidden decisions and made them public and clear.  Make your release criteria objective and measurable, so everyone on the project knows what they're working towards.  Use the criteria as you progress through the project and up to the final release.  Then you can say 'Release it!' with pride.|[http://www.universityalliance.com/info1/whitepapers/villanova/pdfs/WP_VU_ReleaseCriteriaGoodtoGo.pdf Johanna Rothman]}}


Also, ponies.</div></blockquote>
== Criteria for Current Release Milestones ==
 
* [[Basic Release Criteria]]
* Fedora {{FedoraVersionNumber|next}} - [[Fedora {{FedoraVersionNumber|next}} Beta Release Criteria|Beta]], [[Fedora {{FedoraVersionNumber|next}} Final Release Criteria|Final]]


<div style="float: right; margin: 1.5ex 5em 1ex;">[http://www.universityalliance.com/info1/whitepapers/villanova/pdfs/WP_VU_ReleaseCriteriaGoodtoGo.pdf Johanna Rothman]</div></div>
|}
<br>
== Purpose ==
== Purpose ==


The release criteria aim to:
The release criteria aim to:


* Clearly specify the criteria that ''must'' be met for each of our public releases (Alpha, Beta, Final) to ship
* Clearly specify the criteria that ''must'' be met for each of our public releases (nightly composes, Beta and Final) to ship
* Document all the requirements of our target audience for each Fedora release
* Document all the requirements of our target audience for each Fedora release
** The target audiences for each public release (Alpha, Beta, and Final) can be different, and may overlap
** The target audiences for each public release (nightly composes, Beta and Final) can be different, and may overlap
** The criteria at any given time are not set in stone: there may be requirements that have been overlooked, or that are new, and in these cases, the criteria should be expanded to ensure all needs are covered
* Establish when a release is "done" in terms that most people can understand and in ways that help new people to understand the process and participate
* Establish when a release is "done" in terms that most people can understand and in ways that help new people to understand the process and participate


== Benefits ==
== Benefits ==


Having a consistent, public and comprehensive set of release critera should:
Having a consistent, public and comprehensive set of release criteria should:


* Reduce the need for meetings to be held and subjective decisions made at the last minute
* Reduce the need for meetings to be held and subjective decisions made at the last minute
Line 29: Line 30:
* Provide an early warning sign if the release is not on track for shipping on time
* Provide an early warning sign if the release is not on track for shipping on time
* Make it clear whether a given bug should block the finalization of a release
* Make it clear whether a given bug should block the finalization of a release
== Release Criteria Specifics ==
* Unique pages for the release criteria are created for each public release
* Release criteria not only reflect acceptable defect levels, they also detail required levels of polish
== Public Releases ==
* [[Fedora_13_Alpha_Release_Criteria |Fedora 13 Alpha Release Criteria]]
* [[Fedora_13_Beta_Release_Criteria |Fedora 13 Beta Release Criteria]]
* [[Fedora_13_Final_Release_Criteria |Fedora 13 Final Release Criteria]]


== Release Constraints ==
== Release Constraints ==
Line 49: Line 41:


Bugs can be fixed in package updates and new features can be included in the next release.
Bugs can be fixed in package updates and new features can be included in the next release.
== Basic Release Criteria ==
The [[Basic Release Criteria]] have a similar purpose to the Beta and Final release criteria. However, they apply to all Rawhide and Branched nightly composes (as well as all milestone candidate composes). We aim to ensure every nightly compose that is released - in the sense of being synced to the [[Repositories#The_rawhide_repository|''rawhide'' repository]] or the [[Repositories#The_fedora_repository_in_Branched_releases|Branched ''fedora'' repository]] - meets the Basic Release Criteria, using a fully automated process (both the testing and the determination as to whether a compose should be released are automated). The Basic Release Criteria are based on the former Alpha Release Criteria.


== Reference Material ==
== Reference Material ==
Line 56: Line 52:
* http://www.ddj.com/architect/184415651
* http://www.ddj.com/architect/184415651


[[Category:QA]]
[[Category:Release Criteria]]

Latest revision as of 00:12, 12 October 2017

You can't know if you're ready to release unless you know what done means.

....

When you use release criteria to know when a project is done, you have taken potentially hidden decisions and made them public and clear. Make your release criteria objective and measurable, so everyone on the project knows what they're working towards. Use the criteria as you progress through the project and up to the final release. Then you can say 'Release it!' with pride.


Criteria for Current Release Milestones

Purpose

The release criteria aim to:

  • Clearly specify the criteria that must be met for each of our public releases (nightly composes, Beta and Final) to ship
  • Document all the requirements of our target audience for each Fedora release
    • The target audiences for each public release (nightly composes, Beta and Final) can be different, and may overlap
    • The criteria at any given time are not set in stone: there may be requirements that have been overlooked, or that are new, and in these cases, the criteria should be expanded to ensure all needs are covered
  • Establish when a release is "done" in terms that most people can understand and in ways that help new people to understand the process and participate

Benefits

Having a consistent, public and comprehensive set of release criteria should:

  • Reduce the need for meetings to be held and subjective decisions made at the last minute
  • Help others who are not involved in the release process to understand our goals and objectives
  • Reduce the need for "gut level" subjective feelings about whether we are ready to ship or not
  • Help us to focus on the purpose of the release and what we are doing it for while focusing less time and energy on things outside of this scope
  • Provide an early warning sign if the release is not on track for shipping on time
  • Make it clear whether a given bug should block the finalization of a release

Release Constraints

Fedora places a high priority on releasing according to schedule. While release quality is very important, there are circumstances where the schedule takes priority.

The following priorities, in this order, will define what matters most in completing our releases:

  1. Target schedule date
  2. Release quality
  3. New release features

Bugs can be fixed in package updates and new features can be included in the next release.

Basic Release Criteria

The Basic Release Criteria have a similar purpose to the Beta and Final release criteria. However, they apply to all Rawhide and Branched nightly composes (as well as all milestone candidate composes). We aim to ensure every nightly compose that is released - in the sense of being synced to the rawhide repository or the Branched fedora repository - meets the Basic Release Criteria, using a fully automated process (both the testing and the determination as to whether a compose should be released are automated). The Basic Release Criteria are based on the former Alpha Release Criteria.

Reference Material