Skip to content

Commit

Permalink
📝 add release docs, move sub-docs to docs folder
Browse files Browse the repository at this point in the history
  • Loading branch information
fluffynuts committed Oct 26, 2021
1 parent 2323519 commit 1cb560c
Show file tree
Hide file tree
Showing 5 changed files with 77 additions and 2 deletions.
6 changes: 4 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -42,5 +42,7 @@ may be installed by using the bundled helper scripts:
These scripts download the relevant installers from Microsoft servers,
but you run them at your own risk.

Please see [CONTRIBUTING.md](CONTRIBUTING.md) and
[BUILDING.md](BUILDING.md)
Please see
- [CONTRIBUTING.md](doc/CONTRIBUTING.md)
- [BUILDING.md](doc/BUILDING.md)
- [RELEASING.md](doc/RELEASING.md)
File renamed without changes.
File renamed without changes.
60 changes: 60 additions & 0 deletions doc/RELEASING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
Log4Net Release procedure
---

This serves to document the release procedure for log4net, which is probably
more of interest to maintainers than anyone else, but I've found that there
are enough moving parts and time between releases to make the process more
difficult than it needs to be. Some parts are automated and others can be in
the future.

Assuming the code is in a place where a release can be made, for the imagined
release version 2.0.123:

1. Update the documentation under `src/site`
- minimally, this means at least:
- `src/site/xdoc/release/release-notes.xml`
- copy an existing release section & think about:
- what does this release change?
- bug fixes?
- enhancements
- don't forget to mention contributors
- people who reported issues
- people who created pull requests
- people who suggested code that was implemented
- `src/site/xdoc/download_log4net.xml`
- you should be able to search & replace on the prior version
for the new one you're about to create
2. Update the log4net.csproj file with this new version
3. Build release artifacts with `npm run release`
- if this doesn't work, you may need to `npm ci` first!
- currently, this _must_ happen on a windows machine because of older
.net framework requirements which cannot be met on a Linux machine
(or at least, I haven't figured out how - in particular CF)
4. Sign release artifacts (zips & nupkg) under `build/artifacts`
- eg `gpg --argmor --output log4net-2.0.123.nupkg.asc --detach-sig log4net-2.0.123.nupkg`
- there is an accompanying `sign-log4net-libraries.sh` which you could invoke if you cd
into the `build/artifacts` folder
- I build on Windows and sign on Linux as my build machine belongs to my company
and I don't want to store keys there. Always protect your keys fervently!
5. Clone out the log4net doc repo (https://github.com/apache/logging-log4net-site)
- check out the `asf-staging` branch
- create a folder which includes the version, eg `log4net-2.0.123`
6. Copy the contents of `target/site` from this repo into the folder created in (5)
7. Update the symlinks in the base of the docs repo, ie:
- 2.0.x -> 2.0.123
- 2.x -> 2.0.123
8. update the `doap_log4net.rdf` to point to the new release
- (copy-paste-modify an existing release)
9. update the `.htaccess` file
- the trailing RewriteRule should point to the new log4net-2.0.123 folder
10. push the `asf-staging` branch to github and wait a bit
- after a minute or two, check the updates at https://logging.staged.apache.org/log4net
- are you seeing the correct releases page?
- are you seeing the correct downloads page?
- download links should (at this point) not work
11. create an rc-releasd at GitHub with a tag like `rc/2.0.123`
- attach all the files from the build/artifacts folder, _including signatures_
12. get the artifacts in build/artifacts up to https://downloads.apache.org/logging/log4net/
- currently, I have to as another ASF member for help with this
- I also see release notes there - which are out of date (don't know how to update)

13 changes: 13 additions & 0 deletions doc/sign-log4net-libraries.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
#!/bin/bash
# see https://infra.apache.org/release-signing#openpgp-ascii-detach-sig
DID_SOMETHING=0
for f in log4net*.nupkg log4net*.zip; do
DID_SOMETHING=1
echo "signing: $f"
gpg --armor --output $f.asc --detach-sig $f
done

if test "$DID_SOMETHING" = "0"; then
echo "No log4net artifacts found - are you sure you're in the right directory?"
exit 2
fi

0 comments on commit 1cb560c

Please sign in to comment.