Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Ionic iOS build fails, error archive not found

I have an Ionic project. Running via ionic serve gives me the result I expect, no problem there.

However, when running a command like ionic cordova run ios -lc, I receive an error breaking the build process. The error I receive is the following:

[cordova]  error: archive not found at path '/Users/path-to-app/platforms/ios/demoapp.xcarchive
[cordova]  ** EXPORT FAILED **
[cordova]
[cordova]  (node:5866) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): Error code 65 for command: xcodebuild with args: -exportArchive,-archivePath,demoapp.xcarchive,-exportOptionsPlist,/Users/path-to-app/platforms/ios/exportOptions.plist,-exportPath,/Users/path-to-app/platforms/ios/build/device
[cordova]  (node:5866) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.`

I see two different errors here: archive not found and a deprecation problem.

I don't know which one is breaking the build, but I can't seem to find a solution for either one of them.

Ionic information:

Ionic:

   ionic (Ionic CLI)  : 4.1.2
   Ionic Framework    : ionic-angular 3.9.2
   @ionic/app-scripts : 3.2.0

Cordova:

   cordova (Cordova CLI) : 8.0.0
   Cordova Platforms     : android 7.0.0, browser 5.0.4, ios 4.5.5
   Cordova Plugins       : no whitelisted plugins (0 plugins total)

System:

   Android SDK Tools : 25.1.7 (/Users/Vincent/Library/Android/sdk)
   ios-deploy        : 1.9.2
   NodeJS            : v9.1.0 (/usr/local/bin/node)
   npm               : 6.4.1
   OS                : macOS High Sierra
   Xcode             : Xcode 10.0 Build version 10A255
like image 493
Vincent Avatar asked Sep 18 '18 11:09

Vincent


5 Answers

Currently cordova-ios is not compatible with Xcode 10

You can try to disable the new build system that Xcode 10 uses and use the old one by adding this to your build.json file

"buildFlag": [
  "-UseModernBuildSystem=0"
]

or adding --buildFlag="-UseModernBuildSystem=0" to the build command

The full command should be cordova build ios --buildFlag="-UseModernBuildSystem=0".

Or for Ionic ionic cordova build ios -- --buildFlag="-UseModernBuildSystem=0"

like image 80
jcesarmobile Avatar answered Nov 17 '22 09:11

jcesarmobile


In addition to the answer given by jcesarmobile, another solution is to build the app with the Ionic CLI by executing the following command:

ionic cordova build ios -- --buildFlag="-UseModernBuildSystem=0"

According to the documentation of the ionic build command, to pass additional options to the Cordova CLI, you should use the -- separator after the Ionic CLI arguments. The execution of the build command through Ionic CLI instead of Cordova CLI will also build web assets and provide friendly checks before Cordova merely builds the app.

like image 36
AlexGpeppe Avatar answered Nov 17 '22 09:11

AlexGpeppe


An example for a working build.json file (to place into your Cordova / Ionic project root directory) is the following content:

 {
  "ios": {
    "debug": {
      "buildFlag": [
        "-UseModernBuildSystem=0"
      ]
    },
    "release": {
      "buildFlag": [
        "-UseModernBuildSystem=0"
      ]
    }
  }
}

For more parameters about file build.json, see also the Cordova documentation: iOS Platform Guide

like image 20
dgbt Avatar answered Nov 17 '22 09:11

dgbt


The command suggested by jcesarmobile didn't work for me, but doing

cordova build ios --buildFlag="-UseModernBuildSystem=0"

(without ionic) succesfully completed the build.

After that I've been able to do ionic cordova build ios without any problems. (even without the buildFlag). I'm not an expert in this, in fact it was a mistake not to include ionic lol. So, although everything seems to work ok i'm not sure if there are any drawbacks in building with only cordova for the first time. Maybe someone can throw some light in the comments

like image 1
nahuelarjonadev Avatar answered Nov 17 '22 07:11

nahuelarjonadev


A couple of pitfalls: Preparing the Xcode file.

It’s time to prepare the project to be opened in Xcode. However, Ionic-Cordova doesn’t support the new build system of Xcode. So the project has to be prepared for the legacy build system. Pitfall #2.

Important! Disconnect your iPhone or iPad device connected to the Mac or the following command won’t work!!! Pitfall #3.

ionic cordova build ios --prod --buildFlag='-UseModernBuildSystem=0'

Congratulations! Your MyApp.xcodeproj (etc.) file is ready. You’re almost half way to have an IPA uploaded. Just double click on the Myapp.xcodeproj file or open it through Xcode.

Picture showing Xcode

There are several other pitfalls you will find:

  • It’s a common pitfall #4 to not have the proper privilege set. In particular the rol “Developer” (pitfall #4.1) doesn’t have privileges to push apps to the Store
  • Double check that the “Bundle Identifier” is exactly the one you set in the config.xml file!
  • Xcode exposes a signing bug, pitfall #5, so untick the “Automatically manage signing” and tick again. You will face this bug for sure.

Xcode bugs and Cordova not supporting properly the new building system leads to all these issues. I made a full guide showing how to fix them after lurking hours.

like image 1
Victor Martinez Calvo Avatar answered Nov 17 '22 09:11

Victor Martinez Calvo