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

eas build --local fails when using a Yarn 4 monorepo and Corepack #2679

Open
FezVrasta opened this issue Nov 8, 2024 · 3 comments
Open

eas build --local fails when using a Yarn 4 monorepo and Corepack #2679

FezVrasta opened this issue Nov 8, 2024 · 3 comments
Labels
needs review Issue is ready to be reviewed by a maintainer

Comments

@FezVrasta
Copy link

FezVrasta commented Nov 8, 2024

Build/Submit details page URL

No response

Summary

I have a monorepo managed by Yarn 4.5.1, one of the workspaces is an Expo app.

When I run eas build --local and select Android (I can't test iOS) the build fails.

Managed or bare?

managed

Environment

  expo-env-info 1.2.0 environment info:
    System:
      OS: macOS 15.1
      Shell: 5.9 - /bin/zsh
    Binaries:
      Node: 20.11.1 - ~/.nvm/versions/node/v20.11.1/bin/node
      Yarn: 1.22.22 - ~/Developer/<redacted>/node_modules/.bin/yarn
      npm: 10.2.4 - ~/.nvm/versions/node/v20.11.1/bin/npm
      Watchman: 2024.11.04.00 - /opt/homebrew/bin/watchman
    Managers:
      CocoaPods: 1.16.2 - /opt/homebrew/bin/pod
    SDKs:
      iOS SDK:
        Platforms: DriverKit 24.1, iOS 18.1, macOS 15.1, tvOS 18.1, visionOS 2.1, watchOS 11.1
    IDEs:
      Android Studio: 2023.2 AI-232.10227.8.2321.11479570
      Xcode: 16.1/16B40 - /usr/bin/xcodebuild
    npmGlobalPackages:
      eas-cli: 10.2.2
    Expo Workflow: bare
❯ npx expo-doctor                          
Enabled experimental React Native Directory checks. Unset the EXPO_DOCTOR_ENABLE_DIRECTORY_CHECK environment variable to disable this check.
✔ Check package.json for common issues
✔ Check Expo config for common issues
✔ Check for common project setup issues
✔ Check dependencies for packages that should not be installed directly
✔ Check for issues with Metro config
✔ Check if the project meets version requirements for submission to app stores
✔ Check that packages match versions required by installed Expo SDK
✔ Check native tooling versions
✔ Check npm/ yarn versions
✖ Validate packages against React Native Directory package metadata
✔ Check for legacy global CLI installed locally
✔ Check Expo config (app.json/ app.config.js) schema
✔ Check for app config fields that may not be synced in a non-CNG project
✔ Check that native modules do not use incompatible support packages
✔ Check that native modules use compatible support package versions for installed Expo SDK

Detailed check results:

The following issues were found when validating your dependencies against React Native Directory:
Untested on New Architecture: lucide-react-native
No metadata available: @expo-google-fonts/inter, @gluestack-ui/nativewind-utils, @gluestack-ui/overlay, @gluestack-ui/toast, metro-config, shared, tailwind-merge, tailwindcss
Advice: 
- Use libraries that are actively maintained and support the New Architecture. Find alternative libraries with https://reactnative.directory.
- Add packages to expo.doctor.reactNativeDirectoryCheck.exclude in package.json to selectively skip validations, if the warning is not relevant.
- Update React Native Directory to include metadata for unknown packages. Alternatively, set expo.doctor.reactNativeDirectoryCheck.listUnknownPackages in package.json to false to skip warnings about packages with no metadata, if the warning is not relevant.

One or more checks failed, indicating possible issues with the project.
       

Error output

[INSTALL_DEPENDENCIES] We detected that 'workspaces/mobile-client' is a yarn workspace
[INSTALL_DEPENDENCIES] Running "yarn install --no-immutable --inline-builds" in /var/folders/c6/klv3h1_977v_x6t45d515kzc0000gn/T/eas-build-local-nodejs/dd198977-dd10-4281-aa47-d0676d994c2d/build directory
[INSTALL_DEPENDENCIES] yarn install v1.22.22
[INSTALL_DEPENDENCIES] error Workspaces can only be enabled in private projects.
[INSTALL_DEPENDENCIES] info Visit https://yarnpkg.com/en/docs/cli/install for documentation about this command.
[INSTALL_DEPENDENCIES] 
Error: yarn install --no-immutable --inline-builds exited with non-zero code: 1
    at ChildProcess.completionListener (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/spawn-async/build/spawnAsync.js:42:23)
    at Object.onceWrapper (node:events:633:26)
    at ChildProcess.emit (node:events:518:28)
    at maybeClose (node:internal/child_process:1105:16)
    at Socket.<anonymous> (node:internal/child_process:457:11)
    at Socket.emit (node:events:518:28)
    at Pipe.<anonymous> (node:net:337:12)
    ...
    at spawnAsync (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/spawn-async/build/spawnAsync.js:7:23)
    at spawn (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/turtle-spawn/dist/index.js:16:47)
    at installDependenciesAsync (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/build-tools/dist/common/installDependencies.js:24:50)
    at async runInstallDependenciesAsync (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/build-tools/dist/common/setup.js:148:50)
    at async /Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/build-tools/dist/common/setup.js:57:9
    at async BuildContext.runBuildPhase (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/build-tools/dist/context.js:107:28)
    at async setupAsync (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/build-tools/dist/common/setup.js:56:5)
    at async buildAsync (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/build-tools/dist/builders/android.js:41:5)
    at async runBuilderWithHooksAsync (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/build-tools/dist/builders/common.js:12:13)
    at async Object.androidBuilder (/Users/federicozivolo/.npm/_npx/203b5a3d3de594cf/node_modules/@expo/build-tools/dist/builders/android.js:26:16)

Build failed
Unknown error. See logs of the Install dependencies build phase for more information.
npx -y [email protected] eyJqb2IiOnsidHlwZSI6Im1hbmFnZWQiLCJwbGF0Zm9ybSI6ImFuZHJvaWQiLCJwcm9qZWN0Um9vdERpcmVjdG9yeSI6IndvcmtzcGFjZXMvbW9iaWxlLWNsaWVudCIsInByb2plY3RBcmNoaXZlIjp7InR5cGUiOiJQQVRIIiwicGF0aCI6Ii92YXIvZm9sZGVycy9jNi9rbHYzaDFfOTc3dl94NnQ0NWQ1MTVremMwMDAwZ24vVC9lYXMtY2xpLW5vZGVqcy8wYTQwZjJlNS01NmIwLTRiMDUtODI0YS1iM2NjMDAyZDk2OGYudGFyLmd6In0sImJ1aWxkZXJFbnZpcm9ubWVudCI6e30sImNhY2hlIjp7ImRpc2FibGVkIjpmYWxzZSwicGF0aHMiOltdLCJjbGVhciI6ZmFsc2V9LCJzZWNyZXRzIjp7ImJ1aWxkQ3JlZGVudGlhbHMiOnsia2V5c3RvcmUiOnsiZGF0YUJhc2U2NCI6Ii91Mys3UUFBQUFJQUFBQUJBQUFBQVFBZ09HVTRZelU0T1dNMU1qWTRaR0V5WWpjelpqazBOamd5WVRCa09EWmtORGtBQUFHVERMUkZKd0FBQlA4d2dnVDdNQXdHQ2lzR0FRUUJLZ0lSQVFFRWdnVHB5eHNYelVVUmFCYTRkR0F6VjY0dlJrOStqckFRWDZ6RE9aNnpjSTlFb05MblJ1RFNQcFhFZ0RtT3E1b3ZOejAySWlDaDdtRHpZdEhQeituL1dwOVM5eGNJdVArVkMxajh6ZXgxMC9hQUhza2o4VWdUNXVqdms5UnRGdHVMRnBCSVBUSTlDRkRiUFJGb2twOFpiUkgvaVFZcTl5bFpaT2ZlL28zV1VoakYrVS9Md1ZXMVlvV2Nxc3pvdWJyb3F6UUlNcUlQRE1hN3d5RTZ1OGRJZitVUlBSeXgwcitQeDMvY1lZWDBWV3pBc0k1NVZxdmJjdzdNVERydXhGbnQ3Tm1CQUdlUm9qSnNPTjZRdkVvaytZK3hQM0Nsb3lpRXdXUUg3V2pEbDZRdWxQOTAyenFYRE8yM05UeUo5MnNrSW9hbWNjNjYrY09BYlJFeHk1MjVxMUhwakpJWnZyUHhnTklOWDJyNzNZQUJrSlExUkVXeStyZkJLdW9LTi8zczQ1ZU9ueWhCblRFZ0hKbGJFNSt2YUNXY3NFTTRQSjVna25tR0RnRDVEZ0FmbUVNUEZ6bTdRdVZGbkgrR1BDSlR3SThsem1vYTh2cE1pSlNVelhSVDBaRlNRT0hQU0Z4bmwxeHVBOHNxcFY3bTJpMkYzYnhBNUhCZGtvVTBiNWR3TUlKN2x4N0R1OTRWdCtqd1A4Tml0U3hVa0NpWndld3RDdFR4c1ZCT1V2b1cyZFJQTUxvMnFwblM3Q3A4V3plR2E2SXhYMXpsVHN1N1RwUGRPeDBHWWVIakp2amdFN0pMNkZodWFROTN5ZEgwMDNsOHhLODBFQmJ5RWd1OEIvYTNHZFRrem11VGcvYkFJaHhwMjVIZHhNNkhTQkVvc0MrVjl2amtFQ0JXZWxTUGdsZnRLakNUcVpTelVNY01LTzk1RDg0VWk3a2JkSmN6Uk03ZkZOYkxYZGZxUHBMRUQvNEhXRnM4NkRnTUw5VGdqb2EzNUxjb2lzNkF0N2pFZTMvRkVkSDlDRGozYVIvU1ZtVkJDZW5VZWRrVmtzWWVxcnlIZEZvVy9pOWJPeTVPVDJ5MEIzb2JsL0g2RUxrdmxmay9weTh6Q3Jpbk9VclErZnB2c2NNQXVnOUEzVU9iOGJTYmNXcWZJOFJ4WTZub2NGT2E4cXdnSlE0ckp0amQ4M0RWQm1nZTVmUy91bFNPUG5xMmJ6YlZUL1dnRXJGNERLanpyYmlZSTlUZkpxcUtjbjJLeUxsYzhqQWs3WXJVWW9HM2cwY2twVXZWd2Uwcm5xQlpQQ2pYUXhHaVRnSzlkRCtHR2FxVms3dWo5cWJ3TE5iWnRWelg1dUJoOFBsNnNVNC8ybmhSanRmT1RqUkluUGlOeXo4UkJNRWdobHphTGdZQUQ0OTlxMmh5cE1HeFFWc21ObDY3UFluVmVWMlpaZzBYa2FYMHkrUytPbndYeWxVNXZWVGhpS3YyUnJnNHdyb0ppRTU0Y1BsMWNMc051cm1aclBSQy9rYkZJOE9PY3VwMmV2bFNQKzBiSVFLdmR3djlrSzMvYlprNmQrMERYb3VTMFZqdFhhd0NKS2lseTJhVE1TeHlVMVdHSWN6by9wVjlodW1tQVJMNnRBRTdsdlhYRXB6eWFwaTFNYVVXMTNidGliWHFYUHJnU3BoYzJXV3ZCSG1oWnE4SGd2WFBVbTY2cWxuejY2b1RXTW5MbEhaaWdTcFAybmVjVm5LWCtMWGxBdDBYUi9VNVdDRGNxS0lUM1Bvait1b0F0aDNzZFF0aTFaY0FCRFd0TWxoMEs1MytPWWlnRGc1b1pNd0N2aDhjOXBRd2NZeDN3R1pIbmUyUTBoeFF1aGxqN2FUcFZKak9DckVkYjdLOWZ4aTZ3NnJpL0F6SU9CSWdZanZTQ1pFa0hqVG01Z2twaFZaNit6ZkxxN2V4OHZ6MXM4VVBIRVc3U25HR2dKYUEySmhiSzVtcDlKeCtqUysvWVh0Q1QybjJHNkpEckxEcUxPemdvaTB2bWU4Yksrc0dJcnRxclBuQlRTQTNWUm9WNW1GVTJKTUhDMVNwV0d3SlNJTTl1MVErS2d0L0l3amQ2ZUtKN3N4UWI1Nmg2eUFZTEZlYmhOVWhpVVVFcFlaay9xQmo5dDlrRGM1d1N2bFJhYWxWampQamE4VzN3elJJSzJ3bUhDWGxlNFJseXNVQ0VHdFVEYSsxMGs2ZnNLNjZxUlJLb0VjREFBQUFBUUFGV0M0MU1Ea0FBQU15TUlJRExqQ0NBaGFnQXdJQkFnSUpBTzFXU2JvUzdVKy9NQTBHQ1NxR1NJYjNEUUVCREFVQU1FUXhDekFKQmdOVkJBWVRBbFZUTVFrd0J3WURWUVFJRXdBeENUQUhCZ05WQkFjVEFERUpNQWNHQTFVRUNoTUFNUWt3QndZRFZRUUxFd0F4Q1RBSEJnTlZCQU1UQURBZ0Z3MHlOREV4TURneE5qVTJNREZhR0E4eU1EVXlNRE15TmpFMk5UWXdNVm93UkRFTE1Ba0dBMVVFQmhNQ1ZWTXhDVEFIQmdOVkJBZ1RBREVKTUFjR0ExVUVCeE1BTVFrd0J3WURWUVFLRXdBeENUQUhCZ05WQkFzVEFERUpNQWNHQTFVRUF4TUFNSUlCSWpBTkJna3Foa2lHOXcwQkFRRUZBQU9DQVE4QU1JSUJDZ0tDQVFFQXV1RlJSRFl3d0Z4anREWkpGdEREc2hkKzQzbzh3ZVR5NUpYSEEzWStCWVQxVlBHSkdZd01DQ3I2aEYybEN3TjQvTVdIWGtsOHdZaUdQS3ErdldNR3ZheS9kVEVDdjd2TTNjcGJ1QzNuTk45S1lnVzdVZlYzaW80aFFyeVJ2ZENWRzl1YWgwZ2kzWTE5NGdiNTVpNEx6RHB0bC9qMmR0eWVlQnJVNm53dWRPWHo2SmFVMitvcEJJZnpnU3pJS1RoL2xNdzhCTWhpa1o2NC91TEx0c09lSHFZQnRUeG1MMmNmSncrZVp1dTc5bHF1NU1MakN0QVVYT3MxdlQvOXNDZHUyVXlLaU10dXcxT05ITFcwV0dtb0pyd3RXVkhtekwzQ1FEclg1MlhwRUN6d0hZeTY0RmxQOFlheFdZT0RCNTJ3RytJZ0dPTnJhd05lWDlDWjQ0cHJZd0lEQVFBQm95RXdIekFkQmdOVkhRNEVGZ1FVNlhlU2lIQWIwZS9JaTF3RHc3OE94V3hXK0xVd0RRWUpLb1pJaHZjTkFRRU1CUUFEZ2dFQkFGUFBSZG16bEtpVDAzK1FEWmZ6bzhPMWpIcnA0djZKazQ1enA2U1oyRjJWQkJiZzhpL09Vdnlvdkxhc3VPc1JFNnFVN3pxc3ZUYjF4dXI0SDJtS24xN2dkNCtIQ2YwcG54WE52YzFycjBRWTJzem1kVyttS2JCUEVZZTFNMFdSNExaQzEwVllGdkluYkNjRWFrL0wwWXl6ZnNrVlNKeDFERm1ja1Z0ZEsyUVBtbHFnQ3cyUExuR0NlK0NZdXpGdTJzKzlRbmplQmZRVnhQNEZrSkFqYVY0Z1Y4MXk4dE5mVTF6a2xpN2JXWmxFUFpuQ3JoYzRxQ3V2dnpDaFl3N29oS3NKQWo5bjFxS0hiM3dEaWZ2eVpubmhlRjVzUlRGYWF3bFVuZGw3Z21GZVBOaFdrd2xQSmhNNmFzbHhIejAvZFdLOURPcGF0bExmTUFLelRsVkJrL3krM2E1WDVEazUxTDdHYzRWbWMzZjVLbjJlY1E9PSIsImtleXN0b3JlUGFzc3dvcmQiOiIwZmEwNGM5NjI4YmZjOWU4MDBiYjZjMzAxY2RlY2M3YiIsImtleUFsaWFzIjoiOGU4YzU4OWM1MjY4ZGEyYjczZjk0NjgyYTBkODZkNDkiLCJrZXlQYXNzd29yZCI6IjUzZGIyMTQwNWY2M2FhZGE4MDNlZjFjYWU1Nzc0YTczIn19fSwidXBkYXRlcyI6e30sInVzZXJuYW1lIjoiZmV6dnJhc3RhIiwidmVyc2lvbiI6eyJ2ZXJzaW9uQ29kZSI6IjEifSwiZXhwZXJpbWVudGFsIjp7fSwibW9kZSI6ImJ1aWxkIiwidHJpZ2dlcmVkQnkiOiJFQVNfQ0xJIiwiYXBwSWQiOiJhMzE0OTQ1Zi02MzZiLTQwNjAtYTZkNC01MmEwMTdlMWNjYmUiLCJpbml0aWF0aW5nVXNlcklkIjoiNDFkZGJkYzUtY2Y4Zi00Njg3LTg4ZjUtZmUwZTc0ZGIwM2NjIn0sIm1ldGFkYXRhIjp7InRyYWNraW5nQ29udGV4dCI6eyJ0cmFja2luZ19pZCI6IjE4ODQzMWQ5LWRlMGQtNGM3Mi05ZDcyLTc5OWQ3YjUyMDM3MiIsInBsYXRmb3JtIjoiYW5kcm9pZCIsInNka192ZXJzaW9uIjoiNTIuMC4wIiwiYWNjb3VudF9pZCI6ImQ0NWZiOTlmLTYzNDYtNDg5NS1hNjg5LTg2YmExYzAxYzRjZCIsInByb2plY3RfaWQiOiJhMzE0OTQ1Zi02MzZiLTQwNjAtYTZkNC01MmEwMTdlMWNjYmUiLCJwcm9qZWN0X3R5cGUiOiJtYW5hZ2VkIiwiZGV2X2NsaWVudCI6ZmFsc2UsImRldl9jbGllbnRfdmVyc2lvbiI6IjQuMC4yOSIsIm5vX3dhaXQiOmZhbHNlLCJydW5fZnJvbV9jaSI6ZmFsc2UsImxvY2FsIjp0cnVlfSwiYXBwQnVpbGRWZXJzaW9uIjoiMSIsImFwcFZlcnNpb24iOiIxLjAuMCIsImNsaVZlcnNpb24iOiIxMy4xLjEiLCJ3b3JrZmxvdyI6Im1hbmFnZWQiLCJjcmVkZW50aWFsc1NvdXJjZSI6InJlbW90ZSIsInNka1ZlcnNpb24iOiI1Mi4wLjAiLCJmaW5nZXJwcmludEhhc2giOiJlNjI0NWMzNmE0ZjhiNmJmMzhiMGJhZGQ4NTUyYjI1ZWY3ZWY2ZTlhIiwiZmluZ2VycHJpbnRTb3VyY2UiOnsidHlwZSI6IlBBVEgiLCJwYXRoIjoiL3Zhci9mb2xkZXJzL2M2L2tsdjNoMV85Nzd2X3g2dDQ1ZDUxNWt6YzAwMDBnbi9UL2Vhcy1jbGktbm9kZWpzL2IyNjk0NWI1LTQ4ZGQtNDBmYS05MGE3LTA3M2NlY2RkNDQ3NC1ydW50aW1lLWZpbmdlcnByaW50Lmpzb24iLCJpc0RlYnVnRmluZ2VycHJpbnQiOmZhbHNlfSwicmVhY3ROYXRpdmVWZXJzaW9uIjoiMC43Ni4xIiwiZGlzdHJpYnV0aW9uIjoic3RvcmUiLCJhcHBOYW1lIjoiQmV0QnVja2V0IiwiYXBwSWRlbnRpZmllciI6ImNvbS5iZXRidWNrZXQuYXBwIiwiYnVpbGRQcm9maWxlIjoicHJvZHVjdGlvbiIsImdpdENvbW1pdEhhc2giOiJiZjg2YTQwNGExMjFjZTE1NmFlMGNmNDIwODE4NzdiMGVkZjViZDhmIiwiZ2l0Q29tbWl0TWVzc2FnZSI6ImxvZ2luIHdhbGwgc2NyZWVuIiwiaXNHaXRXb3JraW5nVHJlZURpcnR5Ijp0cnVlLCJ1c2VybmFtZSI6ImZlenZyYXN0YSIsInJ1bldpdGhOb1dhaXRGbGFnIjpmYWxzZSwicnVuRnJvbUNJIjpmYWxzZSwiZGV2ZWxvcG1lbnRDbGllbnQiOmZhbHNlLCJyZXF1aXJlZFBhY2thZ2VNYW5hZ2VyIjoieWFybiIsInNpbXVsYXRvciI6ZmFsc2V9fQ== exited with non-zero code: 1
    Error: build command failed.
        

Reproducible demo or steps to reproduce from a blank project

It's a bit complicated to provide a repro, to reproduce the bug create a repository, init yarn workspaces with Yarn v4, then init an Expo app in a workspace, and then run eas build --local.

I think the bug is quite obvious though, EAS is using the wrong Yarn version even though my package.json specifies the correct one and Corepack is enabled.

I noticed the same happens even if I install Yarn 4 globally, replacing Yarn 1.x. The only way around seems to be to use the internal Yarn binary loader (yarn set version) while Corepack is disabled.

@FezVrasta FezVrasta added the needs review Issue is ready to be reviewed by a maintainer label Nov 8, 2024
@FezVrasta FezVrasta changed the title eas build --local fails when using a Yarn 4 monorepo eas build --local fails when using a Yarn 4 monorepo and Corepack Nov 8, 2024
@ethanlee123
Copy link

ethanlee123 commented Nov 27, 2024

im also running into the same issue after upgrading to expo sdk 52
but it is using yarn 4.22

@devYonz
Copy link

devYonz commented Dec 2, 2024

Same issue, How do we setup up pre-build steps for eas? need to do setup yarn v4 before building.

@deeeed
Copy link

deeeed commented Dec 11, 2024

+1

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
needs review Issue is ready to be reviewed by a maintainer
Projects
None yet
Development

No branches or pull requests

4 participants