X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=docs%2FREADME.stable-point-release;h=087d5bda7ee63e618ae3cc668f2b54c7d4bae59b;hb=be8648509d039e6737fa601c61884747c6ee094e;hp=c0215fecb13be18f3f917e9dc62aa360246f6c8d;hpb=5eb3bbd6f6504930e9271f1b526673949b52e1c2;p=dak.git diff --git a/docs/README.stable-point-release b/docs/README.stable-point-release index c0215fec..087d5bda 100644 --- a/docs/README.stable-point-release +++ b/docs/README.stable-point-release @@ -1,13 +1,13 @@ Rough Guide to doing Stable Point Releases in Debian ---------------------------------------------------- +TRY THE NEW pointrelease SCRIPT INSTEAD! + - sudo to dak - bash: -suite=stable -suitename=squeeze -pusuite=proposed-updates -oldrev=6.0.5 -newrev=6.0.6 +suitename=jessie +newrev=8.5 + export SCRIPTVARS=/srv/ftp-master.debian.org/dak/config/debian/vars . $SCRIPTVARS . "${configdir}/common" @@ -15,31 +15,86 @@ 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: -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} +# 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 + +tmpfile=$(mktemp -p "${TMPDIR}" changelog.XXXXXX) +dak make-changelog -s ${pusuite} -b ${suite} | cat - ${ftpdir}/dists/${suite}/ChangeLog > ${tmpfile} +chmod 0644 ${tmpfile} +mv ${tmpfile} ${ftpdir}/dists/${suite}/ChangeLog +if [ -n "${skip}" ]; then + $EDITOR ${ftpdir}/dists/${suite}/ChangeLog +fi + +dak control-suite --add ${suite} < ${pusuite}.list dak control-suite --remove ${pusuite} < ${pusuite}.list -- 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 +- 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 +if [ -n "${skip}" ]; then + for pack in ${skip}; do + mv -t "${ftpdir}/dists/${pusuite}" ${pumorguedir}/${pack}*.changes + done +fi + +# do r0 and propups, if any +cd ~/${suitename}_${newrev} +if [[ -f /srv/release.debian.org/www/${suitename}/${newrev%%.*}/${newrev}/${suitename}-r0-additions.cs ]]; then + cp /srv/release.debian.org/www/${suitename}/${newrev%%.*}/${newrev}/${suitename}-r0-additions.cs . + dak control-suite --add ${suitename}-r0 < ${suitename}-r0-additions.cs +fi +if [[ -f /srv/release.debian.org/www/${suitename}/${newrev%%.*}/${newrev}/propups.unstable ]]; then + 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 +160,40 @@ 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} -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-* +dak generate-packages-sources2 --force -s ${suite},${pusuite} && dak contents generate -f -s ${suite} -a ftp-master -dak generate-releases -f -s ${suite} - -- have the SRMs sign it and put the signature in. -- 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" +- For wheezy: update main/i18n/Index +if [[ ${suitename} == wheezy ]]; then + ${scriptsdir}/generate-i18n-Index "${ftpdir}/dists/${suite}" 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 & +- 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 +cd ${ftpdir}/dists/${suite} +while :; do + if [[ -f /srv/release.debian.org/www/${suitename}/${newrev%%.*}/${newrev}/Release-${newrev}.gpg ]]; then + 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 + break + else + sleep 10 + continue + fi +done +echo "Done" + +- Check if a mirror push is needed or next dinstall is enough. for a push, bash: +cd +${configdir}/cronscript mirror