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

Able to build ios app but unable to get build settings to deplou #2383

Open
ToyboxZach opened this issue May 7, 2024 · 10 comments
Open

Able to build ios app but unable to get build settings to deplou #2383

ToyboxZach opened this issue May 7, 2024 · 10 comments

Comments

@ToyboxZach
Copy link

ToyboxZach commented May 7, 2024

Environment

System:
OS: macOS 14.4.1
CPU: (16) x64 Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz
Memory: 2.12 GB / 16.00 GB
Shell:
version: "5.9"
path: /bin/zsh
Binaries:
Node:
version: 20.10.0
path: /usr/local/bin/node
Yarn:
version: 1.22.21
path: /usr/local/bin/yarn
npm:
version: 10.7.0
path: ~/toybox/app/node_modules/.bin/npm
Watchman:
version: 2023.12.04.00
path: /usr/local/bin/watchman
Managers:
CocoaPods:
version: 1.15.2
path: /usr/local/bin/pod
SDKs:
iOS SDK:
Platforms:
- DriverKit 23.4
- iOS 17.4
- macOS 14.4
- tvOS 17.4
- visionOS 1.1
- watchOS 10.4
Android SDK:
Android NDK: 22.1.7171670
IDEs:
Android Studio: 2022.3 AI-223.8836.35.2231.10406996
Xcode:
version: 15.3/15E204a
path: /usr/bin/xcodebuild
Languages:
Java:
version: 17.0.10
path: /usr/bin/javac
Ruby:
version: 2.6.10
path: /usr/bin/ruby
npmPackages:
"@react-native-community/cli": Not Found
react: Not Found
react-native: Not Found
react-native-macos: Not Found
npmGlobalPackages:
"react-native": Not Found
Android:
hermesEnabled: true
newArchEnabled: false
iOS:
hermesEnabled: true
newArchEnabled: false

Description

I am able to consistently build the app and get good out put, but the command line tool never is able to deploy it.

I have gone into the built direct and done xcrun on my simulator so I know the generated binary is completely fine.

I dove into this package to figure out why it was unable to get the build settings and I'm able to mimic what I expect this line to be doing:

 const buildSettings = child_process.execFileSync(
    'xcodebuild',
    [
      xcodeProject.isWorkspace ? '-workspace' : '-project',
      xcodeProject.name,
      '-scheme',
      scheme,
      '-sdk',
      getPlatformName(buildOutput),
      '-configuration',
      mode,
      '-showBuildSettings',
      '-json',
    ],
    {encoding: 'utf8'},
  );
  
  xcodebuild -workspace <APPNAME>.xcworkspace -scheme <SCHEME> -sdk iphonesimulator -configuration Debug -showBuildSettings -json

And I get relatively valid results

This is the output I get:

success Successfully built the app
2024-05-07 13:06:15.701 xcodebuild[65545:562982] DVTPlugInQuery: Requested but did not find extension point with identifier 'Xcode.InterfaceBuilderBuildSupport.PlatformDefinition'. This is programmer error; code should only request extension points that are defined by itself or its dependencies.
error Failed to get build settings for your project.

Reproducible Demo

I don't know how to get this down into an easily reproducible situation, but at a minimum it feels like there is a bunch of missing logging or information as the actual errors don't make any sense.

If anyone has suggestions for a fix or cause I can try to break it down further (I have done all the suggested stack overflow answers)

@szymonrybczak
Copy link
Collaborator

hey @ToyboxZach did you resolve your issue?

@ToyboxZach
Copy link
Author

Nope, and still no idea where to even go with breaking this down

@szymonrybczak
Copy link
Collaborator

@ToyboxZach that's really strange! Please make sure that version of xcodebuild in your shell matches the one that is used by Xcode, also try re-installing it to match target destination.

@ToyboxZach
Copy link
Author

Thanks, I’ll try that, the weird thing is the build is working just fine, it’s just the ability to grab the build settings that seems to be weird.

@pvev
Copy link

pvev commented Jul 1, 2024

hey @ToyboxZach @szymonrybczak were you able to solve this issue? I have tried already everything: upgrading OS, reinstalling Xcode but no luck. Also, xcodebuild used in shell matches the one used by xcode. I already run out of ideas :(

@ToyboxZach
Copy link
Author

Yes I believe all my versions match, both are 15.4

And the build is completely fine, I can even launch the binary, its explicitly failing to launch because the tool is failing to get the build settings for some reason, even though the build settings look pretty valid to me.

@chrishanthmathew91
Copy link

chrishanthmathew91 commented Aug 14, 2024

I faced the same issue and spent quite a bit of time on it. I finally narrowed it down to the following line:

let selectedTarget = targets[0];

It looks like the cli fetches all the targets that have been defined and uses the first item from the list to install the app in the simulator.

Screenshot 2024-08-14 at 23 44 44

In my case as seen in the screenshot, for some reason "React" is mentioned as a target at the top of the list. So the cli - although it builds the right target - when trying to install the build, tries to pick up this "React" build (which obviously doesn't exist). I ended up just removing the "React" target so that my scheme looks like the following:

Screenshot 2024-08-14 at 23 55 15

I would suggest you to check your scheme and ensure that the right target is mentioned at the top of the list

@pvev
Copy link

pvev commented Aug 18, 2024

it worked perfectly for me by following @chrishanthmathew91 recommendation:

  • In Xcode, go to the menu bar and select Product > Scheme > Edit Scheme....
  • In the Scheme editor, on the left-hand side, you’ll see a list of build actions (e.g., Build, Run, Test).
  • Under the Build section, select the React target and click the - button.

Thanks!

@ToyboxZach
Copy link
Author

That is not my problem, as I don't have a React target in my build section I only have my two Targets for the two different skus of my app + the Pods target

@szymonrybczak
Copy link
Collaborator

@chrishanthmathew91 @pvev btw if you have any troubles with targets selection logic you can also set it manually by specific --target option 👍

@ToyboxZach please provide more information, such as react-native version etc. Try also playing manually with xcodebuild command and with arguments there, maybe that'll help

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants