How to release Forrest
- About this document
- Who is the Release Manager
- Tasks to be done by the project before the release can start
- Preparing the project for the release
- Preparations for the Release Manager
- Preparing the Release Plan
- Preparing the code base
- Preparing your working copy of SVN trunk
- Preparing the "dist" SVN
- Preparing docs for next release cycle
- Building the release candidate packages
- Testing the release candidate and voting
- Finalizing the release
- Prepare the site-author docs for next development phase
- Upload and announcement
About this document
This documents the steps that the Release Manager (RM) should follow when doing a Forrest release. Note that it might have mistakes - we seem to discover something new each time and some steps might need to happen in a different order. Fine tune these notes for next time. Do some practice runs. Read through these notes often in the lead up to the release to imagine the effect and order of some steps.
There are some steps that other committers, and even developers, can assist with, especially in the areas of getting ready for the release and the final testing. Many of the steps can be done only by the Release Manager.
The lead-up to the release is a good opportunity to build the project community and to draw in new developers. The steps in this process try to maximise that.
Who is the Release Manager
The Release Manager is a single person who does the final work of the release process to prepare and sign release packages, co-ordinate testing and voting, uploading to the dist area and ensuring mirrors, and sending the announcement.
The project developers have the role of preparing the product to release quality, testing, fixing issues, and voting for the release candidate. The votes of the PMC will decide whether the product is fit for release.
The RM makes all the calls regarding the actual preparations and the doing of the release. Many projects have the same release manager for years.
The RM could do the job alone, which enables speedy process. There are not actually many tasks where assistants can help with the release itself (other than with the pre-release tasks and testing). However it is a good idea to have an assistant so as to pass on the knowledge, to help document the process, and to perceive potential flaws. More than one assistant would probably hinder.
The RM needs to have an incredible amount of time and energy available, especially to prepare the first release candidate and to finalise the release.
The RM should be comfortable with using SVN and be familiar with the distribution mirror system, and with ASF release procedures. Also need to be a quick decision-maker and able to find and solve issues on the spot. It would be nice if others help to solve last minute issues, but don't expect it.
The following notes are terse. If you don't understand, then probably not ready to be RM.
Tasks to be done by the project before the release can start
There are a number of things to be done by the project before the release will start. Don't leave these until the last minute. It is not the Release Manager's job to fix bugs nor address blocker issues. The RM job begins after the project is ready to do the release.
- The project updates the Roadmap to schedule the realistic Issues. Be brutal. If these issues have not been fixed by now, then it is quite okay to re-schedule them to delay until the next development version. See example emails from the lead-up to previous releases.
- The project made good progress towards fixing the Blockers and applying the outstanding patches.
- The documentation content is ready.
- Plugins have been reviewed and deployed as necessary. Some perhaps need to go through a release process. This should happen independently of the core release process.
- Supporting products (e.g. Ant, Xerces) should have been updated well before this stage. Do not attempt such upgrades too close to the release, as it will distract attention from other issues and possibly introduce new problems.
- Add some issues to the Roadmap for the important general issues that need to happen before the release. Some examples from last time: FOR-911, FOR-868, FOR-865, FOR-855, FOR-644.
- Relevant changes are listed in the site-author/status.xml and contributors have been attributed. Other changes are listed in the various plugins/status.xml files. See FOR-865
- Add relevant information to the upgrading notes.
Major changes are listed in the site-author/status.xml using the "importance" attribute. This will be used to generate the list of top changes for the Release Notes and Announcement text.
- Committers (as many as possible) have their up-to-date PGP keys in the KEYS file in Forrest's root directory. Instructions about how to add keys are included in that file. See instructions about how to create and manage PGP keys, and see the notes about encouraging a strong web of trust. See these tools to ensure that signatures and keys are okay: pgp signature checker
- Be familiar with our voting guidelines and release actions.
Preparing the project for the release
In this step the Release Manager starts the process to finalise the outstanding blocker issues.
Ensure the above preconditions are met.
If not, then the project is not yet ready for release. Remember that it is not the RM's job to do this.
If so, then send an email to get the project to decide what to do with the remaining issues. Propose to delay some issues to a future release, encourage people to fix others. See FOR-853. Look at msg02310.html for an example of such a message.
Start discussion on Java-Version to use for compiling and testing the release. If necessary, alter the build.compiler.vm value in main/build.xml and plugins/build.xml and in various other files. Conduct a text search for the old version.
Preparations for the Release Manager
Particularly the Release Manager, but also anyone assisting, needs to be familiar with standard procedures and Apache terminology. This is crucial for a successful release.
If you have never done a release before or need to refresh your memory, read all about Apache releases in general at http://www.apache.org/dev/#releases and Apache Incubator. Note that these documents change often. Make sure any assistants have read and understood this as well.
- As discussed above, be sure that you have plenty of time and energy. You will need to be persistent throughout the process.
- Practice signing email in readiness for the announcement.
- Investigate the release procedure notes of other ASF projects.
- Make sure that the network connection is reliable and efficient.
Install the Java-Version that has been agreed for compiling the release. Do this well ahead of time to avoid delays, and ensure that Forrest works for you.
- Get a printout of this document to scribble notes as you go.
- Use a text file to prepare/record your svn merge commands.
- Browse the dev mail list to see what happened around the previous release. Some mails will be useful to glean words to re-use.
Preparing the Release Plan
Prepare the Release Plan to define the corner stones of the coming release. Deciding the dates and timing that suits everybody might be difficult. Try to be careful about holiday periods and try to find timing that is good to attract the most people to help.
Some items are:
- Java-Version to test this release
- The Release Manager
- Date for end of vote on release plan
- Date for create release candidate and start of testing period
- Optional creation of release candidate #2 (when there are bugs)
- Date for end of vote on the final release candidate
- Scheduled release date
Preparing the code base
Anyone can help with this phase.
Ensure that there are no license issues. The committers and PMC would have been continually monitoring this. There are some tools to assist with scanning for issues. See further information.
Ensure that the line-endings and svn:eol-style property are correct for all files. See further information.
- Ensure that documentation structure and content is ready.
- Ensure that the documentation is building properly, do 'cd site-author; forrest'. Fix any linking errors.
Create a new file, etc/RELEASE-NOTES-0.9.txt, where x.y is the version currently being released.
In this file, insert the list of important changes which is obtained by doing:
Fixme ()move this step to later, emphasise preparing it now, e.g. in today's there are no "important" for "docs" category.Fixme ()Needed to hand tweak some "Link:" ... some have local URLS. Manually removed Table of Contents.
- Prepare the announcement text. Create a file admin/announcement-x.txt (by 'svn move' the old one) and list the major new features, e.g. locationmap. The admin directory is not included in the release package so editing can continue.
Ensure that each plugin that uses the locationmap has its "release version" set to 0.8 or more.
If a plugin has a locationmap.xml file or uses "lm:" references in its *.xmap, then it is using locationmap. See How to Build a Plugin.
- Ensure that plugins descriptors in both core and whiteboard are up-to-date.
Ensure that all relevant plugins have been deployed to plugins/0.9/ (see other notes at How to Build a Plugin).Fixme (open)Check and integrate the documents referenced in that howto.
Preparing your working copy of SVN trunk
In this step you make absolutely sure that your working copy of SVN trunk has no local modifications, or additional files that you have been fiddling with, and especially files that might be hidden by svn:ignore settings.
There are two ways to do this. Either do a complete new svn checkout, or use the 'svn status --no-ignore' command on your existing working copy.
In a new empty directory do 'svn co https://svn.apache.org/repos/asf/forrest/trunk'
- Do 'svn update -r HEAD' to ensure that you are up-to-date.
- Run 'svn status --no-ignore'
Delete any extra files you might have added/changed in your local copy. Delete any "build" directories in plugins, etc. Extra files must not be packed with the release. It must be a pristine copy of the current trunk.
Preparing the "dist" SVN
The SVN at https://svn.apache.org/repos/asf/forrest/dist/ holds some html files and other files that form the distribution website. This is checked out on the server at /www/www.apache.org/dist/forrest
Note that the actual release artefacts are not stored in SVN.
Ensure that the KEYS file is synchronised with the copy in Forrest svn trunk and commit the changes. Do ssh to the server and 'svn up' in that directory.
Preparing docs for next release cycle
In this phase we get the docs ready for the release. You will commit these changes after the code-freeze, but do not publish to the website until after the release.
Edit site.xml as follows:
Move all version numbers one line down so that the existing:
<versions tab="docs"> <overview label="Overview" href="versions/index.html"/> <v0.9 label="0.9-dev" href="site:index"/> <v0.8 label="0.8 (current)" href="site:v0.80//index"/> <v0.7 label="0.7" href="site:v0.70//index"/> <versions>
<versions tab="docs"> <overview label="Overview" href="versions/index.html"/> <v0.10 label="0.10-dev" href="site:index"/> <v0.9 label="0.9 (current)" href="site:v0.90//index"/> <v0.8 label="0.8" href="site:v0.80//index"/> <versions>
- Similarly edit tabs.xml
Further edit site.xml to configure the menu labels. See an example site.xml from a past release. Basically do this ...
- Add section <v0.100> with minimal content above the <v0.90> section.
- Edit the label@ and description@ attributes for each of the three sections. <v0.100> and <v0.90> and <v0.80>
- Remove the label@ attribute for the <v0.80> section. This prevents it from appearing in the linkmap ToC.
- Remove the whole section <v0.70> of the past docs.
- Edit version numbers in xdocs/versions/index.xml
- Edit version numbers in xdocs/pluginDocs/index.xml
- Edit version numbers in MOTD section of site-author/skinconf.xml
- Edit version numbers in main/fresh-site/..../site.xml and tabs.xml
Remove the past versions (0.7) docs directory by doing 'svn rm site-author/content/xdocs/docs_0_70
Edit site-author/conf/cli.xconf where it excludes old docs from being generated (a trick to speed up). Adjust the version numbers.
- Change the "fixfor" attribute to the next version for the "project.issues-rss-url" RSS feed in the site-author/forrest.properties file. Find the version number via the "Road Map" link at our Jira front page. Verify localhost:8888/forrest-issues.html
Edit site-author/status.xml to Remove the "-dev" from the current <release> tag, and set the anticipated release date. Remove the "-dev" from the text intro.
- Validate status.xml (e.g. with 'xmllint' or with 'forrest validate-status').
Create a new directory as a stub for the next section of development docs. Create a placeholder index page and upgrading notes. See a past release for example. Do this ...
svn mkdir docs_0_100 svn copy docs_0_90/index.xml docs_0_100 svn copy docs_0_90/upgrading.xml docs_0_100 ... edit those docs to suit. Emphasise developers and encourage svn.
- Temporarily remove the "dev" note from upgrading_xy.xml
Edit the Forrest home page in the "News and events" section and add a text like:
Apache Forrest 0.9 was released on ## YYYY-MM-DD ##. [### Add some important new features ###]
- In the top-level quickstart $FORREST_HOME/index.html
- Ensure that the documentation is building properly, do 'cd site-author; forrest'. Fix any linking errors. Review changes.html to ensure section numbering.
- Edit the site-author/content/doap.xml to add the new release date. Note that we have copies FOR-1210.
Edit the forrest/site-author/content/xdocs/mirrors.html and adjust all version-specific content. In the "Verify" section near the end, add the name of the Release Manager and the PGP key Id used to sign the release.
- Search (e.g. with find and grep) to ensure that no version numbers have been missed. Sometimes people add more hard-coded version numbers since the last release. If you find any, then add them to the list above (or better still, automate them).
- Commit all of the above changes after the code-freeze has started in the next section.
Building the release candidate packages
In this phase the Release Manager builds the release candidate to be tested.
- Announce that the code-freeze has now commenced. Use the template announce_code_freeze.txt to send email to dev list. The meaning of "code-freeze" is defined in that template.
Update your SVN working copy to include any last minute changes.
- Do any final work, such as license header checks and xml code cleanup.
Ensure that your Java version is the lowest specified of our supported versions.NoteSet the environment variable JAVA_HOME to the path of the Java version. Note for Windows: If you change the setting in system properties, you need to logout and login again for the changes to become effective.
Update the version numbers at various places:
Fixme ()There are probably other areas which have version numbers. How can we improve this? Possibly with XML Entities, possibly with Ant properties.
Edit main/build.xml and remove the "-dev" text around line 48:
<property name="forrest.version" value="0.9-dev"/> to: <property name="forrest.version" value="0.9"/>
- Similarly in main/forrest.build.xml around line 28.
Edit plugins/build.xml to increase the docs version number to the next major release. Around line 23:
<property name="forrest.version" value="0.9"/> to: <property name="forrest.version" value="0.10"/>NoteThis is deliberately a major version up. It is assumed that new plugins will be developed against the next version of Forrest. Individual plugins can override this property in their own build files.
Run the following quick tests from the command line of your system to ensure that all is well:
Change to the main directory and run build test. The build should conclude without errors from both seed builds.
Change to the site-author directory and run 'forrest'. The docs should build without errors.
If there are any problems, focus on problems that prevent building and invite other commiters to help you solve the problems.NoteIt is not your job to fix bugs and code freeze should not commence with a broken trunk.
If there are bugs with the build system that cannot be easily fixed, then call a halt to the release process and start a discussion on rescheduling options on the dev-list with the template rc_did_not_build_what_now.txt
Remove the build directories from core and plugins. Do svn st --no-ignore in the root directory of your release candidate directory to be sure that all files created by the test build have been removed and no other files have been changed. The status command should report no changes.
Edit 3 files in tools/forrestbar to update the version number to match the new release:
xpi/install.rdf, line 24: <em:version>0.9<em:version> xpi/install.js, line 19: var err = initInstall("ForrestBar", "forrestbar", "0.9"); xpi/chrome/content/contents.rdf, line 25: chrome:displayName="ForrestBar 0.9"/>
- Build the forrestbar and replace site-author/content/xdocs/tools/forrestbar.xpi
- Update the etc/RELEASE-NOTES-0.9.txt as described above.
- Commit all of the above changes.
Take note of the SVN revision number of your trunk by running svn info from the command line in the Release Candidate's root dir and look at the "Last Changed Rev: ######". This will be used later for the svn log message when the branch is created. Also it is helpful for ensuring that no new commits have been made, i.e. people forgetting the code freeze. From here on carefully watch the svn@ list.
Cleanup your working copy to remove any extra files.
cd $FORREST_HOME find . -name build | xargs rm -rf svn status --no-ignore
Now we will build the release candidate packages for Windows and Unix.
- Change to directory $FORREST_HOME/main and run 'build release-dist' to generate the release candidate packages.
Tag SVN trunk for the release candidate:
svn copy -m "Create tag forrest_###xy###_rc# from trunk" \ https://svn.apache.org/repos/asf/forrest/trunk \ https://svn.apache.org/repos/asf/forrest/tags/forrest_###xy###_rc#
where '###xy###' is a compact (without the dots) form of the version number (e.g. 04, 041, 05).
where 'rc#' is the release candidate number (e.g. rc1, rc2).
See http://svn.apache.org/repos/asf/forrest/tags/ for examples of past tags.
- Unpack and test the relevant archive in a fresh new directory. No point getting people to test if it is broken. You need this for your own testing and vote anyway. Be sure to set FORREST_HOME and PATH properly for this release candidate location i.e. ensure that you are not using your trunk working copy.
Sign the Release Candidate packages and create the *.asc and *.md5 files.
Here is one example when using gpg and openssl from the command line.
gpg --output apache-forrest-0.9.tar.gz.asc \ --detach-sig --armor apache-forrest-0.9.tar.gz gpg --verify apache-forrest-0.9.tar.gz.asc \ apache-forrest-0.9.tar.gz
... should say "Good signature from ..."
openssl dgst -md5 -out apache-forrest-0.9.tar.gz.md5 \ apache-forrest-0.9.tar.gz md5sum apache-forrest-0.9.tar.gz
... output should match that of the md5 file.
Create a maintenance branch in SVN. This command can be run from anywhere because it uses full URLs.
svn copy -r ##### -m "Create the 0.9 release branch from r#####" \ https://svn.apache.org/repos/asf/forrest/trunk \ https://svn.apache.org/repos/asf/forrest/branches/forrest_#xy#_branch where '#xy#' is a compact form of the version (e.g. 04, 041, 05). '#####' is the SVN revision number that the branch was created from, which was the revision that the release candidate packages were generated from. (Remember that you recorded this number earlier.)
See http://svn.apache.org/repos/asf/forrest/branches/ for examples of past branches, e.g. forrest_07_branch
Testing the release candidate and voting
Get Forrest developers to test the actual packges on various platforms.
- Upload the release candidate packages and signatures to your committer's webspace.
Use template test_and_vote_on_rel_cand.txt for an email to the dev-list asking all developers to test and vote. Don't forget to modify the template, to specify the md5sums etc. People need to tell you the md5sum to be sure that they have tested and voted on the correct release candidate. This is especially important if there has been more than one release candidate.
During this testing phase, the Release Manager should:
- Make sure that people are reporting that the packages unpack on different systems without problems.
- Make sure that people have followed the actual user instructions in the Forrest distribution at README.txt and index.html
- Encourage people to build some difficult sites.
- Remind people about how long remains for testing.
- If substantial problems are revealed (not just minor glitches) then co-ordinate their fixing by other developers. Doing the fixing of issues is not the Release Manager's job. Deciding what constitutes a "substantial" issue is entirely the RM's call. Remember that there is still a code freeze, so don't let people be tempted to fix other minor stuff or add some pet new feature that they have neglected. That can easily introduce new problems. Of course be as accommodating as possible.
- If necessary start again with Building the packages and build another release candidate. Remember to do 'svn update' first and to record the new SVN revision number.
- Tally the votes and report the result to the dev list.
Finalizing the release
When a good release candidate has been achieved and affirmed by the vote, we'll finalize the release.
- Remove the release candidate packages from your public_html directory.
If there have been changes to the trunk since the branch was created, then merge trunk to branch. Remember to use a proper commit message which includes the revision number used for the merge (see the SVN Book).Fixme (fso)What is the purpose of this step? It doesn't seem to be right because trunk may already contain parts of the next version. What we should do is do all fixing of RC-problems in the rc-branch (same as changing docs) then, on release, merge branch back into trunk to integrate fixes and doc-changes back into trunk. wdyt?Fixme (dc)It should not contain new functionality because we are in a code freeze
Tag SVN by doing:
svn copy -m "Create tag forrest_###xy###_release from release branch" \ https://svn.apache.org/repos/asf/forrest/branches/forrest_###xy###_branch \ https://svn.apache.org/repos/asf/forrest/tags/forrest_###xy###_release
where '###xy###' is a compact (without the dots) form of the version number (e.g. 04, 041, 05).
See http://svn.apache.org/repos/asf/forrest/tags/ for examples of past tags, e.g. forrest_08_releaseFixme (fso)If we change procedure to create an rc-branch this will become a merge changes from trunk then rename rc-branch to final release branch. right?
Tag the "site" SVN by doing:
svn copy -m "Create tag forrest_###xy###_release_site from site" \ https://svn.apache.org/repos/asf/forrest/site \ https://svn.apache.org/repos/asf/forrest/tags/forrest_###xy###_release_site
where '###xy###' is a compact (without the dots) form of the version number (e.g. 04, 041, 05).
Announce the end of the code-freeze by sending the email-template announce_end_of_code_freeze.txt to the dev list.
Prepare the site-author docs for next development phase
While waiting for the mirrors to catch up, you will copy the docs set for the next development, then call off the code-freeze. Do this ...
- Create a copy of current dev-docs in trunk for the next development phase ...
cd site-author/content/xdocs svn copy docs_0_90 docs_0_100 svn copy pluginDocs/plugins_0_90 plugins_0_100
- Edit site.xml and add a copy of the most current versioned section (e.g. <v0.90>) above it. Increment the first decimal of the section's name to reflect the next planned release (e.g. <v0.100>).
Edit site-author/status.xml to add a new <release> section above it for development on the next version. Add one placeholder action for the next "upgrading" doc. Do the same in the release branch for a possible x.y.1
<release version="0.10-dev" date="not yet released"> <introduction> ... </release> <release version="0.9" date="2007-08-18"> <action ...
- Return the "dev" note to upgrading_xy.xml and add some of the orginal general points that still apply.
- Edit site-author/conf/cli.xconf to exclude the old docs again.
- Add new plugins directories to the "forrest/site" SVN ...
svn mkdir pluginDocs/plugins_0_100 svn mkdir plugins/0.10
Edit main/build.xml, increment the version and add a -dev tag: around line 45: <property name="version" value="0.10-dev"/>
Edit main/forrest.build.xml and update the version: around line 32:
<property name="version" value="0.10-dev"/>
- Edit version numbers in plugins/build.xml
- Edit version numbers in tools/forrestbar
- Increment the version numbers in the head of the xml source of this "How_to_release" document. These are xml entities which display the various version numbers in this document.
Update the .htaccess file to redirect /docs/dev/ to the next version, and do other changes noted in the .htaccess file. See site-author/content/.htaccessFixme (fso)Need to go through .htaccess and clean up.
- Update the release version number and release date in xdocs/index.xml and site-author/content/doap.xml files. Note that we have copies FOR-1210.
- Commit all of the above changes. Either wait for the cronjob, or ssh in and do 'svn up'
- Remember that there is then a one hour rsync delay.
- Send email to the dev list to remind people about the new docs set docs_0_100 and that we don't update docs_0_70 set. Also remind about the new release branch of svn. See example email from the 0.8 release.
Upload and announcement
In this phase we'll upload the new Release, wait for it to be available on most mirror sites, publish the new website, then announce the release.
The reason for waiting, is because when you send the announcement, most of the mirrors need to be up-to-date or your audience will grumble. See various notes below, explaining the delays.
- The signatures that were provided by people who voted +1 for the release may be appended to the *.asc file.
Use scp to upload the release: the *.tar.gz, the *.zip, the *.asc and *.md5 files, and the RELEASE-NOTES-0.9.txt to people.apache.org at /www/www.apache.org/ dist/forrest/ directory.
Ensure correct file permissions by executing 'chgrp forrest *' then 'chmod g+w *' in that directory. Each PMC member has a server account and belongs to the forrest group.
See these tools to ensure that signatures and keys are okay: pgp signature checker
Leave the previous dist there as well as the new one, until after the announcement (because mirrors.html cannot be updated until most mirrors have received the release).NoteThe other files there (HEADER.html README.html LICENSE.txt KEYS) are all automatically updated from the SVN:forrest/dist/ repository (explained above).
Wait for the various mirrors to pick up the new files.
For some mirrors, this takes only a few hours. However others are slow. How long to wait is a tradeoff, e.g. 8 hours has been the norm.
See Status of mirrors. It is a very useful service and fun to watch. See the "age histogram" near the bottom.
Take note of the time that the eu.apache.org mirror is updated, then compare each "mirror age" to that.
When you see that a good proportion of the mirrors have received the release, then update the website, then send the announcement.
- Ensure that docs are *not* being excluded via site-author/conf/cli.xconf as we need to re-build the whole site.
- Before re-building and deploying the new website, check the time. Remember that an 'svn up' happens our on server just after the hour, then a bit later the rsync happens and the site is live about 20 minutes past. This site deployment will take some time, mostly because you are actually doing a fresh installation of a local forrestbot (it does 'svn co forrest/site').
Re-build and publish the Forrest website as normal. Be sure to use the new version of trunk for building the docs. Refer to Publishing Forrest Documentation for details. Beware, there is a forrestbot bug whereby with a brand new forrest installation, the first deploy only does the added files. So deploy again.
- Test the new Forrest website and the redirects f.a.o/docs/ and f.a.o/docs/dev/ and the download page.
Update the xml.apache.org website (Forrest is part of the Apache XML federation of projects). Edit xml-site/src/documentation/content/xdocs/news.xml and record the announcement, and then commit the new HTML to xml-site/targets/forrest Note that they use forrest-0.7 to build their website. See http://xml.apache.org/guidelines.html#website-top
Send announce_release.txt as email to the Forrest user and dev list and the ASF-wide announce lists. Sign the email (e.g. PGP).
Do the Freshmeat announcement: http://freshmeat.net/projects/forrest/
- Update the release information at our Wikipedia page.
- Remove the old generated docs from SVN forrest/site/docs_0_70 which removes them from the website.
Remove old dist files from the /www/www.apache.org/dist/forrest/ directory. They have already been automatically archived at archive.apache.org/dist/forrest/
- Tidy up any "site:v0.8" references. These will refer to old documentation that will be removed at the next release. Especially status.xml file will have such. Generalise as many as possible.
Do some Jira administration (need to be in the jira-administrators group)
Tweak the "release" versions via "admin" interface at our Jira. Do this ...
Re-name the VersionIds using "Manage Versions" then "Edit details": e.g. 0.9-dev is renamed to 0.9 and 0.10 becomes 0.10-dev
Mark 0.9 as released using "Manage Versions". Review the Issues for the old version.
Edit the filter "FOR-roadmap-dev" to refer to the new "0.10-dev" version.
- Deploy the Forrest site again. It will automatically rebuild the Open Issues page.
Or perhaps not.. if you think of anything, please refine these instructions.