From Fedora Project Wiki

(Created page with "== Goal == The goal is to rebuild every single Fedora package, regardless of content, before the Fedora 21 Alpha Change Deadline. == Driving Features == * [[Changes/GCC49| gc...")
 
No edit summary
Line 13: Line 13:
on Friday, June 6th.  All automated rebuilds should be finished prior to the Feature Freeze.
on Friday, June 6th.  All automated rebuilds should be finished prior to the Feature Freeze.
Any clean-up manual rebuilds should be finished prior to the Alpha Change Deadline.
Any clean-up manual rebuilds should be finished prior to the Alpha Change Deadline.
=== Opting Out ===
Release Engineering has given maintainers the ability to
opt out of the scripted rebuild in order to do the build on their own.
Note that every single package needs to be rebuilt, regardless of the
contents.
In order to opt out of the scripted rebuild, a maintainer will need to
check a file into their package's master branch, named '''noautobuild'''.
This file should contain a short rationale of why you wish to do the
build yourself.
If the build initiation script encounters such a file, it will skip that
package.  However, in the interest of expediency (Change freeze being the
8th of July, Alpha Change Freeze being the 22nd of July), a very short grace period will be given for completing
the builds on your own.  If your build has not been attempted by the
23rd of June, the script will no longer honor the noautobuild request and
will attempt to rebuild your package.  If, however, a rebuild has been
attempted, the script will bypass your package.  This should prevent
multiple attempts to build something that fails for one reason or
another.


== Scripts ==
== Scripts ==
Line 77: Line 56:


== Frequently Asked Questions ==
== Frequently Asked Questions ==
=== How do I opt out of the scripted rebuild? ===
See the [[ Fedora_21_Mass_Rebuild#Opting_Out |Opting Out]] section.
=== When will my own build "count" for the rebuild? ===
=== When will my own build "count" for the rebuild? ===
After the last piece needed for thee mass rebuild a gcc build was put into place, a build done by a maintainer will "count" toward the rebuild.  2014-06-05 00:00:00 is the UTC time that builds count from
After the last piece needed for thee mass rebuild a gcc build was put into place, a build done by a maintainer will "count" toward the rebuild.  2014-06-05 00:00:00 is the UTC time that builds count from

Revision as of 03:53, 5 June 2014

🔗 Goal

The goal is to rebuild every single Fedora package, regardless of content, before the Fedora 21 Alpha Change Deadline.

🔗 Driving Features

🔗 Schedule

Given the changes required for the above features and the given schedules, Release Engineering will be ready to start scripted rebuilds on Friday, June 6th. All automated rebuilds should be finished prior to the Feature Freeze. Any clean-up manual rebuilds should be finished prior to the Alpha Change Deadline.

🔗 Scripts

Release Engineering has created two scripts. One is to initiate the builds, and the other is to query for items still needing to be built.

🔗 Build Initiation

The rebuild script works in the following way:

 Generate a list of all packages in f21
 Loop through each package:
   Query if a build has already been attempted/completed since koji changes went live.
   If so, move to next package
   If not, check out git
   Check for a noautobuild file
   If so, move to next package
   If not, rpmdev-bumpspec
   fedpkg commit -cp
   fedpkg (background) build
   Move on to next package

Each step will have some error catching and logging so that people can clean up the various failures for whatever reasons. The builds will be background builds, which will allow other builds done to take higher priority when a builder has a free slot. However maintainers should take care when doing this so that the background build won't take 'latest' precedent when it finishes. Asking rel-eng to kill the scripted build will typically be enough.

🔗 Build Tagging

Once the rebuild script has finished, another script will run to tag the builds into f21. This script will check that a newer build hasn't been done or started in f21 since the scripted rebuild was submitted. This will protect against the scripted rebuild overriding an even newer build done while the scripted rebuild was waiting in the background.

🔗 Status Query

Release Engineering has developed a script to query f21 and report on packages that have yet to be rebuilt. Results of these queries will be delivered to various places, yet to be determined, broken down by maintainer for easier discovery of work needed.

🔗 Maintainer Actions

  • Maintainers that wish to do their own builds should read the Opting Out section.
  • Maintainers can help this effort by ensuring rpmdev-bumpspec correctly bumps your package's spec files.
  • Maintainers should ensure that their packages currently build from source.
  • Maintainers should ensure that there are no unwanted changes committed to git but not built yet.

🔗 Frequently Asked Questions

🔗 When will my own build "count" for the rebuild?

After the last piece needed for thee mass rebuild a gcc build was put into place, a build done by a maintainer will "count" toward the rebuild. 2014-06-05 00:00:00 is the UTC time that builds count from

🔗 Will the rebuilds be ordered?

Currently there is no plan to logically order the rebuilds based on deps. The ordering will be alphanumerical based on package name. There are no planned ABI/soname changes that would require logical build ordering. Further, all the builds will be kept in a special tag (f21-rebuild) until the whole run is done, and then they will be tagged into f21 in one shot to minimize the shuffle of buildroot contents during the rebuilds.


🔗 Feedback

Questions/comments/concerns should be directed to [1], or #fedora-releng on freenode IRC.