-
Notifications
You must be signed in to change notification settings - Fork 1.7k
142 lines (122 loc) · 4.14 KB
/
build-downstream.yml
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
name: build-downstreams
permissions: read-all
on:
push:
branches:
- main
- 'FEATURE-BRANCH-*'
pull_request:
jobs:
build-downstreams:
name: ${{ matrix.repo }}
strategy:
fail-fast: false
matrix:
repo: ['terraform-provider-google', 'terraform-provider-google-beta', 'terraform-google-conversion', 'docs-examples']
runs-on: ubuntu-22.04
env:
BASE_BRANCH: ${{ github.event.pull_request.base.ref || github.ref }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: Checkout Repository
uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Set up Ruby
uses: ruby/setup-ruby@ec02537da5712d66d4d50a0f33b7eb52773b5ed1
with:
ruby-version: '3.1'
- name: Cache Bundler gems
uses: actions/cache@v2
with:
path: mmv1/vendor/bundle
key: ${{ runner.os }}-gems-${{ hashFiles('mmv1/**/Gemfile.lock') }}
restore-keys: |
${{ runner.os }}-gems-
- name: Install Ruby dependencies
run: |
bundle config path mmv1/vendor/bundle
bundle install
working-directory: mmv1
- name: Set up Go
uses: actions/setup-go@v3
with:
go-version: '^1.19'
# Cache Go modules
- name: Cache Go modules
uses: actions/cache@v2
with:
path: ~/go/pkg/mod
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-
- run: go install golang.org/x/tools/cmd/goimports@latest
# - name: Build ${{ matrix.repo }}
# run: |
# GH_REPO="${{ matrix.repo }}"
# if [[ "$GH_REPO" == terraform-provider-google* ]]; then
# UPSTREAM_OWNER=hashicorp
# elif [ "$GH_REPO" == "terraform-google-conversion" ]; then
# UPSTREAM_OWNER=GoogleCloudPlatform
# elif [ "$GH_REPO" == "docs-examples" ]; then
# UPSTREAM_OWNER=terraform-google-modules
# else
# echo "case not supported"
# exit 1
# fi
# echo "UPSTREAM_OWNER=$UPSTREAM_OWNER" >> $GITHUB_OUTPUT
- name: Build ${{ matrix.repo }}
run: |
set -e
set -x
# Set GOPATH to a directory the runner user has access to
export GOPATH=~/go
function clone_repo() {
export OUTPUT_PATH=$GOPATH/src/github.com/$UPSTREAM_OWNER/$GH_REPO
GITHUB_PATH=https://x-access-token:[email protected]/$UPSTREAM_OWNER/$GH_REPO
mkdir -p "$(dirname $OUTPUT_PATH)"
git clone $GITHUB_PATH $OUTPUT_PATH --branch $BASE_BRANCH
}
GH_REPO="${{ matrix.repo }}"
if [ "$GH_REPO" == "docs-examples" ] && [ "$BASE_BRANCH" == "main" ]; then
BASE_BRANCH="master"
fi
GITHUB_PATH=https://x-access-token:[email protected]/$UPSTREAM_OWNER/$GH_REPO
if [[ "$GH_REPO" == terraform-provider-google* ]]; then
UPSTREAM_OWNER=hashicorp
clone_repo
if [ "$GH_REPO" == "terraform-provider-google" ]; then
export VERSION=ga
else
export VERSION=beta
fi
make clean-provider
make provider
elif [ "$GH_REPO" == "terraform-google-conversion" ]; then
UPSTREAM_OWNER=GoogleCloudPlatform
clone_repo
make clean-tgc
make tgc
elif [ "$GH_REPO" == "docs-examples" ]; then
UPSTREAM_OWNER=terraform-google-modules
clone_repo
make tf-ocis
else
echo "case not supported"
exit 1
fi
# - name: Zip the directory
# run: zip -r output.zip .
# - name: Upload artifact
# uses: actions/upload-artifact@v2
# with:
# name: zipped-repo
# path: output.zip
# - name: Save PR number
# run: |
# mkdir -p ./pr
# echo ${{ github.event.number }} > ./pr/NR
# - uses: actions/upload-artifact@v2
# with:
# name: pr
# path: pr/