Unverified Commit 098ece52 authored by Emmanuel Garcia's avatar Emmanuel Garcia Committed by GitHub

Disable warnings for the dart plugin registrant (#76561)

parent b5139515
...@@ -250,6 +250,8 @@ class KernelCompiler { ...@@ -250,6 +250,8 @@ class KernelCompiler {
mainUri, mainUri,
newMainDart, newMainDart,
mainFile, mainFile,
// TODO(egarciad): Turn this on when the plugins are fixed.
throwOnPluginPubspecError: false,
)) { )) {
mainUri = newMainDart.path; mainUri = newMainDart.path;
} }
......
...@@ -539,22 +539,24 @@ List<PluginInterfaceResolution> resolvePlatformImplementation( ...@@ -539,22 +539,24 @@ List<PluginInterfaceResolution> resolvePlatformImplementation(
if (plugin.implementsPackage == null || plugin.implementsPackage.isEmpty) { if (plugin.implementsPackage == null || plugin.implementsPackage.isEmpty) {
final String defaultImplementation = plugin.defaultPackagePlatforms[platform]; final String defaultImplementation = plugin.defaultPackagePlatforms[platform];
if (defaultImplementation == null) { if (defaultImplementation == null) {
globals.printError( if (throwOnPluginPubspecError) {
'Plugin `${plugin.name}` doesn\'t implement a plugin interface, nor sets ' globals.printError(
'a default implementation in pubspec.yaml.\n\n' 'Plugin `${plugin.name}` doesn\'t implement a plugin interface, nor sets '
'To set a default implementation, use:\n' 'a default implementation in pubspec.yaml.\n\n'
'flutter:\n' 'To set a default implementation, use:\n'
' plugin:\n' 'flutter:\n'
' platforms:\n' ' plugin:\n'
' $platform:\n' ' platforms:\n'
' $kDefaultPackage: <plugin-implementation>\n' ' $platform:\n'
'\n' ' $kDefaultPackage: <plugin-implementation>\n'
'To implement an interface, use:\n' '\n'
'flutter:\n' 'To implement an interface, use:\n'
' plugin:\n' 'flutter:\n'
' implements: <plugin-interface>' ' plugin:\n'
'\n' ' implements: <plugin-interface>'
); '\n'
);
}
didFindError = true; didFindError = true;
continue; continue;
} }
...@@ -569,12 +571,14 @@ List<PluginInterfaceResolution> resolvePlatformImplementation( ...@@ -569,12 +571,14 @@ List<PluginInterfaceResolution> resolvePlatformImplementation(
if (directDependencyResolutions.containsKey(resolutionKey)) { if (directDependencyResolutions.containsKey(resolutionKey)) {
final PluginInterfaceResolution currResolution = directDependencyResolutions[resolutionKey]; final PluginInterfaceResolution currResolution = directDependencyResolutions[resolutionKey];
if (currResolution.plugin.isDirectDependency && plugin.isDirectDependency) { if (currResolution.plugin.isDirectDependency && plugin.isDirectDependency) {
globals.printError( if (throwOnPluginPubspecError) {
'Plugin `${plugin.name}` implements an interface for `$platform`, which was already ' globals.printError(
'implemented by plugin `${currResolution.plugin.name}`.\n' 'Plugin `${plugin.name}` implements an interface for `$platform`, which was already '
'To fix this issue, remove either dependency from pubspec.yaml.' 'implemented by plugin `${currResolution.plugin.name}`.\n'
'\n\n' 'To fix this issue, remove either dependency from pubspec.yaml.'
); '\n\n'
);
}
didFindError = true; didFindError = true;
} }
if (currResolution.plugin.isDirectDependency) { if (currResolution.plugin.isDirectDependency) {
...@@ -931,19 +935,22 @@ Future<void> _writeAndroidPluginRegistrant(FlutterProject project, List<Plugin> ...@@ -931,19 +935,22 @@ Future<void> _writeAndroidPluginRegistrant(FlutterProject project, List<Plugin>
/// Returns [true] if it's necessary to create a plugin registrant, and /// Returns [true] if it's necessary to create a plugin registrant, and
/// if the new entrypoint was written to disk. /// if the new entrypoint was written to disk.
/// ///
/// This method also validates each plugin's pubspec.yaml, but errors are only
/// reported if [throwOnPluginPubspecError] is [true].
///
/// For more details, see https://flutter.dev/go/federated-plugins. /// For more details, see https://flutter.dev/go/federated-plugins.
Future<bool> generateMainDartWithPluginRegistrant( Future<bool> generateMainDartWithPluginRegistrant(
FlutterProject rootProject, FlutterProject rootProject,
PackageConfig packageConfig, PackageConfig packageConfig,
String currentMainUri, String currentMainUri,
File newMainDart, File newMainDart,
File mainFile, File mainFile, {
) async { bool throwOnPluginPubspecError,
}) async {
final List<Plugin> plugins = await findPlugins(rootProject); final List<Plugin> plugins = await findPlugins(rootProject);
final List<PluginInterfaceResolution> resolutions = resolvePlatformImplementation( final List<PluginInterfaceResolution> resolutions = resolvePlatformImplementation(
plugins, plugins,
// TODO(egarciad): Turn this on after fixing the pubspec.yaml of the plugins used in tests. throwOnPluginPubspecError: throwOnPluginPubspecError,
throwOnPluginPubspecError: false,
); );
final LanguageVersion entrypointVersion = determineLanguageVersion( final LanguageVersion entrypointVersion = determineLanguageVersion(
mainFile, mainFile,
......
...@@ -1915,6 +1915,7 @@ void main() { ...@@ -1915,6 +1915,7 @@ void main() {
'package:app/main.dart', 'package:app/main.dart',
flutterBuild, flutterBuild,
mainFile, mainFile,
throwOnPluginPubspecError: true,
); );
expect(didGenerate, isTrue); expect(didGenerate, isTrue);
expect(flutterBuild.readAsStringSync(), expect(flutterBuild.readAsStringSync(),
...@@ -2000,6 +2001,7 @@ void main() { ...@@ -2000,6 +2001,7 @@ void main() {
'package:app/main.dart', 'package:app/main.dart',
flutterBuild, flutterBuild,
mainFile, mainFile,
throwOnPluginPubspecError: true,
), throwsToolExit(message: ), throwsToolExit(message:
'Invalid plugin specification url_launcher_macos.\n' 'Invalid plugin specification url_launcher_macos.\n'
'Invalid "macos" plugin specification.' 'Invalid "macos" plugin specification.'
...@@ -2055,6 +2057,7 @@ void main() { ...@@ -2055,6 +2057,7 @@ void main() {
'package:app/main.dart', 'package:app/main.dart',
flutterBuild, flutterBuild,
mainFile, mainFile,
throwOnPluginPubspecError: true,
), throwsToolExit(message: ), throwsToolExit(message:
'Invalid plugin specification url_launcher_macos.\n' 'Invalid plugin specification url_launcher_macos.\n'
'Cannot find the `flutter.plugin.platforms` key in the `pubspec.yaml` file. ' 'Cannot find the `flutter.plugin.platforms` key in the `pubspec.yaml` file. '
...@@ -2066,6 +2069,35 @@ void main() { ...@@ -2066,6 +2069,35 @@ void main() {
FileSystem: () => fs, FileSystem: () => fs,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
}); });
testUsingContext('Does not show error messages if throwOnPluginPubspecError is false', () async {
final FileSystem fs = MemoryFileSystem();
final Set<String> directDependencies = <String>{
'url_launcher_windows',
};
resolvePlatformImplementation(<Plugin>[
Plugin.fromYaml(
'url_launcher_windows',
'',
YamlMap.wrap(<String, dynamic>{
'platforms': <String, dynamic>{
'windows': <String, dynamic>{
'dartPluginClass': 'UrlLauncherPluginWindows',
},
},
}),
<String>[],
fileSystem: fs,
appDependencies: directDependencies,
),
],
throwOnPluginPubspecError: false,
);
expect(testLogger.errorText, '');
}, overrides: <Type, Generator>{
FileSystem: () => fs,
ProcessManager: () => FakeProcessManager.any(),
});
}); });
group('pubspec', () { group('pubspec', () {
......
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