forked from d2iq-archive/dcos-commons
-
Notifications
You must be signed in to change notification settings - Fork 6
/
release.sh
executable file
·151 lines (131 loc) · 5.6 KB
/
release.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
#!/bin/bash
# --
# Builds and uploads a release of the SDK against a release-specific tag.
# This does NOT create releases of individual services in the repo, just the SDK itself.
# --
syntax() {
echo "Syntax: ./release.sh -r <tagname or 'snapshot'> [-f] [-d]"
echo "Arguments:"
echo " -r: The version string of the PX SDK (only PX part) to be used in gradle and in the tag name, or '-r snapshot' to publish a snapshot. Eg. 1.3.2"
echo " -f: Force the tag creation if the tag already exists. (not applicable to '-r snapshot')"
echo " -d: Dry run. Build artifacts but do not upload/publish them."
}
# Exit immediately on failure:
set -e
REPO_ROOT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
cd $REPO_ROOT_DIR
GRADLE_BUILD_FILE=$REPO_ROOT_DIR/build.gradle
FLAG_RELEASE=""
FLAG_FORCE="false"
FLAG_DRY_RUN="false"
while getopts "r:fd" opt; do
case $opt in
r)
FLAG_RELEASE=${OPTARG,,} # to lowercase
;;
f)
FLAG_FORCE="true"
;;
d)
FLAG_DRY_RUN="true"
;;
\?)
syntax
exit 1
;;
esac
done
if [ -z "$FLAG_RELEASE" ]; then
echo "Missing required tag argument (-r <tagname or 'snapshot'>)"
syntax
exit 1
fi
echo "Settings: tag=$FLAG_RELEASE force=$FLAG_FORCE dry_run=$FLAG_DRY_RUN"
export SDK_VERSION=$(egrep "version = '(.*)'" $GRADLE_BUILD_FILE | cut -d "'" -f2)
export PX_VERSION=$(egrep "pxVersion = '(.*)'" $GRADLE_BUILD_FILE | cut -d "'" -f2)
if [[ -z "$SDK_VERSION" || -z "$PX_VERSION" ]]; then
echo "Unable to extract SDK version or PX version from $GRADLE_BUILD_FILE"
exit 1
fi
echo "Current gradle version: $SDK_VERSION"
echo "Current PX gradle version: $PX_VERSION"
if [[ "${SDK_VERSION^^}" = *"SNAPSHOT"* ]]; then
echo "DCOS SDK version may not contain 'SNAPSHOT'."
exit 1
fi
if [ "x${FLAG_RELEASE}" = "xsnapshot" ]; then
# Sanity check: Validate that build.gradle already has a '-SNAPSHOT' version (case sensitive comparison)
if [[ "$PX_VERSION" != *"-SNAPSHOT"* ]]; then
echo "PX version in $GRADLE_BUILD_FILE doesn't contain '-SNAPSHOT'."
echo "The master branch must only have snapshot builds."
exit 1
fi
RELEASE_VERSION=$SDK_VERSION-$PX_VERSION
else
# Uploading a release: Create and publish the release tag, which contains a commit updating build.gradle.
# Sanity check: Tagged releases of snapshots is disallowed (case insensitive comparison)
if [[ "${FLAG_RELEASE^^}" = *"SNAPSHOT"* ]]; then
echo "Requested tag release version may not contain 'SNAPSHOT'."
exit 1
fi
RELEASE_VERSION=$SDK_VERSION-$FLAG_RELEASE
if [ "x$FLAG_DRY_RUN" = "xfalse" ]; then
sed -i "s/pxVersion = '${PX_VERSION}'/pxVersion = '${FLAG_RELEASE}'/" $GRADLE_BUILD_FILE
git add $GRADLE_BUILD_FILE
git commit -m "Automated cut of $RELEASE_VERSION"
if [ "x$FLAG_FORCE" = "xtrue" ]; then
git tag -f "$RELEASE_VERSION"
git push origin -f "$RELEASE_VERSION"
else
FAILED=""
git tag "$RELEASE_VERSION" || FAILED="true"
# Jump through hoops to avoid conflicts with 'set -e':
if [ -n "$FAILED" ]; then
echo "Tag named '$RELEASE_VERSION' already exists locally. Use '-f' to overwrite the current tag."
exit 1
fi
git push origin "$RELEASE_VERSION" || FAILED="true"
if [ -n "$FAILED" ]; then
echo "Tag named '$RELEASE_VERSION' already exists in remote repo. Use '-f' to overwrite the current tag."
exit 1
fi
fi
fi
fi
# Perform all builds before attempting to upload anything
sdk/bootstrap/build.sh # produces sdk/bootstrap/bootstrap.zip
sdk/cli/build.sh # produces sdk/cli/[dcos-service-cli-linux, dcos-service-cli-darwin, dcos-service-cli.exe]
./gradlew :executor:distZip # produces sdk/executor/build/distributions/executor.zip
rm -f tools/pip/*.whl
# not modifying this to $RELEASE_VERSION ($PX_VERSION-$SDK_VERSION) to avoid breaking pip version formatting
tools/pip/build.sh $SDK_VERSION # produces tools/pip/[testing|tools]-[SDK_VERSION (with modifications)]-py3-none-any.whl
# Collect the other artifacts into a single directory, calculate a SHA256SUMS file, and then upload the lot.
# The SHA256SUMS file is required for construction of packages that use default CLIs, and is a Good Idea in general.
echo "Collecting artifacts in $(pwd)/$RELEASE_VERSION"
rm -rf $RELEASE_VERSION
mkdir $RELEASE_VERSION
# Note about .whl files: pip is picky about version formatting, so the outputted filenames may not exactly match $SDK_VERSION due to some mangling.
# For example, "1.2.3-SNAPSHOT" has to be converted to "1.2.3+snapshot".
# Additionally, pip will refuse to install .whl files without the extra info in the filename, so we leave all that in.
cp sdk/bootstrap/bootstrap.zip \
sdk/executor/build/distributions/executor.zip \
sdk/cli/dcos-service-cli* \
tools/pip/*.whl \
$RELEASE_VERSION/
# Ensure that checksums do not contain relative dir path:
cd $RELEASE_VERSION/
sha256sum * | tee SHA256SUMS # print stdout+stderr, write stdout to file
ls -l
cd ..
S3_DIR=s3://$S3_RELEASE_BUCKET/dcos-commons/artifacts/$RELEASE_VERSION
if [ "x$FLAG_DRY_RUN" != "xfalse" ]; then
echo "Dry run: Exiting without uploading artifacts to $S3_DIR"
exit 0
fi
echo "Uploading artifacts to $S3_DIR"
# Build+upload Java libraries to Maven repo (within S3, see build.gradle):
./gradlew publish
# Upload contents of artifact dir:
aws s3 sync --acl public-read $RELEASE_VERSION/ $S3_DIR 1>&2
# Clean up
rm -rf $RELEASE_VERSION