본문 바로가기
Error Handling

GitHub Actions 빌드 에러 65

by songmoro 2025. 6. 12.
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