Merge pull request #104 from cogwheel0/simplify-fastlane-config-and-release-workflows
chore: simplify fastlane config and release workflows
This commit is contained in:
198
.github/workflows/release.yml
vendored
198
.github/workflows/release.yml
vendored
@@ -4,17 +4,10 @@ on:
|
|||||||
push:
|
push:
|
||||||
tags:
|
tags:
|
||||||
- 'v*'
|
- 'v*'
|
||||||
workflow_dispatch:
|
|
||||||
inputs:
|
concurrency:
|
||||||
tag:
|
group: release-${{ github.ref }}
|
||||||
description: 'Existing release tag to update (e.g. v1.2.3)'
|
cancel-in-progress: true
|
||||||
required: true
|
|
||||||
type: string
|
|
||||||
remove_old_assets:
|
|
||||||
description: 'Remove existing assets before uploading new ones'
|
|
||||||
required: false
|
|
||||||
default: true
|
|
||||||
type: boolean
|
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-android:
|
build-android:
|
||||||
@@ -24,59 +17,33 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
#1 Checkout Repository
|
#1 Checkout Repository
|
||||||
- name: Checkout Repository
|
- name: Checkout Repository
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
#2 Setup Java
|
#2 Setup Java
|
||||||
- name: Set Up Java
|
- name: Set Up Java
|
||||||
uses: actions/setup-java@v3
|
uses: actions/setup-java@v4
|
||||||
with:
|
with:
|
||||||
distribution: 'zulu'
|
distribution: 'temurin'
|
||||||
java-version: '21'
|
java-version: '21'
|
||||||
|
|
||||||
|
- name: Setup Gradle and caching
|
||||||
|
uses: gradle/actions/setup-gradle@v3
|
||||||
|
|
||||||
#3 Setup Flutter
|
#3 Setup Flutter
|
||||||
- name: Set Up Flutter
|
- name: Set Up Flutter
|
||||||
uses: subosito/flutter-action@v2
|
uses: subosito/flutter-action@v2
|
||||||
with:
|
with:
|
||||||
channel: 'stable'
|
channel: 'stable'
|
||||||
|
cache: true
|
||||||
|
|
||||||
#4 Install Dependencies
|
#4 Install Dependencies
|
||||||
- name: Install Dependencies
|
- name: Install Dependencies
|
||||||
run: flutter pub get
|
run: flutter pub get --enforce-lockfile
|
||||||
|
|
||||||
- name: Generate Freezed Classes
|
- name: Generate code (build_runner)
|
||||||
run: flutter pub run build_runner build --delete-conflicting-outputs
|
run: dart run build_runner build --delete-conflicting-outputs -q
|
||||||
|
|
||||||
- name: Determine Release Tag and Version
|
|
||||||
id: meta
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
|
|
||||||
RELEASE_TAG="${{ inputs.tag }}"
|
|
||||||
else
|
|
||||||
RELEASE_TAG="${{ github.ref_name }}"
|
|
||||||
fi
|
|
||||||
echo "RELEASE_TAG=$RELEASE_TAG" >> $GITHUB_ENV
|
|
||||||
# Derive VERSION_NAME (strip leading v)
|
|
||||||
VERSION_NAME="${RELEASE_TAG#v}"
|
|
||||||
echo "VERSION_NAME=$VERSION_NAME" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
# Extract current build number from pubspec.yaml if present, otherwise 1
|
|
||||||
CURRENT_VERSION_LINE=$(grep "^version:" pubspec.yaml || true)
|
|
||||||
CURRENT_BUILD=$(echo "$CURRENT_VERSION_LINE" | awk -F'+' '{print $2}')
|
|
||||||
if [[ -z "$CURRENT_BUILD" ]]; then CURRENT_BUILD=1; fi
|
|
||||||
|
|
||||||
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
|
|
||||||
# Rebuild mode: compute a unique, monotonic build number without committing
|
|
||||||
# Use CI run number offset to avoid conflicts across multiple rebuilds
|
|
||||||
BASE_BUILD=$CURRENT_BUILD
|
|
||||||
RUN_NUM=${GITHUB_RUN_NUMBER:-1}
|
|
||||||
BUILD_NUMBER=$((BASE_BUILD + RUN_NUM))
|
|
||||||
else
|
|
||||||
# Tag build: honor the build number committed in pubspec, default to CURRENT_BUILD
|
|
||||||
BUILD_NUMBER="$CURRENT_BUILD"
|
|
||||||
fi
|
|
||||||
echo "BUILD_NUMBER=$BUILD_NUMBER" >> $GITHUB_ENV
|
|
||||||
echo "Using tag=$RELEASE_TAG version=$VERSION_NAME build=$BUILD_NUMBER"
|
|
||||||
|
|
||||||
#5 Setup Keystore
|
#5 Setup Keystore
|
||||||
- name: Create Keystore
|
- name: Create Keystore
|
||||||
@@ -89,10 +56,10 @@ jobs:
|
|||||||
working-directory: android
|
working-directory: android
|
||||||
|
|
||||||
- name: Build APK
|
- name: Build APK
|
||||||
run: flutter build apk --split-per-abi --release --build-name "$VERSION_NAME" --build-number "$BUILD_NUMBER"
|
run: flutter build apk --split-per-abi --release
|
||||||
|
|
||||||
- name: Build appBundle
|
- name: Build appBundle
|
||||||
run: flutter build appbundle --release --build-name "$VERSION_NAME" --build-number "$BUILD_NUMBER"
|
run: flutter build appbundle --release
|
||||||
|
|
||||||
- name: Upload Artifacts
|
- name: Upload Artifacts
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
@@ -104,50 +71,16 @@ jobs:
|
|||||||
build/app/outputs/flutter-apk/app-x86_64-release.apk
|
build/app/outputs/flutter-apk/app-x86_64-release.apk
|
||||||
build/app/outputs/bundle/release/app-release.aab
|
build/app/outputs/bundle/release/app-release.aab
|
||||||
|
|
||||||
- name: Generate Release Notes
|
- name: Create or Update Release
|
||||||
id: release_notes
|
|
||||||
run: |
|
|
||||||
# Get the previous tag
|
|
||||||
PREVIOUS_TAG=$(git tag --sort=-version:refname | head -2 | tail -1)
|
|
||||||
|
|
||||||
# If no previous tag exists, use the first commit
|
|
||||||
if [ -z "$PREVIOUS_TAG" ]; then
|
|
||||||
PREVIOUS_TAG=$(git rev-list --max-parents=0 HEAD)
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Generate commit messages since the previous tag
|
|
||||||
echo "" >> release_notes.md
|
|
||||||
git log --pretty=format:"- %s (%h)" $PREVIOUS_TAG..${{ github.ref_name }} >> release_notes.md
|
|
||||||
|
|
||||||
# Set the release notes as output
|
|
||||||
echo "RELEASE_NOTES<<EOF" >> $GITHUB_OUTPUT
|
|
||||||
cat release_notes.md >> $GITHUB_OUTPUT
|
|
||||||
echo "EOF" >> $GITHUB_OUTPUT
|
|
||||||
if: github.event_name == 'push'
|
|
||||||
|
|
||||||
- name: Create or Update Release (tag push)
|
|
||||||
if: github.event_name == 'push'
|
|
||||||
uses: ncipollo/release-action@v1
|
uses: ncipollo/release-action@v1
|
||||||
with:
|
with:
|
||||||
artifacts: "build/app/outputs/flutter-apk/app-arm64-v8a-release.apk,build/app/outputs/flutter-apk/app-armeabi-v7a-release.apk,build/app/outputs/flutter-apk/app-x86_64-release.apk,build/app/outputs/bundle/release/app-release.aab"
|
artifacts: "build/app/outputs/flutter-apk/app-arm64-v8a-release.apk,build/app/outputs/flutter-apk/app-armeabi-v7a-release.apk,build/app/outputs/flutter-apk/app-x86_64-release.apk,build/app/outputs/bundle/release/app-release.aab"
|
||||||
tag: ${{ env.RELEASE_TAG }}
|
tag: ${{ github.ref_name }}
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
body: ${{ steps.release_notes.outputs.RELEASE_NOTES }}
|
|
||||||
generateReleaseNotes: true
|
generateReleaseNotes: true
|
||||||
allowUpdates: true
|
allowUpdates: true
|
||||||
makeLatest: true
|
makeLatest: true
|
||||||
|
|
||||||
- name: Update Existing Release (manual rebuild)
|
|
||||||
if: github.event_name == 'workflow_dispatch'
|
|
||||||
uses: ncipollo/release-action@v1
|
|
||||||
with:
|
|
||||||
artifacts: "build/app/outputs/flutter-apk/app-arm64-v8a-release.apk,build/app/outputs/flutter-apk/app-armeabi-v7a-release.apk,build/app/outputs/flutter-apk/app-x86_64-release.apk,build/app/outputs/bundle/release/app-release.aab"
|
|
||||||
tag: ${{ env.RELEASE_TAG }}
|
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
allowUpdates: true
|
|
||||||
removeArtifacts: ${{ inputs.remove_old_assets }}
|
|
||||||
makeLatest: true
|
|
||||||
omitBodyDuringUpdate: true
|
|
||||||
|
|
||||||
build-ios:
|
build-ios:
|
||||||
name: Build iOS
|
name: Build iOS
|
||||||
@@ -156,52 +89,23 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
#1 Checkout Repository
|
#1 Checkout Repository
|
||||||
- name: Checkout Repository
|
- name: Checkout Repository
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
#2 Setup Flutter
|
#2 Setup Flutter
|
||||||
- name: Set Up Flutter
|
- name: Set Up Flutter
|
||||||
uses: subosito/flutter-action@v2
|
uses: subosito/flutter-action@v2
|
||||||
with:
|
with:
|
||||||
channel: 'stable'
|
channel: 'stable'
|
||||||
|
cache: true
|
||||||
|
|
||||||
#3 Install Dependencies
|
#3 Install Dependencies
|
||||||
- name: Install Dependencies
|
- name: Install Dependencies
|
||||||
run: flutter pub get
|
run: flutter pub get --enforce-lockfile
|
||||||
|
|
||||||
- name: Generate Freezed Classes
|
- name: Generate code (build_runner)
|
||||||
run: flutter pub run build_runner build --delete-conflicting-outputs
|
run: dart run build_runner build --delete-conflicting-outputs -q
|
||||||
|
|
||||||
- name: Determine Release Tag and Version
|
|
||||||
id: meta
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
|
|
||||||
RELEASE_TAG="${{ inputs.tag }}"
|
|
||||||
else
|
|
||||||
RELEASE_TAG="${{ github.ref_name }}"
|
|
||||||
fi
|
|
||||||
echo "RELEASE_TAG=$RELEASE_TAG" >> $GITHUB_ENV
|
|
||||||
# Derive VERSION_NAME (strip leading v)
|
|
||||||
VERSION_NAME="${RELEASE_TAG#v}"
|
|
||||||
echo "VERSION_NAME=$VERSION_NAME" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
# Extract current build number from pubspec.yaml if present, otherwise 1
|
|
||||||
CURRENT_VERSION_LINE=$(grep "^version:" pubspec.yaml || true)
|
|
||||||
CURRENT_BUILD=$(echo "$CURRENT_VERSION_LINE" | awk -F'+' '{print $2}')
|
|
||||||
if [[ -z "$CURRENT_BUILD" ]]; then CURRENT_BUILD=1; fi
|
|
||||||
|
|
||||||
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
|
|
||||||
# Rebuild mode: compute a unique, monotonic build number without committing
|
|
||||||
# Use CI run number offset to avoid conflicts across multiple rebuilds
|
|
||||||
BASE_BUILD=$CURRENT_BUILD
|
|
||||||
RUN_NUM=${GITHUB_RUN_NUMBER:-1}
|
|
||||||
BUILD_NUMBER=$((BASE_BUILD + RUN_NUM))
|
|
||||||
else
|
|
||||||
# Tag build: honor the build number committed in pubspec, default to CURRENT_BUILD
|
|
||||||
BUILD_NUMBER="$CURRENT_BUILD"
|
|
||||||
fi
|
|
||||||
echo "BUILD_NUMBER=$BUILD_NUMBER" >> $GITHUB_ENV
|
|
||||||
echo "Using tag=$RELEASE_TAG version=$VERSION_NAME build=$BUILD_NUMBER"
|
|
||||||
|
|
||||||
#4 Setup Xcode
|
#4 Setup Xcode
|
||||||
- name: Setup Xcode
|
- name: Setup Xcode
|
||||||
@@ -209,16 +113,34 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
xcode-version: latest-stable
|
xcode-version: latest-stable
|
||||||
|
|
||||||
#5 Install CocoaPods
|
#5 Cache CocoaPods
|
||||||
|
- name: Cache CocoaPods
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
path: |
|
||||||
|
ios/Pods
|
||||||
|
key: ${{ runner.os }}-pods-${{ hashFiles('ios/Podfile.lock') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-pods-
|
||||||
|
|
||||||
- name: Install CocoaPods
|
- name: Install CocoaPods
|
||||||
run: |
|
run: |
|
||||||
cd ios
|
cd ios
|
||||||
pod install
|
pod install --verbose
|
||||||
|
|
||||||
|
#6 Cache Xcode DerivedData
|
||||||
|
- name: Cache Xcode DerivedData
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
path: |
|
||||||
|
~/Library/Developer/Xcode/DerivedData
|
||||||
|
key: ${{ runner.os }}-xcode-${{ hashFiles('ios/Podfile.lock', 'ios/Runner.xcodeproj/project.pbxproj', 'pubspec.lock') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-xcode-
|
||||||
|
|
||||||
#6 Build iOS App (without signing)
|
|
||||||
- name: Build iOS App
|
- name: Build iOS App
|
||||||
run: |
|
run: |
|
||||||
flutter build ios --release --no-codesign --build-name "$VERSION_NAME" --build-number "$BUILD_NUMBER"
|
flutter build ios --release --no-codesign
|
||||||
|
|
||||||
#7 Create IPA from App Bundle
|
#7 Create IPA from App Bundle
|
||||||
- name: Create IPA
|
- name: Create IPA
|
||||||
@@ -227,9 +149,8 @@ jobs:
|
|||||||
cd build/ios/Release-iphoneos
|
cd build/ios/Release-iphoneos
|
||||||
mkdir Payload
|
mkdir Payload
|
||||||
cp -r Runner.app Payload/
|
cp -r Runner.app Payload/
|
||||||
zip -r ../ipa/conduit-${{ env.VERSION_NAME }}.ipa Payload
|
zip -r ../ipa/conduit.ipa Payload
|
||||||
cd ../ipa
|
cd ../ipa
|
||||||
shasum -a 256 conduit-${{ env.VERSION_NAME }}.ipa > conduit-${{ env.VERSION_NAME }}.ipa.sha256
|
|
||||||
|
|
||||||
#8 Upload Artifacts
|
#8 Upload Artifacts
|
||||||
- name: Upload Artifacts
|
- name: Upload Artifacts
|
||||||
@@ -238,28 +159,13 @@ jobs:
|
|||||||
name: iOS-Release
|
name: iOS-Release
|
||||||
path: |
|
path: |
|
||||||
build/ios/ipa/*.ipa
|
build/ios/ipa/*.ipa
|
||||||
build/ios/ipa/*.sha256
|
|
||||||
|
|
||||||
#9 Update Release (tag push)
|
#9 Update Release
|
||||||
- name: Update Release with IPA (tag push)
|
- name: Update Release with IPA
|
||||||
if: github.event_name == 'push'
|
|
||||||
uses: ncipollo/release-action@v1
|
uses: ncipollo/release-action@v1
|
||||||
with:
|
with:
|
||||||
artifacts: "build/ios/ipa/*.ipa,build/ios/ipa/*.sha256"
|
artifacts: "build/ios/ipa/*.ipa"
|
||||||
tag: ${{ env.RELEASE_TAG }}
|
tag: ${{ github.ref_name }}
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
allowUpdates: true
|
allowUpdates: true
|
||||||
makeLatest: true
|
makeLatest: true
|
||||||
|
|
||||||
#10 Update Release (manual rebuild)
|
|
||||||
- name: Update Release with IPA (manual rebuild)
|
|
||||||
if: github.event_name == 'workflow_dispatch'
|
|
||||||
uses: ncipollo/release-action@v1
|
|
||||||
with:
|
|
||||||
artifacts: "build/ios/ipa/*.ipa,build/ios/ipa/*.sha256"
|
|
||||||
tag: ${{ env.RELEASE_TAG }}
|
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
allowUpdates: true
|
|
||||||
removeArtifacts: ${{ inputs.remove_old_assets }}
|
|
||||||
makeLatest: true
|
|
||||||
omitBodyDuringUpdate: true
|
|
||||||
|
|||||||
@@ -15,24 +15,8 @@
|
|||||||
|
|
||||||
default_platform(:android)
|
default_platform(:android)
|
||||||
|
|
||||||
def write_android_changelog
|
|
||||||
require 'yaml'
|
|
||||||
pubspec_path = File.expand_path('../../pubspec.yaml', __dir__)
|
|
||||||
pubspec = YAML.load_file(pubspec_path)
|
|
||||||
version = pubspec['version']
|
|
||||||
semver, build = version.split('+', 2)
|
|
||||||
tag = "v#{semver}"
|
|
||||||
link = "https://github.com/cogwheel0/conduit/releases/tag/#{tag}"
|
|
||||||
|
|
||||||
changelog_dir = File.expand_path('metadata/android/en-US/changelogs', __dir__)
|
|
||||||
Dir.mkdir(changelog_dir) unless Dir.exist?(changelog_dir)
|
|
||||||
changelog_file = File.join(changelog_dir, "#{build}.txt")
|
|
||||||
File.write(changelog_file, link + "\n")
|
|
||||||
end
|
|
||||||
|
|
||||||
desc "Push a new release build to the Google Play"
|
desc "Push a new release build to the Google Play"
|
||||||
lane :release do
|
lane :release do
|
||||||
write_android_changelog
|
|
||||||
upload_to_play_store(
|
upload_to_play_store(
|
||||||
json_key: ENV['FASTLANE_JSON_KEY_PATH'],
|
json_key: ENV['FASTLANE_JSON_KEY_PATH'],
|
||||||
track: 'production',
|
track: 'production',
|
||||||
|
|||||||
@@ -0,0 +1 @@
|
|||||||
|
https://github.com/cogwheel0/conduit/releases/tag/v2.1.10
|
||||||
@@ -6,3 +6,4 @@ skip_metadata(true)
|
|||||||
skip_screenshots(true)
|
skip_screenshots(true)
|
||||||
run_precheck_before_submit(false)
|
run_precheck_before_submit(false)
|
||||||
ipa("../build/ios/ipa/conduit.ipa")
|
ipa("../build/ios/ipa/conduit.ipa")
|
||||||
|
release_notes('en-US' => File.read('metadata/en-US/release_notes.txt'))
|
||||||
|
|||||||
@@ -14,15 +14,6 @@
|
|||||||
# update_fastlane
|
# update_fastlane
|
||||||
default_platform(:ios)
|
default_platform(:ios)
|
||||||
lane :release do
|
lane :release do
|
||||||
require 'yaml'
|
|
||||||
pubspec_path = File.expand_path('../../pubspec.yaml', __dir__)
|
|
||||||
pubspec = YAML.load_file(pubspec_path)
|
|
||||||
version = pubspec['version'] # e.g., "2.1.6+31"
|
|
||||||
semver, _build = version.split('+', 2)
|
|
||||||
tag = "v#{semver}"
|
|
||||||
link = "https://github.com/cogwheel0/conduit/releases/tag/#{tag}"
|
|
||||||
notes_path = File.expand_path('metadata/en-US/release_notes.txt', __dir__)
|
|
||||||
File.write(notes_path, link + "\n")
|
|
||||||
app_store_connect_api_key(
|
app_store_connect_api_key(
|
||||||
key_id: ENV['FASTLANE_API_KEY_ID'],
|
key_id: ENV['FASTLANE_API_KEY_ID'],
|
||||||
issuer_id: ENV['FASTLANE_API_KEY_ISSUER_ID'],
|
issuer_id: ENV['FASTLANE_API_KEY_ISSUER_ID'],
|
||||||
|
|||||||
@@ -142,9 +142,23 @@ print_status "Updating pubspec.yaml to version: $NEW_VERSION+$NEW_BUILD"
|
|||||||
sed -i.bak "s/^version: .*/version: $NEW_VERSION+$NEW_BUILD/" pubspec.yaml
|
sed -i.bak "s/^version: .*/version: $NEW_VERSION+$NEW_BUILD/" pubspec.yaml
|
||||||
rm pubspec.yaml.bak
|
rm pubspec.yaml.bak
|
||||||
|
|
||||||
|
# Generate Fastlane changelogs
|
||||||
|
print_status "Generating Fastlane changelogs..."
|
||||||
|
LINK="https://github.com/cogwheel0/conduit/releases/tag/$TAG_VERSION"
|
||||||
|
|
||||||
|
# Android changelog (by build number)
|
||||||
|
ANDROID_CHANGELOG_DIR="android/fastlane/metadata/android/en-US/changelogs"
|
||||||
|
mkdir -p "$ANDROID_CHANGELOG_DIR"
|
||||||
|
echo "$LINK" > "$ANDROID_CHANGELOG_DIR/$NEW_BUILD.txt"
|
||||||
|
|
||||||
|
# iOS release notes
|
||||||
|
IOS_NOTES_PATH="ios/fastlane/metadata/en-US/release_notes.txt"
|
||||||
|
mkdir -p "$(dirname "$IOS_NOTES_PATH")"
|
||||||
|
echo "$LINK" > "$IOS_NOTES_PATH"
|
||||||
|
|
||||||
# Commit changes
|
# Commit changes
|
||||||
print_status "Committing changes..."
|
print_status "Committing changes..."
|
||||||
git add pubspec.yaml
|
git add pubspec.yaml "$ANDROID_CHANGELOG_DIR/$NEW_BUILD.txt" "$IOS_NOTES_PATH"
|
||||||
git commit -m "chore: bump version to $NEW_VERSION"
|
git commit -m "chore: bump version to $NEW_VERSION"
|
||||||
|
|
||||||
git push origin main
|
git push origin main
|
||||||
|
|||||||
Reference in New Issue
Block a user