#javascript #react-native #detox
#javascript #react-native #detox
Вопрос:
Спасибо за вашу помощь. Я новичок в Detox, React Native, Mac, Xcode и публикации в StackOverflow (новая работа), извиняюсь, если я упускаю детали.
Я следую инструкциям из: https://reactnative.dev
Я запустил
npx react-native init MyTestApp
И у меня есть работающее приложение для iOS, в котором я могу запускать пакет и взаимодействовать с демонстрационным приложением. Я слабо понимаю, что происходит.
Затем я начал следовать руководству здесь:
https://reactnativetesting.io/e2e/setup.html#installing-detox
Я перехожу к разделу:
$ detox build -c ios
$ detox test -c ios
И хоть убей, я не могу заставить команду detox build -c ios работать, результат выглядит следующим образом:
clang: error: linker command failed with exit code 1 (use -v to see invocation)
warning: no rule to process file '/*****/*********/*****************/JamesReactNativeTest/ios/Pods/Flipper-RSocket/rsocket/benchmarks/CMakeLists.txt' of type 'text' for architecture 'arm64' (in target 'Flipper-RSocket' from project 'Pods')
warning: no rule to process file '/*****/*********/*****************/JamesReactNativeTest/ios/Pods/Flipper-RSocket/rsocket/benchmarks/README.md' of type 'net.daringfireball.markdown' for architecture 'arm64' (in target 'Flipper-RSocket' from project 'Pods')
warning: no rule to process file '/*****/*********/*****************/JamesReactNativeTest/ios/Pods/Flipper-RSocket/rsocket/README.md' of type 'net.daringfireball.markdown' for architecture 'arm64' (in target 'Flipper-RSocket' from project 'Pods')
warning: no rule to process file '/*****/*********/*****************/JamesReactNativeTest/ios/Pods/Flipper-RSocket/rsocket/benchmarks/CMakeLists.txt' of type 'text' for architecture 'x86_64' (in target 'Flipper-RSocket' from project 'Pods')
warning: no rule to process file '/*****/*********/*****************/JamesReactNativeTest/ios/Pods/Flipper-RSocket/rsocket/benchmarks/README.md' of type 'net.daringfireball.markdown' for architecture 'x86_64' (in target 'Flipper-RSocket' from project 'Pods')
warning: no rule to process file '/*****/*********/*****************/JamesReactNativeTest/ios/Pods/Flipper-RSocket/rsocket/README.md' of type 'net.daringfireball.markdown' for architecture 'x86_64' (in target 'Flipper-RSocket' from project 'Pods')
warning: Capabilities for Signing amp; Capabilities may not function correctly because its entitlements use a placeholder team ID. To resolve this, select a development team in the JamesReactNativeTest editor. (in target 'JamesReactNativeTest' from project 'JamesReactNativeTest')
** BUILD FAILED **
The following build commands failed:
Ld /*****/*********/*****************/JamesReactNativeTest/ios/build/Build/Intermediates.noindex/JamesReactNativeTest.build/Debug-iphonesimulator/JamesReactNativeTest.build/Objects-normal/arm64/Binary/JamesReactNativeTest normal arm64
(1 failure)
Что меня очень смущает, так это то, что my .detoxrc.json, похоже, имеет правильный двоичный путь, потому что, когда я запускаю эту команду через терминал, она работает, я (возможно, ошибочно) предполагаю, что Detox вносит изменения в эту команду, чтобы она завершилась неудачей? Я читал, что ваш package.json считывается detox build, но команда там для iOS тоже работает.
Я делаю что-то очень глупое, но я запутался и не вижу ответа. Извиняюсь, если подобный вопрос уже существует, я ничего не мог связать с моей проблемой. Еще раз приветствую любую помощь, которую вы можете предложить.
detoxrc.json
{
"testRunner": "jest",
"runnerConfig": "e2e/config.json",
"configurations": {
"ios": {
"type": "ios.simulator",
"binaryPath": "ios/build/Build/Products/Debug-iphonesimulator/JamesReactNativeTest.app",
"build": "xcodebuild -workspace ios/JamesReactNativeTest.xcworkspace -scheme JamesReactNativeTest -configuration Debug -sdk iphonesimulator -derivedDataPath ios/build",
"device": {
"type": "iPhone 11"
}
},
"android": {
"type": "android.emulator",
"binaryPath": "SPECIFY_PATH_TO_YOUR_APP_BINARY",
"device": {
"avdName": "Pixel_2_API_29"
}
}
}
}
package.json
{
"name": "JamesReactNativeTest",
"version": "0.0.1",
"private": true,
"scripts": {
"android": "react-native run-android",
"ios": "react-native run-ios",
"start": "react-native start",
"test": "jest",
"lint": "eslint ."
},
"dependencies": {
"react": "16.13.1",
"react-native": "0.63.4",
"react-native-macos": "^0.63.0-0"
},
"devDependencies": {
"@babel/core": "^7.12.10",
"@babel/runtime": "^7.12.5",
"@react-native-community/eslint-config": "^2.0.0",
"babel-jest": "^26.6.3",
"detox": "^18.2.2",
"eslint": "^7.17.0",
"eslint-plugin-detox": "^1.0.0",
"jest": "^26.6.3",
"jest-circus": "^26.6.3",
"metro-react-native-babel-preset": "^0.64.0",
"react-test-renderer": "16.13.1"
},
"jest": {
"preset": "react-native"
}
}
Ответ №1:
Пришлось добавить «-UseModernBuildSystem = YES -arch x86_64» к шагу сборки для разрешения.
Комментарии:
1. Чувак, ты только что спас меня из глубокой ямы, в которой я был уже несколько дней. Спасибо! Это помогло мне запустить мою сборку detox на M1.