1 In order to perform a release, a few steps have to be taken:
3 [ ] = Should be automated
7 [Prepare codebase for release]
8 # [@] Run tests/multitest.php, fix any errors
9 # [@] Run `php release1-update.php $VERSION` (bumps version numbers)
10 # [if necessary] Bump version numbers in TODO
11 # Write new WHATSNEW and FOCUS entry
12 # Commit as "Release x.y.z." and push
13 # [ ] Tag and push the release
14 . `git tag -u 0x869C48DA vx.y.z` (this is Edward's master private key;
15 substitute with your own if you're making a release. Use tag message
16 "HTML Purifier vx.y.z")
18 # [@] `build-all.sh` in releases: Build the zip and tar.gz
19 # [@] Upload files with `upload-all.sh x.y.z`
21 ( Should get some sort of repos that contains just the pristine tarballs/zips??? )
23 # [ ] Build the PEAR release
27 NOTE: If you need to setup the PEAR environment, setup PEAR first, then:
28 pear install PEAR_PackageFileManager
29 # this is actually a somewhat gnarly knot of dependency jumps
30 # from Ubuntu. First thing to do is pear upgrade-all, then
31 # run this with --alldeps and manually install the ones that
33 pear channel-discover htmlpurifier.org
34 # [@] Run sum-all.bat (generates sha1 checksums)
35 # [@] Run sign-all.bat, enter password when prompted (signs releases)
36 # Update the webpages:
37 - news/YEAR/MODA-name.xhtml
38 . Write a news entry describing the release (see WHATSNEW)
39 - news/YEAR/MODA-name.txt
40 . Use: news item on webpage (add link to webpage as HTML Purifier),
41 download links (substitute in htmlpurifier.org), sha-1 sums.
42 . Sign using `gpg -u 0x869C48DA --clearsign filename` then move *.txt.asc over *.txt original
44 . Bump version number and date
45 - Update submodule live/
50 - Full-disclosure for security problems in previous release
51 # Commit and push and mirror.sh
55 ( SVN compatibility; this is still in the air )
56 # svn import a clean Git checkout of the tag with the .git directory
58 svn import svn+ssh://ezyang@htmlpurifier.org/home/ezyang/svn/svnroot/htmlpurifier/tags/1.2.3
60 # [@] Regenerate API documentation with `regenerate-docs.sh`
61 # Smoketest release by downloading packages, verify contents list, sha1 and sig
62 # Upload PEAR release at http://htmlpurifier.org/pear-server.php
63 # Regenerate configuration documentation
64 - Run http://htmlpurifier.org/live/configdoc/generate.php
65 # Update relevant feeder sites/lists
66 - [@] Run Freshmeat script update-freshmeat.bat (update-freshmeat.php username password)
67 # requires php5-xmlrpc and php5-curl on Ubuntu
68 # NOT WORKING RIGHT NOW, will fix
69 - Announce mailing list <https://panel.dreamhost.com/?tree=mail.list¤t_step=Index&next_step=ShowSend&address=admin&domain=htmlpurifier.org>
70 - Hotscripts listing <http://www.hotscripts.com/account/index.html?section=listings&type=edit&listing_id=65309>
71 . Change version number where applicable
72 # Add new version items in NEWS for trunk