X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=docs%2FREADME.stable-point-release;h=304795f1cd890312e493134072318bf9fff39d05;hb=4f3c7874fd19d380b106a9d4bbab0403ed089359;hp=7b9c4a68b54f3fb2a4f5c28177d8e8d634060ce0;hpb=3763616342f209debf2e7be2ed885550d9518621;p=dak.git diff --git a/docs/README.stable-point-release b/docs/README.stable-point-release index 7b9c4a68..304795f1 100644 --- a/docs/README.stable-point-release +++ b/docs/README.stable-point-release @@ -3,11 +3,9 @@ Rough Guide to doing Stable Point Releases in Debian - sudo to dak - bash: -suite=oldstable -suitename=lenny -pusuite=oldstable-proposed-updates -oldrev=5.0.8 -newrev=5.0.9 +suitename=wheezy +newrev=7.10 + export SCRIPTVARS=/srv/ftp-master.debian.org/dak/config/debian/vars . $SCRIPTVARS . "${configdir}/common" @@ -15,31 +13,75 @@ export SCRIPTVARS=/srv/ftp-master.debian.org/dak/config/debian/vars umask 022 export LANG=C export LC_ALL=C + +suite=$(psql -qAtc "SELECT suite_name FROM suite WHERE codename='${suitename}'") +oldrev=$(psql -qAtc "SELECT version FROM suite WHERE codename='${suitename}'") +case "${suite}" in + stable) pusuite=proposed-updates ;; + oldstable) pusuite=oldstable-proposed-updates ;; + *) pusuite=INVALID ;; +esac + +echo "Point release for ${suite} (${suitename}); old version: ${oldrev}, new: ${newrev}" +echo "Updates come from ${pusuite}" + pg_timestamp pre_${suite}_${newrev} cd ~ -mkdir -p ${suite}_${newrev} -cd ${suite}_${newrev} +mkdir -p ${suitename}_${newrev} +cd ${suitename}_${newrev} dak control-suite -l ${pusuite} > ${pusuite}.list dak control-suite -l ${suite} > ${suite}.list - ask SRMs if there is anything to be skipped from this release. If so edit ${pusuite}.list (and later the Changelog too) - bash: +# skip: list of *source* packages to skip, whitespace seperated +skip="" +if [ -n "${skip}" ]; then + mv ${pusuite}.list ${pusuite}.list.ori + grep -vFf <(dak ls -f heidi -S -s ${pusuite} ${skip}) ${pusuite}.list.ori > ${pusuite}.list +fi + dak make-changelog -s ${pusuite} -b ${suite} | cat - ${ftpdir}/dists/${suite}/ChangeLog | sponge ${ftpdir}/dists/${suite}/ChangeLog -cat ${pusuite}.list | dak control-suite --add ${suite} +if [ -n "${skip}" ]; then + $EDITOR ${ftpdir}/dists/${suite}/ChangeLog +fi + +dak control-suite --add ${suite} < ${pusuite}.list dak control-suite --remove ${pusuite} < ${pusuite}.list +- clean up *.changes from proposed-updates: +# Be careful if uploads were not included in the point release. +pumorguedir="${base}/morgue/queues/$(date +%Y/%m)" +mkdir -p "${pumorguedir}" +cd ${ftpdir}/dists/${pusuite} +mv -t "${pumorguedir}" -n -- *.changes + +- -r0 additions? + For example new d-i. If so: +cd ~/${suitename}_${newrev} +cp /srv/release.debian.org/www/${suitename}/${newrev%%.*}/${newrev}/${suitename}-r0-additions.cs . +dak control-suite --add ${suitename}-r0 < ${suitename}-r0-additions.cs + - sync with stable RM if there is any propup needed. do it, if so: -like, cat /srv/release.debian.org/www/squeeze/6.0/6.0.4/propup.unstable | dak control-suite --add unstable -Note: unstable first, then testing +cp /srv/release.debian.org/www/${suitename}/${newrev%%.*}/${newrev}/propups.unstable . +dak control-suite --force --add unstable .r' symlink in dists/ cd $ftpdir/dists/ @@ -73,46 +147,34 @@ EOF - prepare for gps. bash: dak dominate --force -s ${suite} -dak generate-filelist -s ${suite} +- check output from cruft report: +dak cruft-report -s ${suite} +- if cruft was removed: go back to run dominate again + +- if cruft was removed: update changelog from /srv/ftp.debian.org/web/removals.txt: +# $EDITOR ${ftpdir}/dists/${suite}/ChangeLog - Let SRM see if all is ok - then: -dak generate-packages-sources -s ${suite} ; dak contents generate -f -s ${suite} +dak generate-packages-sources2 --force -s ${suite},${pusuite} && dak contents generate -f -s ${suite} -a ftp-master -cd $ftpdir/dists/${suite} -for carch in $(dak admin s-a list-arch ${suite}); do - echo doing ${carch} - cp $base/dak/templates/contents Contents-${carch}.new; - zcat {main,contrib,non-free}/Contents-${carch}.gz | ~joerg/mergecontents.pl | sort >> Contents-${carch}.new; - gzip -9v Contents-${carch}.new; - mv Contents-${carch}.new.gz Contents-${carch}.gz; -done - -rm {main,contrib,non-free}/Contents-* +- For wheezy: update main/i18n/Index +if [[ ${suitename} == wheezy ]]; then + ${scriptsdir}/generate-i18n-Index "${ftpdir}/dists/${suite}" +fi -dak generate-releases -f -s ${suite} +- Generate Releases: +dak generate-releases -f -s ${suite} ${pusuite} +# Remove InRelease: Release can be signed by both ftpmaster & stable release keys +rm ${ftpdir}/dists/${suite}/InRelease - have the SRMs sign it and put the signature in. +cd ${ftpdir}/dists/${suite} +cat /srv/release.debian.org/www/${suitename}/${newrev%%.*}/${newrev}/Release-${newrev}.gpg >> Release.gpg +gpg --no-default-keyring --keyring /usr/share/keyrings/debian-archive-keyring.gpg --trust-model=always --verify Release.gpg Release + - Check if a mirror push is needed or next dinstall is enough. for a push o if so, bash: - -TRACEFILE="${ftpdir}/project/trace/ftp-master.debian.org" -DATE_SERIAL=$(date +"%Y%m%d01") -FILESOAPLUS1=$(awk '/serial/ { print $3+1 }' ${TRACEFILE} ) -if [ "$DATE_SERIAL" -gt "$FILESOAPLUS1" ]; then - SERIAL="$DATE_SERIAL" -else - SERIAL="$FILESOAPLUS1" -fi -date -u > ${TRACEFILE} -echo "Using dak v1" >> ${TRACEFILE} -echo "Running on host: $(hostname -f)" >> ${TRACEFILE} -echo "Archive serial: ${SERIAL}" >> ${TRACEFILE} -cd ${mirrordir} -rsync -aH --link-dest ${ftpdir} --delete --delete-after --ignore-errors ${ftpdir}/. . -date -u > /srv/ftp.debian.org/web/mirrorstart -echo "Using dak v1" >> /srv/ftp.debian.org/web/mirrorstart -echo "Running on host $(hostname -f)" >> /srv/ftp.debian.org/web/mirrorstart -sudo -H -u archvsync /home/archvsync/runmirrors > ~dak/runmirrors.log 2>&1 & - +cd +${configdir}/cronscript mirror