-
Notifications
You must be signed in to change notification settings - Fork 88
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
Too long chain of profile extensions, make sure "extends" keys do not make a cycle
#2793
Comments
Thank you for filing this issue! |
# Why https://linear.app/expo/issue/ENG-14636/allow-longer-profile-extend-chains-in-easjson expo/eas-cli#2793 A user complained that the max profile extension chain length is different for build and submit profiles, and for neither the limit is mentioned in the docs Companion to: expo/eas-cli#2831 # How Updated the maximal length of extension chain for submit profile to 5, which makes it the same as for build profiles. Updated the docs regarding the max length of the profile extension chain. # Test Plan Tested manually Build Profile | Before | After | | - | - | | <img width="1104" alt="Screenshot 2025-01-21 at 14 51 35" src="https://github.com/user-attachments/assets/7a14f4b6-268c-4b39-aea0-7a2b0eff26ce" /> | <img width="1104" alt="Screenshot 2025-01-21 at 14 50 50" src="https://github.com/user-attachments/assets/6c784725-2874-4389-ad39-54da0fc399fe" /> | Submit Profile | Before | After | | - | - | | <img width="1104" alt="Screenshot 2025-01-21 at 14 51 46" src="https://github.com/user-attachments/assets/0b03326b-5e35-4bef-b2f7-239285c342b4" /> | <img width="1104" alt="Screenshot 2025-01-21 at 14 51 16" src="https://github.com/user-attachments/assets/2c7aa570-1299-40da-aa98-3f57f82f4590" /> | # Checklist <!-- Please check the appropriate items below if they apply to your diff. --> - [x] I added a `changelog.md` entry and rebuilt the package sources according to [this short guide](https://github.com/expo/expo/blob/main/CONTRIBUTING.md#-before-submitting) - [x] This diff will work correctly for `npx expo prebuild` & EAS Build (eg: updated a module plugin). - [x] Conforms with the [Documentation Writing Style Guide](https://github.com/expo/expo/blob/main/guides/Expo%20Documentation%20Writing%20Style%20Guide.md)
Hi @cunneen |
Build/Submit details page URL
No response
Summary
The expo docs for EAS submit and EAS build both seem to encourage using the
"extends"
keyword ineas.json
to share configuration, which would indeed be useful.It looks like EAS build has a maximum "extends" depth of 5, which seems adequate but should really be mentioned in the docs.
EAS submit, on the other hand, has a maximum "extends" depth of 2, which throws an error even for my simple case, especially when one considers that:
Too long chain of profile extensions, make sure "extends" keys do not make a cycle
My eas.json file:
Managed or bare?
managed
Environment
expo-env-info 1.2.1 environment info:
System:
OS: macOS 14.5
Shell: 5.9 - /bin/zsh
Binaries:
Node: 18.18.2 - ~/.nvm/versions/node/v18.18.2/bin/node
Yarn: 1.22.22 - ~/.nvm/versions/node/v18.18.2/bin/yarn
npm: 9.8.1 - ~/.nvm/versions/node/v18.18.2/bin/npm
Watchman: 2024.12.02.00 - /opt/homebrew/bin/watchman
Managers:
CocoaPods: 1.15.2 - /Users/mikecunneen/.rvm/gems/ruby-3.3.5/bin/pod
SDKs:
iOS SDK:
Platforms: DriverKit 24.2, iOS 18.2, macOS 15.2, tvOS 18.2, visionOS 2.2, watchOS 11.2
Android SDK:
API Levels: 34, 35
Build Tools: 34.0.0, 35.0.0
System Images: android-34 | Google Play ARM 64 v8a
IDEs:
Android Studio: 2024.1 AI-241.18034.62.2412.12266719
Xcode: 16.2/16C5032a - /usr/bin/xcodebuild
npmPackages:
expo: ~51.0.39 => 51.0.39
react: 18.2.0 => 18.2.0
react-dom: 18.2.0 => 18.2.0
react-native: 0.74.5 => 0.74.5
react-native-web: ~0.19.6 => 0.19.12
npmGlobalPackages:
eas-cli: 14.2.0
Expo Workflow: managed
npx expo-doctor
✔ Check package.json for common issues
✔ Check Expo config for common issues
✔ Check native tooling versions
✔ Check if the project meets version requirements for submission to app stores
✔ Check for common project setup issues
✔ Check dependencies for packages that should not be installed directly
✔ Check for app config fields that may not be synced in a non-CNG project
✔ Check for issues with Metro config
✔ Check npm/ yarn versions
✔ Check Expo config (app.json/ app.config.js) schema
✔ Check for legacy global CLI installed locally
✔ Check that native modules do not use incompatible support packages
✔ Check that packages match versions required by installed Expo SDK
✔ Check that native modules use compatible support package versions for installed Expo SDK
Didn't find any issues with the project!
Error output
I don't want to use up my EAS build and submit credits, but it should be easily reproducible with my
eas.json
above when EAS Build is run with thepreview:testflight
profile and--auto-submit
, i.e.:eas build --profile preview:testflight --auto-submit
Here's a (redacted) transcript of my session. Incidentally, the
build
succeeded despite the error but obviously thesubmit
did not work.OUTPUT
Reproducible demo or steps to reproduce from a blank project
See above.
Footnotes
EAS Build > Automate Submissions > Selecting a Submission Profile (https://docs.expo.dev/build/automate-submissions/#selecting-a-submission-profile) ↩
The text was updated successfully, but these errors were encountered: