-
Notifications
You must be signed in to change notification settings - Fork 0
219 lines (191 loc) · 6.63 KB
/
mob-react-native-production-deploy-android.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
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
name: Firebase deployment
# Variables needed setted in testing environment
# AWS_BUCKET
# GRADLE_ENV_NAME
# ENV_VARIABLES
# ENV_FILE_NAME
# ANDROID_PACKAGE_NAME
on:
workflow_call:
inputs:
RELEASE_TAG:
type: string
description: Tag
required: true
ANDROID_KEYSTORE_NAME:
type: string
required: true
NODE_VERSION:
type: string
default: '18'
required: false
DISABLE_CACHE:
type: string
default: 'false'
required: false
SLACK_CHANNEL:
type: string
required: false
VERSION_CODE_OFFSET:
type: number
default: 0
required: false
GRADLE_VERSION:
type: string
default: release-candidate
required: false
secrets:
SLACK_WEBHOOK_URL:
required: true
# ANDROID
ANDROID_KEYSTORE_BASE64:
required: true
ANDROID_KEYSTORE_PASSWORD:
required: true
ANDROID_KEY_ALIAS:
required: true
ANDROID_KEY_PASSWORD:
required: true
ANDROID_SERVICE_ACCOUNT:
required: true
AWS_ACCESS_KEY_ID:
required: true
AWS_SECRET_ACCESS_KEY:
required: true
AWS_REGION:
required: true
env:
RELEASE_TAG: '${{ inputs.RELEASE_TAG }}'
DISABLE_CACHE: '${{ inputs.DISABLE_CACHE }}'
SLACK_CHANNEL: '${{ inputs.SLACK_CHANNEL }}'
NODE_VERSION: '${{ inputs.NODE_VERSION }}'
VERSION_CODE_OFFSET: '${{ inputs.VERSION_CODE_OFFSET || 0 }}'
GRADLE_VERSION: '${{ inputs.GRADLE_VERSION }}'
SLACK_WEBHOOK_URL: '${{ secrets.SLACK_WEBHOOK_URL }}'
GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}'
# Android
ANDROID_KEYSTORE_NAME: '${{ inputs.ANDROID_KEYSTORE_NAME }}'
ANDROID_KEYSTORE_BASE64: '${{ secrets.ANDROID_KEYSTORE_BASE64 }}'
ANDROID_KEYSTORE_PASSWORD: '${{ secrets.ANDROID_KEYSTORE_PASSWORD }}'
ANDROID_KEY_ALIAS: '${{ secrets.ANDROID_KEY_ALIAS }}'
ANDROID_KEY_PASSWORD: '${{ secrets.ANDROID_KEY_PASSWORD }}'
ANDROID_SERVICE_ACCOUNT: '${{ secrets.ANDROID_SERVICE_ACCOUNT }}'
ANDROID_OUTPUT_FILEPATH: 'android/app/build/outputs/bundle/${{ vars.GRADLE_ENV_NAME }}Release/app-${{ vars.GRADLE_ENV_NAME }}-release.aab'
jobs:
deploy:
environment: production
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: ${{ env.NODE_VERSION }}
- name: Cache dependencies
uses: actions/cache@v3
if: env.DISABLE_CACHE != 'true'
id: cache
with:
path: ./node_modules
key: modules-${{ hashFiles('package-lock.json') }}
- name: Install dependencies
if: (steps.cache.outputs.cache-hit != 'true')
run: npm ci --ignore-scripts
- name: Calculate version code
shell: bash
env:
RUN_NUMBER: ${{ github.run_number }}
run: echo VERSION_CODE=$((${{ env.RUN_NUMBER }} + ${{ env.VERSION_CODE_OFFSET }})) >> $GITHUB_ENV
- name: Bump version
uses: chkfung/[email protected]
with:
gradlePath: android/app/build.gradle
versionCode: ${{ env.VERSION_CODE }}
versionName: ${{ env.RELEASE_TAG }}
- name: Modify package.json based on bumped tag
shell: bash
run: |
echo sed -i 's/\"version\":\s*\"[0-9]+\.[0-9]+\.[0-9]+\",\"version\": \"${{ env.RELEASE_TAG }}\"/g' package.json
- name: Create .env file
shell: bash
run: echo "${{ vars.ENV_VARIABLES }}" > ${{ vars.ENV_FILE_NAME }}
- name: Capitalize gradle environment
id: CAPITALIZED_GRADLE_ENV
uses: ASzc/change-string-case-action@v5
with:
string: ${{ vars.GRADLE_ENV_NAME }}
- name: Decode Keystore
id: keystore
uses: timheuer/[email protected]
with:
fileName: ${{ env.ANDROID_KEYSTORE_NAME }}
encodedString: ${{ secrets.ANDROID_KEYSTORE_BASE64 }}
- name: Gradle cache
uses: actions/cache@v3
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
!~/.gradle/wrapper/dists/**/gradle*.zip
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*') }}
restore-keys: |
${{ runner.os }}-gradle-
- name: Gradle Setup
uses: gradle/[email protected]
with:
gradle-version: ${{ env.GRADLE_VERSION }}
build-root-directory: android/
gradle-executable: android/
- name: Clean NDK
shell: bash
run: |
rm -rf /usr/local/lib/android/sdk/ndk
sed -i '/^ANDROID_NDK/d' ~/.bashrc
sed -i '/^ANDROID_NDK_HOME/d' ~/.bashrc
sed -i '/^ANDROID_NDK_LATEST_HOME/d' ~/.bashrc
sed -i '/^ANDROID_NDK_ROOT/d' ~/.bashrc
- name: Build Android Release
run: cd android && ./gradlew bundle${{ env.GRADLE_ENV }}Release --no-daemon
env:
GRADLE_ENV: ${{ steps.CAPITALIZED_GRADLE_ENV.outputs.capitalized }}
SIGNING_STORE_PATH: ${{ steps.keystore.outputs.filePath }}
SIGNING_STORE_PASSWORD: ${{ env.ANDROID_KEYSTORE_PASSWORD }}
SIGNING_KEY_ALIAS: ${{ env.ANDROID_KEY_ALIAS }}
SIGNING_KEY_PASSWORD: ${{ env.ANDROID_KEY_PASSWORD }}
- name: Get project name
uses: antifree/[email protected]
with:
filename: app.json
prefix: app
- name: Configure AWS Credentials
uses: aws-actions/[email protected]
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ${{ secrets.AWS_REGION }}
- name: Upload artifact S3
env:
FILE_NAME: '${{ vars.ANDROID_PACKAGE_NAME }}-${{ env.RELEASE_TAG }}.aab'
run: aws s3 cp ${{ env.ANDROID_OUTPUT_FILEPATH }} s3://${{ vars.AWS_BUCKET }}/${{ env.app_name }}/android/${{ env.FILE_NAME }}
- name: Upload to Play store
uses: r0adkll/upload-google-play@v1
with:
releaseFiles: ${{ env.ANDROID_OUTPUT_FILEPATH }}
serviceAccountJsonPlainText: ${{ env.ANDROID_SERVICE_ACCOUNT }}
packageName: ${{ vars.ANDROID_PACKAGE_NAME }}
track: internal
releaseName: ${{ env.RELEASE_TAG }}
status: completed
inAppUpdatePriority: 2
notify:
runs-on: ubuntu-latest
needs:
- deploy
if: success() || failure()
continue-on-error: true
steps:
- name: Slack Notify
uses: steplix/[email protected]
with:
template: push
status: failure
channel: ${{ env.SLACK_CHANNEL }}