mirror of
https://github.com/timescale/timescaledb.git
synced 2025-05-18 03:23:37 +08:00
146 lines
4.1 KiB
Bash
Executable File
146 lines
4.1 KiB
Bash
Executable File
#!/bin/bash
|
|
set -eu
|
|
|
|
# Folder, where we have cloned repositories' sources
|
|
SOURCES_DIR="sources"
|
|
|
|
GH_USERNAME=$(gh auth status | grep 'Logged in to' |cut -d ' ' -f 9)
|
|
|
|
FORK_DIR="$GH_USERNAME-timescaledb"
|
|
|
|
echo "---- Deriving the release related versions from main ----"
|
|
|
|
cd ~/"$SOURCES_DIR"/"$FORK_DIR"
|
|
git fetch --all
|
|
|
|
CURRENT_VERSION=$(tail -1 version.config | cut -d ' ' -f 3)
|
|
cd sql/updates
|
|
CURRENT_PATCH_VERSION=$(echo $CURRENT_VERSION | cut -d '.' -f 3)
|
|
NEW_PATCH_VERSION=$((CURRENT_PATCH_VERSION + 1))
|
|
RELEASE_BRANCH="${CURRENT_VERSION/%.$CURRENT_PATCH_VERSION/.x}"
|
|
NEW_VERSION="${CURRENT_VERSION/%.$CURRENT_PATCH_VERSION/.$NEW_PATCH_VERSION}"
|
|
|
|
for f in ./*
|
|
do
|
|
case $f in
|
|
*$CURRENT_VERSION.sql) LAST_UPDATE_FILE=$f;;
|
|
*) true;;
|
|
esac
|
|
done
|
|
LAST_VERSION=$(echo "$LAST_UPDATE_FILE" |cut -d '-' -f 1 |cut -d '/' -f 2)
|
|
|
|
echo "CURRENT_VERSION is $CURRENT_VERSION"
|
|
#echo "LAST_UPDATE_FILE is $LAST_UPDATE_FILE"
|
|
echo "LAST_VERSION is $LAST_VERSION"
|
|
echo "RELEASE_BRANCH is $RELEASE_BRANCH"
|
|
echo "NEW_VERSION is $NEW_VERSION"
|
|
cd ~/"$SOURCES_DIR"/"$FORK_DIR"
|
|
|
|
|
|
# Derived Variables
|
|
RELEASE_PR_BRANCH="release-$NEW_VERSION"
|
|
UPDATE_FILE="$CURRENT_VERSION--$NEW_VERSION.sql"
|
|
DOWNGRADE_FILE="$NEW_VERSION--$CURRENT_VERSION.sql"
|
|
LAST_UPDATE_FILE="$LAST_VERSION--$CURRENT_VERSION.sql"
|
|
LAST_DOWNGRADE_FILE="$CURRENT_VERSION--$LAST_VERSION.sql"
|
|
|
|
|
|
echo "---- Creating release branch $RELEASE_PR_BRANCH from $RELEASE_BRANCH, on the fork ----"
|
|
|
|
git checkout -b "$RELEASE_PR_BRANCH" upstream/"$RELEASE_BRANCH"
|
|
git branch
|
|
git pull && git diff HEAD
|
|
|
|
|
|
echo "---- Modifying version.config to the new versions ----"
|
|
|
|
sed -i.bak "s/${CURRENT_VERSION}/${NEW_VERSION}/g" version.config
|
|
sed -i.bak "s/${LAST_VERSION}/${CURRENT_VERSION}/g" version.config
|
|
rm version.config.bak
|
|
|
|
|
|
echo "---- Creating update SQL file $UPDATE_FILE ----"
|
|
|
|
cd sql/updates
|
|
cp latest-dev.sql "$UPDATE_FILE"
|
|
git add "$UPDATE_FILE"
|
|
truncate -s 0 latest-dev.sql
|
|
|
|
|
|
echo "---- Creating downgrade SQL file $DOWNGRADE_FILE ----"
|
|
|
|
touch reverse-dev.sql
|
|
cp reverse-dev.sql "$DOWNGRADE_FILE"
|
|
git add "$DOWNGRADE_FILE"
|
|
truncate -s 0 reverse-dev.sql
|
|
|
|
|
|
echo "---- Adding update sql file to CMakeLists.txt ----"
|
|
|
|
cd ..
|
|
gawk -i inplace '/'$LAST_UPDATE_FILE')/ { print; print " updates/'$UPDATE_FILE')"; next }1' CMakeLists.txt
|
|
sed -i.bak "s/${LAST_UPDATE_FILE})/${LAST_UPDATE_FILE}/g" CMakeLists.txt
|
|
rm CMakeLists.txt.bak
|
|
|
|
|
|
echo "---- Adding downgrade sql file to CMakeLists.txt ----"
|
|
|
|
gawk -i inplace '/ '$LAST_DOWNGRADE_FILE')/ { print; print " '$DOWNGRADE_FILE')"; next }1' CMakeLists.txt
|
|
sed -i.bak "s/ ${LAST_DOWNGRADE_FILE})/ ${LAST_DOWNGRADE_FILE}/g" CMakeLists.txt
|
|
rm CMakeLists.txt.bak
|
|
|
|
sed -i.bak "s/FILE ${LAST_DOWNGRADE_FILE})/FILE ${DOWNGRADE_FILE})/g" CMakeLists.txt
|
|
rm CMakeLists.txt.bak
|
|
|
|
|
|
echo "---- Creating CHANGELOG_$NEW_VERSION.md file ----"
|
|
|
|
rm -f ~/CHANGELOG_"$NEW_VERSION".md
|
|
|
|
cd ~/"$SOURCES_DIR"/"$FORK_DIR"
|
|
./scripts/merge_changelogs.sh > ~/CHANGELOG_"$NEW_VERSION".md
|
|
|
|
echo "---- Editing the CHANGELOG.md file with the contents of CHANGELOG_$NEW_VERSION.md file. ----"
|
|
|
|
cd ~/"$SOURCES_DIR"/"$FORK_DIR"
|
|
RELEASE_NOTE_START=$(grep -n $CURRENT_VERSION CHANGELOG.md | cut -d ':' -f 1 | head -1)
|
|
CHANGELOG_HEADER_LINES=$((RELEASE_NOTE_START - 1))
|
|
|
|
mv CHANGELOG.md CHANGELOG.md.tmp
|
|
head -n $CHANGELOG_HEADER_LINES CHANGELOG.md.tmp > CHANGELOG.md
|
|
cat ~/CHANGELOG_"$NEW_VERSION".md >> CHANGELOG.md
|
|
CHANGELOG_LENGTH=$(wc -l CHANGELOG.md.tmp | cut -d ' ' -f 5)
|
|
CHANGELOG_ENTRIES=$((CHANGELOG_LENGTH-CHANGELOG_HEADER_LINES))
|
|
tail -n "$CHANGELOG_ENTRIES" CHANGELOG.md.tmp >> CHANGELOG.md
|
|
rm CHANGELOG.md.tmp
|
|
|
|
|
|
echo "---- Deleting all unreleased pr_* , fix_* , ... style files, except template ones ----"
|
|
|
|
cd .unreleased
|
|
|
|
for f in ./*
|
|
do
|
|
case $f in
|
|
*template.*) true;;
|
|
*RELEASE_NOTES*) true;;
|
|
*) git rm "$f";;
|
|
esac
|
|
done
|
|
|
|
cd ..
|
|
|
|
git diff HEAD --name-only
|
|
|
|
|
|
echo "---- Committing the Release PR to fork ----"
|
|
|
|
#Remove date from the intermediate CHANGELOG file.
|
|
|
|
cut -d '(' -f1 < ~/CHANGELOG_"$NEW_VERSION".md > ~/CHANGELOG_"$NEW_VERSION".md.tmp
|
|
mv ~/CHANGELOG_"$NEW_VERSION".md.tmp ~/CHANGELOG_"$NEW_VERSION".md
|
|
|
|
git commit --no-verify -a -F ~/CHANGELOG_"$NEW_VERSION".md
|
|
|
|
git push origin $RELEASE_PR_BRANCH
|