-
Notifications
You must be signed in to change notification settings - Fork 369
/
buildrelease.sh
executable file
·119 lines (100 loc) · 3.29 KB
/
buildrelease.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
#!/bin/bash
# Script to perform a release build for all APIs tagged at
# a specific commit. A single argument is required: the commit to use.
# The repo is cloned into a fresh "releasebuild" directory.
set -e
# Additional arguments:
# --rebuild_docs: Just build the projects and docs, don't create nuget packages.
# Also, use the latest to pick up new docs changes rather than
# the commit of the tag.
# --skip_tests: Skip the integration tests
# --ssh: Use SSH to clone GitHub repos
rebuild_docs=false
run_tests=true
clone_path_prefix="https://github.com/"
commit=
while (( "$#" )); do
if [[ "$1" == "--rebuild_docs" ]]
then
rebuild_docs=true
elif [[ "$1" == "--skip_tests" ]]
then
run_tests=false
elif [[ "$1" == "--ssh" ]]
then
clone_path_prefix="[email protected]:"
else
commit=$1
fi
shift
done
if [ -z "$commit" ]
then
echo "Please specify a commit hash"
exit 1
fi
# Do everything from the repository root for sanity.
cd $(dirname $0)
rm -rf releasebuild
git clone ${clone_path_prefix}googleapis/google-cloud-dotnet.git releasebuild -c core.autocrlf=input --recursive
cd releasebuild
# Make sure the package is deterministic. We don't do this for local builds,
# but it makes debugging work more reliably for PDBs in packages.
export DeterministicSourcePaths=true
if [[ "$rebuild_docs" = true ]]
then
git checkout main
else
git checkout $commit
fi
# Turn the multi-line output of git tag --points-at into space-separated list of projects
projects=$(git tag --points-at $commit | sed 's/-.*//g' | awk -vORS=\ '{print $1}' | sed 's/ $//')
if [ -z "$projects" ]
then
echo "No tags found for commit $commit"
exit 1
fi
# If we're building at least one tool, assume we're not building anything else: we just need to pack
# the tools into the nuget directory, and finish.
if [[ $projects == Google.Cloud.Tools.* ]]
then
for project in $projects
do
dotnet pack -c Release -o $PWD/nuget tools/$project
done
exit 0
fi
./build.sh $projects
# Build LRO and IAM to make docs simpler. We always build the docs from "current" even if there's
# a different package reference version... which means it's *possible* they'll be inaccurate,
# but it's simpler than getting it perfectly correct.
./build.sh Google.LongRunning Google.Cloud.Iam.V1
# Retry integration tests up to 3 times as they can sometimes
# be a little flakey.
if [[ "$run_tests" = true ]]
then
./runintegrationtests.sh $projects || ./runintegrationtests.sh --retry || ./runintegrationtests.sh --retry
fi
if [[ "$rebuild_docs" = false ]]
then
for project in $projects
do
# Don't pack the whole solution - just the project. (Avoids packing dependent
# projects such as Google.LongRunning.)
dotnet pack --no-build --no-restore -o $PWD/nuget -c Release apis/$project/$project
done
fi
# TODO: Make builddocs.sh cope with being run from any directory.
(cd docs && ./builddocs.sh $projects)
echo "Release build and docs complete for the following projects:"
for project in $projects
do
echo "- ${project}"
done
if [[ "$rebuild_docs" = false ]]
then
echo "- Push packages to nuget:"
echo " - cd releasebuild/nuget"
echo " - Remove any packages you don't want to push"
echo " - for pkg in *.nupkg; do dotnet nuget push -s https://api.nuget.org/v3/index.json -k API_KEY_HERE \$pkg; done"
fi