Skip to content
This repository has been archived by the owner on Oct 26, 2024. It is now read-only.

Test iOS

Test iOS #1

Workflow file for this run

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: Setup Flutter
uses: subosito/flutter-action@v2
with:
channel: 'stable'
flutter-version: '3.24.1'
- 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