Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Infra] Switch zip building over to Xcode 15.2 #12737

Merged
merged 30 commits into from
Apr 18, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
6945629
[Infra] Switch zip building over to Xcode 15.2
ncooke3 Apr 9, 2024
f098d2b
Fix yml syntax
ncooke3 Apr 9, 2024
24fb157
Fix yml matrix syntax throughout
ncooke3 Apr 9, 2024
3e42db3
Fix symlink issue when creating xcframework before Xcode 15.3
ncooke3 Apr 13, 2024
ddbc247
Merge branch 'main' into nc/zip-testing
ncooke3 Apr 13, 2024
6739980
Add changelog entry
ncooke3 Apr 13, 2024
99b6423
Catch error
ncooke3 Apr 15, 2024
2e58c41
Don't build on arm macs
ncooke3 Apr 15, 2024
cc4088a
Revert "Don't build on arm macs"
ncooke3 Apr 15, 2024
83ff298
Try macos14-arm
ncooke3 Apr 15, 2024
d77d85b
Merge branch 'main' into nc/zip-testing
ncooke3 Apr 16, 2024
63df007
plain macos-14 is arm
ncooke3 Apr 16, 2024
7ccc76d
Shortcut test macos14 zip
ncooke3 Apr 17, 2024
1ba4536
Fix invalid syntax
ncooke3 Apr 17, 2024
e0dfc4f
Fix invalid syntax (1)
ncooke3 Apr 17, 2024
7105e5f
wrokaround Xcode 15 resource issues
ncooke3 Apr 17, 2024
8e2de3e
Delete resources after copy
ncooke3 Apr 17, 2024
8c51f9d
Move delete
ncooke3 Apr 17, 2024
195aaa5
MAdd logging
ncooke3 Apr 17, 2024
ce646f4
Debug
ncooke3 Apr 17, 2024
6701681
debug workaround by only running FST
ncooke3 Apr 17, 2024
337abdb
Disable Firebase core tests
ncooke3 Apr 17, 2024
2f3de81
Debug workaround one last time
ncooke3 Apr 17, 2024
7da0ca4
try printig file structure
ncooke3 Apr 17, 2024
ced882f
last attempt
ncooke3 Apr 17, 2024
97cb7f6
debug after local download
ncooke3 Apr 17, 2024
85892fa
try different approach
ncooke3 Apr 17, 2024
86de133
getting closer?
ncooke3 Apr 18, 2024
13dd16e
Revert all debugging code
ncooke3 Apr 18, 2024
4b6fa9f
Disable FST and set Xcode version for package-* jobs
ncooke3 Apr 18, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
130 changes: 62 additions & 68 deletions .github/workflows/zip.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,14 +28,14 @@ jobs:
package-release:
# Don't run on private repo.
if: (github.repository == 'Firebase/firebase-ios-sdk' && github.event_name == 'schedule') || github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch'
runs-on: macos-12
runs-on: macos-14
steps:
- uses: actions/checkout@v4
- uses: mikehardy/buildcache-action@c87cea0ccd718971d6cc39e672c4f26815b6c126
with:
cache_key: package-release
- name: Xcode 14.1
run: sudo xcode-select -s /Applications/Xcode_14.1.app/Contents/Developer
- name: Xcode 15.2
run: sudo xcode-select -s /Applications/Xcode_15.2.app/Contents/Developer
- uses: ruby/setup-ruby@v1
- name: Setup Bundler
run: ./scripts/setup_bundler.sh
Expand All @@ -54,11 +54,11 @@ jobs:
build:
# Don't run on private repo unless it is a PR.
if: (github.repository == 'Firebase/firebase-ios-sdk' && github.event_name == 'schedule') || github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch'
runs-on: macos-12
runs-on: macos-14
steps:
- uses: actions/checkout@v4
- name: Xcode 14.1
run: sudo xcode-select -s /Applications/Xcode_14.1.app/Contents/Developer
- name: Xcode 15.2
run: sudo xcode-select -s /Applications/Xcode_15.2.app/Contents/Developer
- name: Build
run: |
cd ReleaseTooling
Expand All @@ -68,14 +68,14 @@ jobs:
# Don't run on private repo.
if: (github.repository == 'Firebase/firebase-ios-sdk' && github.event_name == 'schedule') || github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch'
needs: build
runs-on: macos-12
runs-on: macos-14
steps:
- uses: actions/checkout@v4
- uses: mikehardy/buildcache-action@c87cea0ccd718971d6cc39e672c4f26815b6c126
with:
cache_key: package-head
- name: Xcode 14.1
run: sudo xcode-select -s /Applications/Xcode_14.1.app/Contents/Developer
- name: Xcode 15.2
run: sudo xcode-select -s /Applications/Xcode_15.2.app/Contents/Developer
- uses: ruby/setup-ruby@v1
- name: Setup Bundler
run: ./scripts/setup_bundler.sh
Expand Down Expand Up @@ -341,10 +341,8 @@ jobs:
SDK: "Database"
strategy:
matrix:
os: [macos-12]
include:
- os: macos-12
xcode: Xcode_14.2
os: [macos-13]
xcode: [Xcode_15.2]
# TODO: Building FirebaseUI fails on Xcode 15 because it needs to sign the resources.
# - os: macos-13
# xcode: Xcode_15.2
Expand Down Expand Up @@ -446,59 +444,55 @@ jobs:
name: quickstart_artifacts_dynamiclinks
path: quickstart-ios/

