mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-09 01:18:35 +03:00
ci: add ci-release-build.sh
Add a check that verifies that `is_release_build` is `yes` only for release commits. And also verify that the commit message has the correct version. Closes: #945 Approved by: cgwalters
This commit is contained in:
parent
b69c6ba992
commit
82410f0e59
@ -19,6 +19,7 @@ env:
|
||||
tests:
|
||||
- ci/ci-commitmessage-submodules.sh
|
||||
- ci/build-check.sh
|
||||
- ci/ci-release-build.sh
|
||||
|
||||
timeout: 30m
|
||||
|
||||
|
48
ci/ci-release-build.sh
Executable file
48
ci/ci-release-build.sh
Executable file
@ -0,0 +1,48 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# Makes sure that is_release_build is only set to yes in a release commit. A
|
||||
# release commit must be titled: "Release $MAJOR.$MINOR". Also checks that the
|
||||
# release version in the build system matches the commit msg.
|
||||
|
||||
# if running under PAPR, use the branch/PR HEAD actually
|
||||
# being tested rather than the merge sha
|
||||
HEAD=${PAPR_COMMIT:-HEAD}
|
||||
|
||||
git log --format=%B -n 1 $HEAD > log.txt
|
||||
|
||||
if grep -q ^is_release_build=yes configure.ac; then
|
||||
echo "*** is_release_build is set to yes ***"
|
||||
|
||||
V=$(grep -Po '^#define PACKAGE_VERSION "\K[0-9]+\.[0-9]+(?=")' config.h)
|
||||
if [ -z "$V" ]; then
|
||||
echo "ERROR: couldn't read PACKAGE_VERSION"
|
||||
exit 1
|
||||
fi
|
||||
echo "OK: release version is $V"
|
||||
|
||||
# check if the commit title indicates a release and has the correct version
|
||||
if ! grep -q "^Release $V" log.txt; then
|
||||
echo "ERROR: release commit doesn't match version"
|
||||
echo "Commit message:"
|
||||
cat log.txt
|
||||
echo "Build version: $V"
|
||||
exit 1
|
||||
fi
|
||||
echo "OK: release commit matches version"
|
||||
|
||||
if grep -q "^LIBOSTREE_$V" src/libostree/libostree-devel.sym; then
|
||||
echo "ERROR: devel syms still references release version"
|
||||
exit 1
|
||||
fi
|
||||
echo "OK: devel syms no longer reference release version"
|
||||
|
||||
else
|
||||
echo "*** is_release_build is set to no ***"
|
||||
|
||||
if grep -qE "^Release [0-9]+\.[0-9]+" log.txt; then
|
||||
echo "ERROR: release commit does not have is_release_build=yes"
|
||||
exit 1
|
||||
fi
|
||||
echo "OK: commit is not a release"
|
||||
fi
|
Loading…
Reference in New Issue
Block a user