-
Notifications
You must be signed in to change notification settings - Fork 42
87 lines (78 loc) · 3.12 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
name: Build & Release draft
on:
push:
branches:
- 'master'
- 'prestashop/8.x'
pull_request:
types: [ opened, reopened, synchronize, edited ]
env:
GCLOUD_TOKEN_PATH: ./token.json
jobs:
deploy:
name: build dependencies & create artifact
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/[email protected]
- name: Gcloud auth and write env file
run: |
echo $GOOGLE_APPLICATION_CREDENTIALS > $GCLOUD_TOKEN_PATH
gcloud auth activate-service-account --key-file=$GCLOUD_TOKEN_PATH
gcloud container clusters get-credentials $GCLOUD_CLUSTER \
--zone europe-west1-c --project $GCLOUD_PROJECT
gcloud beta secrets versions access latest --project=$GCLOUD_PROJECT --secret="checkout-module" > .env
rm $GCLOUD_TOKEN_PATH
env:
GOOGLE_APPLICATION_CREDENTIALS: ${{ secrets.GCLOUD_CREDENTIAL_PRODUCTION }}
GCLOUD_TOKEN_PATH: ${{ env.GCLOUD_TOKEN_PATH }}
GCLOUD_CLUSTER: ${{ secrets.GCLOUD_CLUSTER }}
GCLOUD_PROJECT: ${{ secrets.GCLOUD_PROJECT_PRODUCTION }}
- name: Install composer dependencies
run: composer install --no-dev -o
- name: Clean-up project
uses: PrestaShopCorp/[email protected]
- name: Clean-up node_modules directory
run: sudo rm -rf node_modules
- name: Create & upload artifact
uses: actions/upload-artifact@v1
with:
name: ${{ github.event.repository.name }}
path: ../
update_release_draft:
runs-on: ubuntu-latest
needs: [deploy]
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
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Prepare for Release
run: |
cd ${{ github.event.repository.name }}
zip -r ${{ github.event.repository.name }}-${{ github.event.release.tag_name }}.zip ${{ github.event.repository.name }} -x '*.git*'
- 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 }}-${{ github.event.release.tag_name }}.zip
asset_name: ${{ github.event.repository.name }}-${{ github.event.release.tag_name }}.zip
asset_content_type: application/zip