This documents contains the necessary steps to conduct a successful release.
-1. Add all items to `NEWS.md`
+1. Run `tools/release.sh` shell script
- Get a first template with [`clog`](https://github.com/clog-tool/clog-cli)
- ```console
- $ clog -F -r https://github.com/dracut-ng/dracut-ng
- ```
-
-2. Update the contributors list in NEWS.md
-
- Produce the list with:
- ```console
- $ make CONTRIBUTORS
- ```
-
- Append the list to the section in `NEWS.md`
-
-3. Update AUTHORS
-
- ```console
- $ make AUTHORS
- ```
-
-4. Check in AUTHORS and NEWS.md
-
- ```console
- $ git commit -m "docs: update NEWS.md and AUTHORS" NEWS.md AUTHORS
- $ git push origin main
- ```
-
-5. Tag the release, validate the tag and push
-
- ```console
- $ git tag -s 060
- $ git tag -v 060
- $ git push --tags
- ```
-
- Add the section from `NEWS.md` to the git tag message excluding the Rendered
- view entry.
-
-6. Create a new release on github (https://github.com/dracut-ng/dracut-ng/releases/new)
+2. Create a new release on github (https://github.com/dracut-ng/dracut-ng/releases/new)
- Add the section from `NEWS.md` to the release.
-7. Open a new milestone, move all unfinished issue from the previous milestone to the new one and close the released milestone (https://github.com/dracut-ng/dracut-ng/milestones)
+3. Open a new milestone, move all unfinished issue from the previous milestone to the new one and close the released milestone (https://github.com/dracut-ng/dracut-ng/milestones)
NEW_VERSION="$1"
fi
+# change current branch to release
+git branch -m release
+
printf "#### Contributors\n\n" > CONTRIBUTORS.md
cat _CONTRIBUTORS >> CONTRIBUTORS.md
# Update AUTHORS
make AUTHORS
-# Update NEWS.md
+# Update the contributors list in NEWS.md
cargo install clog-cli
head -2 NEWS.md > NEWS_header.md
tail +2 NEWS.md > NEWS_body.md
printf "dracut-%s\n==========\n" "$NEW_VERSION" > NEWS_header_new.md
+
+# Append the list to the section in `NEWS.md`
cat CONTRIBUTORS.md NEWS_body.md > NEWS_body_with_conttributors.md
+# Get a template with [`clog`](https://github.com/clog-tool/clog-cli)
# clog will always output both the new release and old release information together
clog -F --infile NEWS_body_with_conttributors.md -r https://github.com/dracut-ng/dracut-ng | sed '1,2d' > NEWS_body_full.md
# dracut-version.sh
printf "#!/bin/sh\n# shellcheck disable=SC2034\nDRACUT_VERSION=%s\n" "$NEW_VERSION" > dracut-version.sh
+if [ -z "$(git config --get user.name)" ]; then
+ git config user.name "dracutng[bot]"
+fi
+
+if [ -z "$(git config --get user.email)" ]; then
+ git config user.email "<dracutng@gombos.dev>"
+fi
+
# Check in AUTHORS and NEWS.md
-git config user.name "dracutng[bot]"
-git config user.email "<dracutng@gombos.dev>"
git commit -m "docs: update NEWS.md and AUTHORS" NEWS.md AUTHORS dracut-version.sh
-git push origin main
-git tag "$NEW_VERSION" -m "$NEW_VERSION"
-git push --tags
+
+# git push can fail due to insufficient permissions
+if ! git push -u origin release; then
+ exit $?
+fi
+
+# Tag the release, validate the tag and push
+KEYS=$(gpg --list-secret-keys --keyid-format=long 2> /dev/null)
+
+if [ -z "$KEYS" ]; then
+ echo "Could not find gpg or gpg secrets, not signing the git tag."
+ git tag "$NEW_VERSION" -m "$NEW_VERSION"
+else
+ git tag -s "$NEW_VERSION" -m "$NEW_VERSION"
+ git tag -v "$NEW_VERSION"
+fi
# export new version to Github Action
-echo "new_version=${NEW_VERSION,,}" >> "${GITHUB_ENV}"
+# release will not be generated if pushing the tag failed
+git push --tags && echo "new_version=${NEW_VERSION,,}" >> "${GITHUB_ENV}"