Files
blackbox/RELEASE_ENGINEERING.txt

120 lines
3.4 KiB
Plaintext
Raw Normal View History

2015-01-26 20:26:05 +00:00
# Branches and Tags:
There are 3 branches/tags:
* **HEAD:** The cutting edge of development.
* **tag stable:** Stable enough for use by most people.
* **tag production:** Burned in long enough that we are confident it can be widely adopted.
If you are packaging Blackbox for distribution, you should track the *tag production*. You might also want to provide a separate package that tracks *tag stable:* for early adopters.
# Build Tasks
# Stable Releases
Marking the software to be "stable":
2015-01-26 20:30:06 +00:00
Step 1. Tag it.
2015-01-26 20:26:05 +00:00
```
git pull
git tag -d stable
git push origin :stable
git tag stable
git push origin tag stable
```
2015-01-26 20:30:06 +00:00
Step 2. Mark your calendar 1 week from today to check
to see if this should be promoted to production.
2015-01-26 20:26:05 +00:00
# Production Releases
If no bugs have been reported a full week after a stable tag has been pushed, mark the release to be "production".
```
git fetch
git checkout stable
git tag -d production
git push origin :production
git tag production
git push origin tag production
R="v1.$(date +%Y%m%d)"
git tag "$R"
2015-02-03 11:12:52 -05:00
git push origin tag "$R"
```
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
# Updating MacPorts (automatic)
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
Step 1: Generate the Portfile
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
```
tools/macports_report_upgrade.sh 1.20150222
```
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
This script will generate a file called `Portfile-vcs_blackbox.diff` and instructions on how to submit it as a update request.
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
Step 2: Submit the update request.
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
Submit the diff file as a bug as instructed. The instructions should look like this:
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
* PLEASE OPEN A TICKET WITH THIS INFORMATION:
https://trac.macports.org/newticket
2015-02-22 11:25:42 -05:00
* Summary: `vcs_blackbox @1.20150222 Update to latest upstream`
2015-02-22 13:31:27 -05:00
* Description: ```New upstream of vcs_blackbox.
2015-02-22 11:25:42 -05:00
github.setup and checksums updated.```
* Type: `update`
* Component: `ports`
* Port: `vcs_blackbox`
* Keywords: `maintainer haspatch`
2015-02-22 13:31:27 -05:00
* Attach this file: `Portfile-vcs_blackbox.diff`
Step 3: Watch for the update to happen.
# Updating MacPorts (manual)
This is the old, manual, procedure. If the automated procedure fails to work, these notes may or may not be helpful.
2015-02-22 13:31:27 -05:00
The ultimate result of the script should be the output of `diff -u Portfile.orig Portfile` which is sent as an attachment to MacPorts. The new `Portfile` should have these changes:
2015-02-22 13:31:27 -05:00
1. The `github.setup` line should have a new version number.
2. The `checksums` line(s) should have updated checksums.
How to generate the checksums?
The easiest way is to to make a Portfile with incorrect checksums, then run `sudo port -v checksum vcs_blackbox` to see what they should have been. Fix the file, and try again until the checksum command works.
2015-02-22 13:31:27 -05:00
Next run `port lint vcs_blackbox` and make sure it has no errors.
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
Some useful commands:
2015-02-22 11:25:42 -05:00
2015-02-22 13:31:27 -05:00
Change repos in sources.conf:
```
sudo vi /opt/local/etc/macports/sources.conf
Add this line early in the file:
file:///var/tmp/ports
```
Add a local repo:
2015-02-22 13:31:27 -05:00
```
fgrep >/dev/null -x 'file:///var/tmp/ports' /opt/local/etc/macports/sources.conf || sudo sed -i -e '1s@^@file:///var/tmp/ports\'$'\n@' /opt/local/etc/macports/sources.conf
```
Remove the local repo:
2015-02-22 13:31:27 -05:00
```
sudo sed -i -e '\@^file:///var/tmp/ports@d' /opt/local/etc/macports/sources.conf
```
Test a Portfile:
```
sudo port uninstall vcs_blackbox
sudo port clean --all vcs_blackbox
rm -rf ~/.macports/opt/local/var/macports/sources/rsync.macports.org/release/tarballs/ports/security/vcs_blackbox/
rm -rf /var/tmp/ports
mkdir -p /var/tmp/ports/security/vcs_blackbox
cp Portfile /var/tmp/ports/security/vcs_blackbox
cd /var/tmp/ports && portindex
sudo port -v checksum vcs_blackbox
sudo port install vcs_blackbox
```