This repository has been archived by the owner on Oct 26, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
127 lines (108 loc) · 4.76 KB
/
test-ios.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
name: Test iOS
on:
workflow_dispatch:
# Declare default permissions as readonly.
permissions: read-all
jobs:
ios:
name: Create ios
runs-on: macos-latest
steps:
- uses: actions/checkout@v4
- name: Install yq
run: |
if ! command -v yq >/dev/null 2>&1; then
echo "yq not exists"
brew install yq
fi
yq --version
- name: Setup Flutter
uses: subosito/flutter-action@v2
with:
channel: 'stable'
flutter-version: '3.24.4'
- name: Configure .env
run: |
echo "$ENV_KEY" | base64 --decode > .env
env:
ENV_KEY: ${{ secrets.ENV_STG_BASE64 }}
- name: Flutter doctor -v
run: flutter doctor -v
- name: Resolving flutter dependencies
run: flutter pub get
- name: Resolving ios dependencies
run: cd ios && pod install --repo-update && cd ..
- name: Install the Apple certificate and provisioning profile
env:
CERT_BASE64: ${{ secrets.CERT_BASE64 }}
CERT_DEV_BASE64: ${{ secrets.CERT_DEV_BASE64 }}
P12_BASE64: ${{ secrets.P12_BASE64 }}
P12_DEV_BASE64: ${{ secrets.P12_DEV_BASE64 }}
P12_PASSWORD: ${{ secrets.P12_PASSWORD }}
PROVISION_PROFILE_BASE64: ${{ secrets.PROVISION_PROFILE_BASE64 }}
PROVISION_PROFILE_DEV_BASE64: ${{ secrets.PROVISION_PROFILE_DEV_BASE64 }}
KEYCHAIN_PASSWORD: ${{ secrets.KEYCHAIN_PASSWORD }}
run: |
# create variables
CERTIFICATE_PATH=$RUNNER_TEMP/build_certificate.p12
CERTIFICATE_DEV_PATH=$RUNNER_TEMP/build_certificate_dev.p12
CERT_PATH=$RUNNER_TEMP/ios_distribution.cer
CERT_DEV_PATH=$RUNNER_TEMP/ios_development.cer
PP_PATH=$RUNNER_TEMP/watermark_assistant_appstore.mobileprovision
PP_DEV_PATH=$RUNNER_TEMP/watermark_assistant_dev.mobileprovision
KEYCHAIN_PATH=$RUNNER_TEMP/ff-signing.keychain-db
# import certificate and provisioning profile from secrets
echo -n "$P12_BASE64" | base64 --decode --output $CERTIFICATE_PATH
echo -n "$P12_DEV_BASE64" | base64 --decode --output $CERTIFICATE_DEV_PATH
echo -n "$CERT_BASE64" | base64 --decode --output $CERT_PATH
echo -n "$CERT_DEV_BASE64" | base64 --decode --output $CERT_DEV_PATH
echo -n "$PROVISION_PROFILE_BASE64" | base64 --decode --output $PP_PATH
echo -n "$PROVISION_PROFILE_DEV_BASE64" | base64 --decode --output $PP_DEV_PATH
# create temporary keychain
security create-keychain -p "$KEYCHAIN_PASSWORD" $KEYCHAIN_PATH
security set-keychain-settings -lut 21600 $KEYCHAIN_PATH
security unlock-keychain -p "$KEYCHAIN_PASSWORD" $KEYCHAIN_PATH
# import certificate to keychain
security import $CERTIFICATE_PATH -P "$P12_PASSWORD" -A -t cert -f pkcs12 -k $KEYCHAIN_PATH
security import $CERTIFICATE_DEV_PATH -P "$P12_PASSWORD" -A -t cert -f pkcs12 -k $KEYCHAIN_PATH
security import $CERT_PATH -P "$P12_PASSWORD" -A -t cert -k $KEYCHAIN_PATH
security import $CERT_DEV_PATH -P "$P12_PASSWORD" -A -t cert -k $KEYCHAIN_PATH
security list-keychain -d user -s $KEYCHAIN_PATH
# apply provisioning profile
mkdir -p ~/Library/MobileDevice/Provisioning\ Profiles
mv $PP_PATH ~/Library/MobileDevice/Provisioning\ Profiles
mv $PP_DEV_PATH ~/Library/MobileDevice/Provisioning\ Profiles
- name: Build Ipa
run: |
echo "╠ Removing build products and intermediate files from the build root..."
cd ios && xcodebuild clean && cd ..
echo "╠ Releasing to app store..."
flutter build ipa --dart-define-from-file=.env --export-options-plist=ios/ExportOptions-debug.plist
- name: Set version
id: version_step
run: |
VERSION=$(yq '.version' pubspec.yaml)
echo "$VERSION"
echo "version=$VERSION" >> $GITHUB_OUTPUT
# Package the build.
- name: Copy build for iOS
run: |
ls -la
cp *.ipa $GITHUB_WORKSPACE/FaForever_"$VERSION".pre.ipa
working-directory: build/ios/ipa
env:
VERSION: ${{ steps.version_step.outputs.version }}
- uses: actions/upload-artifact@v4
with:
name: ios-ipa-artifact
path: |
./*.ipa
- name: Clean up
if: ${{ always() }}
run: |
if [ -f "$RUNNER_TEMP/ff-signing.keychain-db" ]; then
echo "$RUNNER_TEMP/ff-signing.keychain-db"
security delete-keychain $RUNNER_TEMP/ff-signing.keychain-db
fi
rm -f ~/Library/MobileDevice/Provisioning\ Profiles/watermark_assistant_*.mobileprovision
rm -f .env