-
Notifications
You must be signed in to change notification settings - Fork 130
/
deploy.sh
executable file
·100 lines (80 loc) · 3.03 KB
/
deploy.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
#!/bin/bash
set -e # Exit with nonzero exit code if anything fails
SOURCE_BRANCH="main"
TARGET_BRANCH="gh-pages"
# List of long-lived topic branch names to be published on github.io as a subdirectory
# Once added, branches should not be removed from here,
# because cool URLs don't change.
# (But you can stop advertising them in README.md)
# Even if the branch itself is retired,
# the built copies will continue to be served unless and until its name is removed from here.
TOPIC_BRANCHES=(
"director-free"
"tooling"
"registries"
"registries-on-rec-track"
"registries-separable"
"evergreen"
"everblue"
"section-6-clean-up"
"maintenance-2020"
"p2021-before-reorg"
"p2021")
containsElement () {
local e match="$1"
shift
for e; do [[ "$e" == "$match" ]] && return 0; done
return 1
}
# So we can see what we're doing
set -x
# set up the github credentials
git config --global user.email 87540780+w3cgruntbot@users.noreply.github.com
git config --global user.name w3cgruntbot
git config --global user.password $GITHUB_TOKEN
REPO_URL="https://w3cbot:$GITHUB_TOKEN@github.com/$GITHUB_REPOSITORY.git"
# set up old travis env
TRAVIS_BRANCH=${GH_BRANCH:-$(echo $GITHUB_REF | awk 'BEGIN { FS = "/" } ; { print $3 }')}
TRAVIS_PULL_REQUEST=${GH_EVENT_NUMBER:-false}
# Pull requests and commits to other branches shouldn't try to deploy, just build to verify
if [ "$TRAVIS_PULL_REQUEST" != "false" ] || { [ "$TRAVIS_BRANCH" != "$SOURCE_BRANCH" ] && ! containsElement "$TRAVIS_BRANCH" "${TOPIC_BRANCHES[@]}" ; }; then
echo "Skipping deploy; just doing a build."
./compile.sh
exit 0
fi
# Clone the existing gh-pages for this repo into out/
# Create a new empty branch if gh-pages doesn't exist yet (should only happen on first deploy)
git clone $REPO_URL out
cd out
git checkout $TARGET_BRANCH || git checkout --orphan $TARGET_BRANCH
git reset --hard
if containsElement "$TRAVIS_BRANCH" "${TOPIC_BRANCHES[@]}" ; then
# Delete all existing contents except in the topic branch directory (we will re-create them)
mkdir -p "$TRAVIS_BRANCH"
cd "$TRAVIS_BRANCH"
find -maxdepth 1 ! -name . | xargs rm -rf
cd ../..
./compile.sh "$TRAVIS_BRANCH"
else
# Delete all existing contents except .git and topic branches (we will re-create them)
for i in "${TOPIC_BRANCHES[@]}"; do
echo exclude="$exclude ! -name '$i'";
exclude="$exclude ! -name '$i'";
done
eval find -maxdepth 1 ! -name .git ! -name . "$exclude" | xargs rm -rf
cd ..
./compile.sh
fi
# Now let's go have some fun with the cloned repo
cd out
# If there are no changes to the compiled out (e.g. this is a README update) then just bail.
if [[ -z $(git status --porcelain) ]]; then
echo "No changes to the output on this push; exiting."
exit 0
fi
# Commit the "changes", i.e. the new version.
# The delta will show diffs between new and old versions.
git add -A .
git commit -m ":robot: Deploy to GitHub Pages: ${GITHUB_SHA} from branch \"${TRAVIS_BRANCH}\""
# Now that we're all set up, we can push.
git push $REPO_URL $TARGET_BRANCH