-
Notifications
You must be signed in to change notification settings - Fork 19
147 lines (131 loc) · 4.75 KB
/
build-release.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
143
144
145
146
147
name: Build & Release draft
on:
pull_request:
push:
branches:
- master
- 2.4.x
jobs:
deploy:
name: build dependencies & create artifact
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/[email protected]
- name: Install composer dependencies
run: composer install --no-dev -o
- name: Clean-up project
uses: PrestaShopCorp/[email protected]
- name: Cache module folder
uses: 'actions/cache@v3'
with:
path: ./
key: ${{ github.run_id }}
upload_asset_preproduction:
runs-on: ubuntu-latest
needs: [ deploy ]
if: github.event_name == 'push' || github.event_name == 'pull_request'
steps:
- name: Retrieve from cache module folder
id: retrieve-cache
uses: 'actions/cache@v3'
with:
path: ./
key: ${{ github.run_id }}
- name: Check if retrieved from cache was successful
if: steps.retrieve-cache.outputs.cache-hit != 'true'
run: exit 1
- name: Manually perform GCP CLI authentication
run: |
echo $GOOGLE_JSON_CRED > token.json
gcloud auth activate-service-account --key-file=token.json
rm token.json
env:
GOOGLE_JSON_CRED: ${{ secrets.G_CREDENTIAL_PREPRODUCTION }}
- name: Copy env files
run: |
gcloud secrets versions access latest --project distribution-preprod --secret=mbo-module-env-2x > .env
rm -f .env.dist
env:
GOOGLE_APPLICATION_CREDENTIALS: ${{ secrets.G_CREDENTIAL_PREPRODUCTION }}
- name: Prepare the zip
run: |
cd ..
zip -r ${{ github.event.repository.name }}.zip ${{ github.event.repository.name }}
- name: Create & upload artifact for preprod
uses: 'actions/upload-artifact@v1'
with:
name: ${{ github.event.repository.name }}.preprod
path: ../${{ github.event.repository.name }}.zip
upload_release_asset_production:
name: Upload the production zip asset to the release
runs-on: ubuntu-latest
if: github.event_name == 'push'
needs: deploy
steps:
- name: Retrieve from cache module folder
id: retrieve-cache
uses: 'actions/cache@v3'
with:
path: ./
key: ${{ github.run_id }}
- name: Check if retrieved from cache was successful
if: steps.retrieve-cache.outputs.cache-hit != 'true'
run: exit 1
- name: Manually perform GCP CLI authentication
run: |
echo $GOOGLE_JSON_CRED > token.json
gcloud auth activate-service-account --key-file=token.json
rm token.json
env:
GOOGLE_JSON_CRED: ${{ secrets.G_CREDENTIAL_PRODUCTION }}
- name: Copy env files
run: |
rm -f .env.dist
gcloud secrets versions access latest --project distribution-production-308520 --secret=mbo-module-env-2x > .env
env:
GOOGLE_APPLICATION_CREDENTIALS: ${{ secrets.G_CREDENTIAL_PRODUCTION }}
- name: Create & upload artifact
uses: actions/upload-artifact@v1
with:
name: ${{ github.event.repository.name }}
path: ../
update_release_draft:
runs-on: ubuntu-latest
needs: [upload_release_asset_production]
if: github.event_name == 'push'
steps:
- name: Download artifact
uses: actions/download-artifact@v1
with:
name: ${{ github.event.repository.name }}
- id: release_info
uses: toolmantim/release-drafter@v5
with:
config-name: release-drafter-2x.yml
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Prepare for Release
run: |
cd ${{ github.event.repository.name }}
zip -r ${{ github.event.repository.name }}.zip ${{ github.event.repository.name }}
- name: Clean existing assets
shell: bash
run: |
curl -fsSL https://github.com/github/hub/raw/master/script/get | bash -s 2.14.1
assets=`bin/hub api -t repos/${{ github.repository }}/releases/${{ steps.release_info.outputs.id }}/assets | awk '/\].url/ { print $2 }'`
for asset in $assets
do
bin/hub api -X DELETE $asset
done
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Publish to GitHub Release
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.release_info.outputs.upload_url }}
asset_path: ./${{ github.event.repository.name }}/${{ github.event.repository.name }}.zip
asset_name: ${{ github.event.repository.name }}.zip
asset_content_type: application/zip