Search code examples
iosreact-nativeexpotestflight

RCTFatal+668 error in TestFlight but runs perfectly fine in Expo-Go


Currently, I have an expo-cli managed app. When I run it through the Expo Go app on the simulator or my actual phone, it works perfectly, but when I build it through eas build and submit it to TestFlight, it crashes upon clicking a button. It says that the error is an RCTFatal+668 and -[RCTExceptionsManager reportFatal:stack:exceptionId:extraDataAsJSON:]. Here is an attachment of what it says (the app name is blurred for privacy reasons): Click Here to View the XCode error statements

Also, when I add AsyncStorage.clear() in the code and run the expo-cli app through Expo-Go app, it says that there is something related to the AsyncStorage and RCTAsyncLocalStorage in the terminal (at least I think that's what it's saying). Here is the picture of the log in the terminal (I blurred some of the lines in the terminal for privacy reasons): Click Here to View the Terminal Image.

Are these in any way related? And how can I solve the first issue so that when I deploy my app to TestFlight, it doesn't crash? I've read other articles that mention the stack navigator, so I think it might have to do with that as well.

Here is my package.json:

{
  "name": "{not here for privacy reasons}",
  "version": "1.0.0",
  "main": "node_modules/expo/AppEntry.js",
  "scripts": {
    "start": "expo start",
    "android": "expo start --android",
    "ios": "expo start --ios",
    "web": "expo start --web",
    "postinstall": "patch-package"
  },
  "dependencies": {
    "@react-native-async-storage/async-storage": "~1.17.3",
    "@react-native-picker/picker": "^2.4.2",
    "@react-navigation/bottom-tabs": "^6.4.0",
    "@react-navigation/native": "^6.0.13",
    "@react-navigation/native-stack": "^6.9.1",
    "deprecated-react-native-prop-types": "^2.3.0",
    "eas": "^0.1.0",
    "expo": "~46.0.16",
    "expo-status-bar": "~1.4.0",
    "patch-package": "^6.4.7",
    "react": "18.0.0",
    "react-native": "0.69.6",
    "react-native-flat-button": "^1.0.6",
    "react-native-safe-area-context": "4.3.1",
    "react-native-screens": "~3.15.0",
    "react-native-swipeable": "^0.6.0",
    "react-native-swipeout": "^2.3.6",
    "skyward-rest": "^1.0.1"
  },
  "devDependencies": {
    "@babel/core": "^7.12.9"
  },
  "private": true
}


Solution

  • I have figured it out. I had edited skyward-rest in the node_modules folder because that is where it was downloaded. However, EAS build also runs npm install, resetting all of my changed to the skyward-rest dependency. To solve the problem, I moved the skyward-rest dependency out of the node_modules folder.