728x90
아래 스크립트에서 “Process completed with exit code 65.” 발생
name: iOS Build Test
on:
push:
branches: [ "development" ]
pull_request:
branches: [ "development" ]
jobs:
build:
name: Build and analyse default scheme using xcodebuild command
runs-on: macos-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set Default Scheme
run: |
scheme_list=$(xcodebuild -list -json | tr -d "\n")
default=$(echo $scheme_list | ruby -e "require 'json'; puts JSON.parse(STDIN.gets)['project']['targets'][0]")
echo $default | cat >default
echo Using default scheme: $default
- name: Build
env:
scheme: ${{ 'default' }}
run: |
if [ $scheme = default ]; then scheme=$(cat default); fi
if [ "`ls -A | grep -i \\.xcworkspace\$`" ]; then filetype_parameter="workspace" && file_to_build="`ls -A | grep -i \\.xcworkspace\$`"; else filetype_parameter="project" && file_to_build="`ls -A | grep -i \\.xcodeproj\$`"; fi
file_to_build=`echo $file_to_build | awk '{$1=$1;print}'`
xcodebuild clean build analyze -scheme "$scheme" -destination "platform=iphonesimulator,OS=18.0,name=iPhone 15 Pro" -"$filetype_parameter" "$file_to_build" | xcpretty && exit ${PIPESTATUS[0]}
맥 OS 업데이트되면서 발생한 버그인 줄 알고 맥 OS 버전을 특정 버전 명시로 변경
name: iOS Build Test
on:
push:
branches: [ "development" ]
pull_request:
branches: [ "development" ]
jobs:
build:
name: Build and analyse default scheme using xcodebuild command
runs-on: macos-15
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set Default Scheme
run: |
scheme_list=$(xcodebuild -list -json | tr -d "\n")
default=$(echo $scheme_list | ruby -e "require 'json'; puts JSON.parse(STDIN.gets)['project']['targets'][0]")
echo $default | cat >default
echo Using default scheme: $default
- name: Build
env:
scheme: ${{ 'default' }}
run: |
if [ $scheme = default ]; then scheme=$(cat default); fi
if [ "`ls -A | grep -i \\.xcworkspace\$`" ]; then filetype_parameter="workspace" && file_to_build="`ls -A | grep -i \\.xcworkspace\$`"; else filetype_parameter="project" && file_to_build="`ls -A | grep -i \\.xcodeproj\$`"; fi
file_to_build=`echo $file_to_build | awk '{$1=$1;print}'`
xcodebuild clean build analyze -scheme "$scheme" -destination "platform=iphonesimulator,OS=18.0,name=iPhone 15 Pro" -"$filetype_parameter" "$file_to_build" | xcpretty && exit ${PIPESTATUS[0]}
그 결과 “Process completed with exit code 65.” → “Process completed with exit code 70.”
아래 로그로 인해, 적합한 destination을 찾지 못한 것으로 추정 → 로그 중 다른 destination으로 변경
xcodebuild: error: Unable to find a device matching the provided destination specifier:
{ platform:iOS Simulator, OS:18.0, name:iPhone 15 Pro }
The requested device could not be found because no available devices matched the request.
해결
name: iOS Build Test
on:
push:
branches: [ "development" ]
pull_request:
branches: [ "development" ]
jobs:
build:
name: Build and analyse default scheme using xcodebuild command
runs-on: macos-15
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set Default Scheme
run: |
scheme_list=$(xcodebuild -list -json | tr -d "\n")
default=$(echo $scheme_list | ruby -e "require 'json'; puts JSON.parse(STDIN.gets)['project']['targets'][0]")
echo $default | cat >default
echo Using default scheme: $default
- name: Build
env:
scheme: ${{ 'default' }}
run: |
if [ $scheme = default ]; then scheme=$(cat default); fi
if [ "`ls -A | grep -i \\.xcworkspace\$`" ]; then filetype_parameter="workspace" && file_to_build="`ls -A | grep -i \\.xcworkspace\$`"; else filetype_parameter="project" && file_to_build="`ls -A | grep -i \\.xcodeproj\$`"; fi
file_to_build=`echo $file_to_build | awk '{$1=$1;print}'`
xcodebuild clean build analyze -scheme "$scheme" -destination "platform=iOS Simulator,OS=18.0,name=iPhone 15 Pro" -"$filetype_parameter" "$file_to_build" | xcpretty && exit ${PIPESTATUS[0]}
나중에 비슷한 일이 또 발생했을 때 대응하기 쉽게 로그 기능 추가해서 에러 핸들링 마무리
name: iOS Build Test
on:
push:
branches: [ "development" ]
pull_request:
branches: [ "development" ]
jobs:
build:
name: Build and analyse default scheme using xcodebuild command
runs-on: macos-15
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set Default Scheme
run: |
scheme_list=$(xcodebuild -list -json | tr -d "\n")
default=$(echo $scheme_list | ruby -e "require 'json'; puts JSON.parse(STDIN.gets)['project']['targets'][0]")
echo $default > default
echo "Using default scheme: $default"
- name: Build
env:
scheme: ${{ 'default' }}
run: |
set -o pipefail
# Determine scheme
if [ "$scheme" = "default" ]; then scheme=$(cat default); fi
# Determine project or workspace
if [ "$(ls -A | grep -i \.xcworkspace$)" ]; then
filetype_parameter="workspace"
file_to_build="$(ls -A | grep -i \.xcworkspace$)"
else
filetype_parameter="project"
file_to_build="$(ls -A | grep -i \.xcodeproj$)"
fi
file_to_build=$(echo "$file_to_build" | awk '{$1=$1;print}')
echo "Building $filetype_parameter: $file_to_build with scheme: $scheme" | tee build.log
xcodebuild clean build analyze \
-scheme "$scheme" \
-destination "platform=iOS Simulator,OS=18.0,name=iPhone 16" \
-"$filetype_parameter" "$file_to_build" \
-resultBundlePath ./ResultBundle \
| tee -a build.log \
| xcpretty
BUILD_EXIT_CODE=${PIPESTATUS[0]}
# 압축 로그 및 결과 번들
zip -r ResultBundle.zip ResultBundle
zip -r build-log.zip build.log
exit $BUILD_EXIT_CODE
- name: Upload Build Log
if: always()
uses: actions/upload-artifact@v4
with:
name: build-log
path: build-log.zip
- name: Upload Result Bundle
if: always()
uses: actions/upload-artifact@v4
with:
name: result-bundle
path: ResultBundle.zip
마무리
- 액션에서 fail 날 때 → 에러 원인을 찾을 수 없으면 커맨드로 실행해서 분석
- 커맨드로 분석할 때 → result 창에서 원인 분석 가능
728x90
'Error Handling' 카테고리의 다른 글
Tuist Plist 설정하는 방법 (0) | 2025.06.12 |
---|---|
Tuist Font & 이미지 미적용 문제 (0) | 2025.06.12 |
Reference to invalid associated type 'Entry' of type 'ShortCutProvider' (0) | 2025.02.22 |
This bundle is invalid. Apple is not currently accepting applications built with this version of Xcode. (0) | 2024.12.13 |
expected — waiting for status to be reported github actions (0) | 2023.12.02 |