X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=Releasing;h=27bc82bb2cff5d1b6569022ce4bb69c701df3396;hp=edfb5eb470f69c11f66fcb93a523ea383206a586;hb=HEAD;hpb=3cea033ec928c21b9f7b810898ed3c3cc536d2ce diff --git a/Releasing b/Releasing index edfb5eb4..081ece27 100644 --- a/Releasing +++ b/Releasing @@ -1,34 +1,166 @@ -These are Bdale's notes on how to do a release. +Adding a product to the release + + Make sure the firmware and loader get built by default in + src/Makefile + + Add firmware targets to fat_altos target in Makefile.am + + Add the firmware to altosui/Makefile.am + + Add the firmware to altosui/altos-windows.nsi.in + + Add the firmware to telegps/Makefile.am + + Add the firmware to telegps/telegps-windows.nsi.in - update the version in configure.ac and commit + Add the firmware to Releasing - git tag -a +These are Keith's notes on how to do a release - git-buildpackage --git-ignore-new + - update the version and date in configure.ac if Bdale hasn't already - use --git-ignore-new so trash in checked-out tree doesn't - cause the build to fail! + - update the ANDROID_VERSION in configure.ac if releasing AltosDroid - at this point, we have Debian packages + - follow instructions in doc/RELNOTES - make distclean + - make sure there is a doc/release-notes-.inc - ./autogen.sh --with-fat-dir=/home/bdale/web/altusmetrum/AltOS/releases - make fat + - make sure doc/release-notes.inc points at that - this pushes packages for each platform to web site + - make sure doc/Makefile points at that too - - go edit ~/web/altusmetrum/AltOS/releases/.mdwn to include - release date and explicit ref to dir contents so the AltOS page - shows versioned links, commit and push + - confirm doc/header.inc has correct copyright year + +These are Bdale's notes on how to do a release. + + - make sure Debian build environment is up to date + sudo cowbuilder --update + + - make sure fat build environment is up to date + sudo apt update && sudo apt upgrade && sudo apt autoremove + + - ensure i386 build support is available, and we have tools to build + installers for Windows and Mac OS X + + sudo apt update + sudo apt install genisoimage nsis gcc-avr avr-libc \ + gcc-i686-linux-gnu gcc-aarch64-linux-gnu \ + gcc-arm-linux-gnueabi gcc-arm-linux-gnueabihf \ + gcc-mingw-w64-i686-posix gcc-mingw-w64-x86-64-win32 + + - make sure jsign is installed so we can sign Windows installers: + + https://github.com/ebourg/jsign/releases/download/5.0/jsign_5.0_all.deb + + - make sure ~/web/altusmetrum has no pending pullable commits + + git checkout master + + - update the version in configure.ac if Keith hasn't already + + - if this is an x.y release, then: + git checkout -b branch- + + - if this is an x.y.z release, then: + git checkout branch- # the x.y parts only + - cherry-pick or merge appropriate content from master + + - make sure there is a doc/release-notes-.inc + - make sure that doc/*.txt have the right copyright year and the + new release is included + - confirm doc/header.inc has correct copyright year + - make absolutely sure checked-out tree is "clean" + - make absolutely sure any commits Keith might have pushed to branches + like debian are already pulled + + git log > ChangeLog + git commit -a -m'update ChangeLog for release' + git tag -a -m'Releasing ' # full x.y.z version + + - make sure .git/gbp.conf set to use branch- as upstream + + git checkout debian + git merge branch- + + - verify debian/changelog is "clean" ending in last release version + - craft a suitable debian/changelog entry, possibly using: + export EMAIL=bdale@gag.com + gbp dch --release --multimaint-merge --new-version=-1 + + git commit -n debian/changelog -m "update changelog for Debian build" + + - if this is a -1 release, then + gbp buildpackage --git-no-pristine-tar \ + --git-upstream-branch=branch- \ # eg 1.3 + --git-upstream-tag= # eg 1.3.1 + pristine-tar commit \ + ../build-area/altos_.orig.tar.gz \ + branch- + else if this is not a -1 release + gbp buildpackage + + git tag debian/ + + - at this point we have packages in ~/debian/build-area/altos, now + we move on to the non-Debian part of the release process + + make distclean (just to be sure, this should do nothing) + + ./autogen.sh --enable-multi-arch \ + --with-fat-dir=/home/bdale/web/altusmetrum/ + make && make fat + + - store a stable copy of ARM binaries for production use + + cp src/chaoskey-v1.0/{*.elf,*.ihx,*.bin,*.map} \ + src/easymega-v[1-2].0/{*.elf,*.ihx,*.map} \ + src/easymini-v[1-3].0/{*.elf,*.ihx,*.map} \ + src/easymotor-v3/{*.elf,*.ihx,*.map} \ + src/easytimer-v[1-2]/{*.elf,*.ihx,*.map} \ + src/telebt-v[3-4].0/{*.elf,*.ihx,*.map} \ + src/teledongle-v3.0/{*.elf,*.ihx,*.map} \ + src/telegps-v[1-3].0/{*.elf,*.ihx,*.map} \ + src/telemega-v[1-6].0/{*.elf,*.ihx,*.map} \ + src/telemetrum-v[2-4].0/{*.elf,*.ihx,*.map} \ + src/telemini-v3.0/{*.elf,*.ihx,*.map} \ + src/telelco-v2.0/{*.elf,*.ihx,*.map} \ + src/telefireeight-v[1-2].0/{*.elf,*.ihx,*.map} \ + ~/altusmetrumllc/Binaries/ + cp src/chaoskey-v1.0/flash-loader/{*.elf,*.bin,*.map} \ + src/easymega-v[1-2].0/flash-loader/*.elf \ + src/easymini-v[1-3].0/flash-loader/*.elf \ + src/easymotor-v3/flash-loader/*.elf \ + src/easytimer-v[1-2]/flash-loader/*.elf \ + src/telebt-v[3-4].0/flash-loader/{*.elf,*.bin,*.map} \ + src/teledongle-v3.0/flash-loader/*.elf \ + src/telegps-v[1-3].0/flash-loader/{*.elf,*.bin,*.map} \ + src/telemega-v[1-6].0/flash-loader/*.elf \ + src/telemetrum-v[2-4].0/flash-loader/*.elf \ + src/telemini-v3.0/flash-loader/{*.elf,*.bin,*.map} \ + src/telelco-v2.0/flash-loader/*.elf \ + src/telefireeight-v[1-2].0/flash-loader/*.elf \ + ~/altusmetrumllc/Binaries/loaders/ + (cd ~/altusmetrumllc ; git add Binaries ; git commit -a) + - remove previous versions (only keep latest release) + (cd ~/altusmetrumllc ; git push) + + - Push new release to web site + + make fat-install (cd doc ; make publish) - this pushes fresh documents to the web site + (cd ~/web/altusmetrum/ && \ + git add */releases && git commit -m'Release ' && \ + git push origin master) - sudo debian/rules clean + - upload the Debian package + + - clean up - leave the build tree in an unclutterd state + sudo debian/rules clean + git push origin master branch- debian pristine-tar + git push --tags Testing before a release