quickstart_framework_firestore:
# Don't run on private repo.
if: (github.repository == 'Firebase/firebase-ios-sdk' && github.event_name == 'schedule') || github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch'
needs: package-head
env:
plist_secret: ${{ secrets.GHASecretsGPGPassphrase1 }}
signin_secret: ${{ secrets.GHASecretsGPGPassphrase1 }}
SDK: "Firestore"
strategy:
matrix:
os: [macos-12]
include:
- os: macos-12
xcode: Xcode_14.2
# TODO: Building FirebaseUI fails on Xcode 15 because it needs to sign the resources.
# - os: macos-13
# xcode: Xcode_15.2
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v4
- name: Get framework dir
uses: actions/download-artifact@v4
with:
name: Firebase-actions-dir
- uses: ruby/setup-ruby@v1
- name: Setup Bundler
run: ./scripts/setup_bundler.sh
- name: Move frameworks
run: |
mkdir -p "${HOME}"/ios_frameworks/
find "${GITHUB_WORKSPACE}" -name "Firebase*latest.zip" -exec unzip -d "${HOME}"/ios_frameworks/ {} +
- uses: actions/checkout@v4
- name: Setup quickstart
run: SAMPLE="$SDK" TARGET="${SDK}Example" NON_FIREBASE_SDKS="SDWebImage FirebaseAuthUI FirebaseEmailAuthUI" scripts/setup_quickstart_framework.sh \
"${HOME}"/ios_frameworks/Firebase/NonFirebaseSDKs/* \
"${HOME}"/ios_frameworks/Firebase/FirebaseFirestore/* \
"${HOME}"/ios_frameworks/Firebase/FirebaseAuth/* \
"${HOME}"/ios_frameworks/Firebase/FirebaseAnalytics/*
- name: Xcode
run: sudo xcode-select -s /Applications/${{ matrix.xcode }}.app/Contents/Developer
- name: Install Secret GoogleService-Info.plist
run: scripts/decrypt_gha_secret.sh scripts/gha-encrypted/qs-firestore.plist.gpg \
quickstart-ios/firestore/GoogleService-Info.plist "$plist_secret"
- name: Test Quickstart
run: ([ -z $plist_secret ] || scripts/third_party/travis/retry.sh scripts/test_quickstart_framework.sh "${SDK}")
- name: Remove data before upload
if: ${{ failure() }}
run: scripts/remove_data.sh firestore
- uses: actions/upload-artifact@v4
if: ${{ failure() }}
with:
name: quickstart_artifacts_firestore
path: quickstart-ios/
# quickstart_framework_firestore:
# # Don't run on private repo.
# if: (github.repository == 'Firebase/firebase-ios-sdk' && github.event_name == 'schedule') || github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch'
# needs: package-head
# env:
# plist_secret: ${{ secrets.GHASecretsGPGPassphrase1 }}
# signin_secret: ${{ secrets.GHASecretsGPGPassphrase1 }}
# SDK: "Firestore"
# strategy:
# matrix:
# # TODO: Building FirebaseUI fails on Xcode 15 because it needs to sign the resources.
# os: [macos-13]
# xcode: [Xcode_15.2]
# runs-on: ${{ matrix.os }}
# steps:
# - uses: actions/checkout@v4
# - name: Get framework dir
# uses: actions/download-artifact@v4
# with:
# name: Firebase-actions-dir
# - uses: ruby/setup-ruby@v1
# - name: Setup Bundler
# run: ./scripts/setup_bundler.sh
# - name: Move frameworks
# run: |
# mkdir -p "${HOME}"/ios_frameworks/
# find "${GITHUB_WORKSPACE}" -name "Firebase*latest.zip" -exec unzip -d "${HOME}"/ios_frameworks/ {} +
# - uses: actions/checkout@v4
# - name: Setup quickstart
# run: SAMPLE="$SDK" TARGET="${SDK}Example" NON_FIREBASE_SDKS="SDWebImage FirebaseAuthUI FirebaseEmailAuthUI" scripts/setup_quickstart_framework.sh \
# "${HOME}"/ios_frameworks/Firebase/NonFirebaseSDKs/* \
# "${HOME}"/ios_frameworks/Firebase/FirebaseFirestore/* \
# "${HOME}"/ios_frameworks/Firebase/FirebaseAuth/* \
# "${HOME}"/ios_frameworks/Firebase/FirebaseAnalytics/*
# - name: Xcode
# run: sudo xcode-select -s /Applications/${{ matrix.xcode }}.app/Contents/Developer
# - name: Install Secret GoogleService-Info.plist
# run: scripts/decrypt_gha_secret.sh scripts/gha-encrypted/qs-firestore.plist.gpg \
# quickstart-ios/firestore/GoogleService-Info.plist "$plist_secret"
# - name: Test Quickstart
# run: ([ -z $plist_secret ] || scripts/third_party/travis/retry.sh scripts/test_quickstart_framework.sh "${SDK}")
# - name: Remove data before upload
# if: ${{ failure() }}
# run: scripts/remove_data.sh firestore
# - uses: actions/upload-artifact@v4
# if: ${{ failure() }}
# with:
# name: quickstart_artifacts_firestore
# path: quickstart-ios/

check_framework_firestore_symbols:
# Don't run on private repo.
Expand All @@ -508,8 +502,8 @@ jobs:
FIREBASECI_USE_LATEST_GOOGLEAPPMEASUREMENT: 1
runs-on: macos-13
steps:
- name: Xcode 14.1
run: sudo xcode-select -s /Applications/Xcode_14.1.app/Contents/Developer
- name: Xcode 15.2
run: sudo xcode-select -s /Applications/Xcode_15.2.app/Contents/Developer
- uses: actions/checkout@v4
- name: Get framework dir
uses: actions/download-artifact@v4
Expand Down
2 changes: 2 additions & 0 deletions FirebaseCore/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
# Unreleased
- [changed] Firebase now requires at least Xcode 15.2. See
https://developer.apple.com/news/?id=fxu2qp7b for more info.
- [Zip Distribution] Update zip integration instructions with tips for
preserving symlinks and protecting code signatures.

Expand Down
14 changes: 10 additions & 4 deletions ReleaseTooling/Sources/ZipBuilder/FrameworkBuilder.swift
Original file line number Diff line number Diff line change
Expand Up @@ -709,10 +709,16 @@ struct FrameworkBuilder {
.appendingPathComponent(frameworkBuildName(name) + ".xcframework")

// The arguments for the frameworks need to be separated.
var frameworkArgs: [String] = []
for frameworkBuilt in frameworks {
frameworkArgs.append("-framework")
frameworkArgs.append(frameworkBuilt.path)
let frameworkArgs = frameworks.flatMap { frameworkPath in
do {
// Xcode 15.0-15.2: Return the canonical path to work around issue
// https://forums.swift.org/t/67439
let frameworkCanonicalPath = try frameworkPath.resourceValues(forKeys: [.canonicalPathKey])
.canonicalPath!
ncooke3 marked this conversation as resolved.
Show resolved Hide resolved
return ["-framework", frameworkCanonicalPath]
} catch {
fatalError("Failed to get canonical path for \(frameworkPath): \(error)")
}
}

let outputArgs = ["-output", xcframework.path]
Expand Down
Loading