Unverified Commit c4ef0723 authored by Todd Volkert's avatar Todd Volkert Committed by GitHub

Cocoapods ffi error can be in stdout or stderr (#121470)

Cocoapods ffi error can be in stdout or stderr
parent 2c3fa082
...@@ -361,7 +361,7 @@ class CocoaPods { ...@@ -361,7 +361,7 @@ class CocoaPods {
' pod repo update\n', ' pod repo update\n',
emphasis: true, emphasis: true,
); );
} else if ((stderr.contains('ffi_c.bundle') || stderr.contains('/ffi/')) && } else if ((_isFfiX86Error(stdout) || _isFfiX86Error(stderr)) &&
_operatingSystemUtils.hostPlatform == HostPlatform.darwin_arm64) { _operatingSystemUtils.hostPlatform == HostPlatform.darwin_arm64) {
// https://github.com/flutter/flutter/issues/70796 // https://github.com/flutter/flutter/issues/70796
UsageEvent( UsageEvent(
...@@ -377,6 +377,10 @@ class CocoaPods { ...@@ -377,6 +377,10 @@ class CocoaPods {
} }
} }
bool _isFfiX86Error(String error) {
return error.contains('ffi_c.bundle') || error.contains('/ffi/');
}
void _warnIfPodfileOutOfDate(XcodeBasedProject xcodeProject) { void _warnIfPodfileOutOfDate(XcodeBasedProject xcodeProject) {
final bool isIos = xcodeProject is IosProject; final bool isIos = xcodeProject is IosProject;
if (isIos) { if (isIos) {
......
...@@ -19,6 +19,11 @@ import '../../src/common.dart'; ...@@ -19,6 +19,11 @@ import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/context.dart';
import '../../src/fake_process_manager.dart'; import '../../src/fake_process_manager.dart';
enum _StdioStream {
stdout,
stderr,
}
void main() { void main() {
late FileSystem fileSystem; late FileSystem fileSystem;
late FakeProcessManager fakeProcessManager; late FakeProcessManager fakeProcessManager;
...@@ -492,51 +497,57 @@ Note: as of CocoaPods 1.0, `pod repo update` does not happen on `pod install` by ...@@ -492,51 +497,57 @@ Note: as of CocoaPods 1.0, `pod repo update` does not happen on `pod install` by
'bus error': '/Library/Ruby/Gems/2.6.0/gems/ffi-1.15.5/lib/ffi/library.rb:275: [BUG] Bus Error at 0x000000010072c000', 'bus error': '/Library/Ruby/Gems/2.6.0/gems/ffi-1.15.5/lib/ffi/library.rb:275: [BUG] Bus Error at 0x000000010072c000',
}; };
possibleErrors.forEach((String errorName, String cocoaPodsError) { possibleErrors.forEach((String errorName, String cocoaPodsError) {
testUsingContext('ffi $errorName failure on ARM macOS prompts gem install', () async { void testToolExitsWithCocoapodsMessage(_StdioStream outputStream) {
final FlutterProject projectUnderTest = setupProjectUnderTest(); final String streamName = outputStream == _StdioStream.stdout ? 'stdout' : 'stderr';
pretendPodIsInstalled(); testUsingContext('ffi $errorName failure to $streamName on ARM macOS prompts gem install', () async {
pretendPodVersionIs('100.0.0'); final FlutterProject projectUnderTest = setupProjectUnderTest();
fileSystem.file(fileSystem.path.join('project', 'ios', 'Podfile')) pretendPodIsInstalled();
..createSync() pretendPodVersionIs('100.0.0');
..writeAsStringSync('Existing Podfile'); fileSystem.file(fileSystem.path.join('project', 'ios', 'Podfile'))
..createSync()
fakeProcessManager.addCommands(<FakeCommand>[ ..writeAsStringSync('Existing Podfile');
FakeCommand(
command: const <String>['pod', 'install', '--verbose'], fakeProcessManager.addCommands(<FakeCommand>[
workingDirectory: 'project/ios', FakeCommand(
environment: const <String, String>{ command: const <String>['pod', 'install', '--verbose'],
'COCOAPODS_DISABLE_STATS': 'true', workingDirectory: 'project/ios',
'LANG': 'en_US.UTF-8', environment: const <String, String>{
}, 'COCOAPODS_DISABLE_STATS': 'true',
exitCode: 1, 'LANG': 'en_US.UTF-8',
stderr: cocoaPodsError, },
), exitCode: 1,
const FakeCommand( stdout: outputStream == _StdioStream.stdout ? cocoaPodsError : '',
command: <String>['which', 'sysctl'], stderr: outputStream == _StdioStream.stderr ? cocoaPodsError : '',
), ),
const FakeCommand( const FakeCommand(
command: <String>['sysctl', 'hw.optional.arm64'], command: <String>['which', 'sysctl'],
stdout: 'hw.optional.arm64: 1', ),
), const FakeCommand(
]); command: <String>['sysctl', 'hw.optional.arm64'],
stdout: 'hw.optional.arm64: 1',
await expectToolExitLater( ),
cocoaPodsUnderTest.processPods( ]);
xcodeProject: projectUnderTest.ios,
buildMode: BuildMode.debug, await expectToolExitLater(
), cocoaPodsUnderTest.processPods(
equals('Error running pod install'), xcodeProject: projectUnderTest.ios,
); buildMode: BuildMode.debug,
expect( ),
logger.errorText, equals('Error running pod install'),
contains('set up CocoaPods for ARM macOS'), );
); expect(
expect( logger.errorText,
logger.errorText, contains('set up CocoaPods for ARM macOS'),
contains('enable-libffi-alloc'), );
); expect(
expect(usage.events, contains(const TestUsageEvent('pod-install-failure', 'arm-ffi'))); logger.errorText,
}); contains('enable-libffi-alloc'),
);
expect(usage.events, contains(const TestUsageEvent('pod-install-failure', 'arm-ffi')));
});
}
testToolExitsWithCocoapodsMessage(_StdioStream.stdout);
testToolExitsWithCocoapodsMessage(_StdioStream.stderr);
}); });
testUsingContext('ffi failure on x86 macOS does not prompt gem install', () async { testUsingContext('ffi failure on x86 macOS does not prompt gem install', () async {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment