mirror of
https://github.com/flutter/packages.git
synced 2025-05-26 01:41:08 +08:00

Removes the legacy analysis options override and fixes all resulting issues. This is a combination of dart fix and manual changes (mostly mechanical, but some small restructuring to address warnings more cleanly, such as creating typed structs from args when they are used repeatedly to avoid repeated casting, or making things that were unnecessarily public private). One small opportunistic extra cleanup is that the handling of null-safety prerelease versions is removed, as any new plugin would be written null-safe from the start, so we no longer need to allow those versions. Part of flutter/flutter#76229
164 lines
4.8 KiB
Dart
164 lines
4.8 KiB
Dart
// Copyright 2013 The Flutter Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import 'package:args/command_runner.dart';
|
|
import 'package:file/file.dart';
|
|
import 'package:flutter_plugin_tools/src/test_command.dart';
|
|
import 'package:test/test.dart';
|
|
|
|
import 'util.dart';
|
|
|
|
void main() {
|
|
group('$TestCommand', () {
|
|
CommandRunner<void> runner;
|
|
final RecordingProcessRunner processRunner = RecordingProcessRunner();
|
|
|
|
setUp(() {
|
|
initializeFakePackages();
|
|
final TestCommand command = TestCommand(mockPackagesDir, mockFileSystem,
|
|
processRunner: processRunner);
|
|
|
|
runner = CommandRunner<void>('test_test', 'Test for $TestCommand');
|
|
runner.addCommand(command);
|
|
});
|
|
|
|
tearDown(() {
|
|
cleanupPackages();
|
|
processRunner.recordedCalls.clear();
|
|
});
|
|
|
|
test('runs flutter test on each plugin', () async {
|
|
final Directory plugin1Dir =
|
|
createFakePlugin('plugin1', withExtraFiles: <List<String>>[
|
|
<String>['test', 'empty_test.dart'],
|
|
]);
|
|
final Directory plugin2Dir =
|
|
createFakePlugin('plugin2', withExtraFiles: <List<String>>[
|
|
<String>['test', 'empty_test.dart'],
|
|
]);
|
|
|
|
await runner.run(<String>['test']);
|
|
|
|
expect(
|
|
processRunner.recordedCalls,
|
|
orderedEquals(<ProcessCall>[
|
|
ProcessCall(
|
|
'flutter', const <String>['test', '--color'], plugin1Dir.path),
|
|
ProcessCall(
|
|
'flutter', const <String>['test', '--color'], plugin2Dir.path),
|
|
]),
|
|
);
|
|
|
|
cleanupPackages();
|
|
});
|
|
|
|
test('skips testing plugins without test directory', () async {
|
|
createFakePlugin('plugin1');
|
|
final Directory plugin2Dir =
|
|
createFakePlugin('plugin2', withExtraFiles: <List<String>>[
|
|
<String>['test', 'empty_test.dart'],
|
|
]);
|
|
|
|
await runner.run(<String>['test']);
|
|
|
|
expect(
|
|
processRunner.recordedCalls,
|
|
orderedEquals(<ProcessCall>[
|
|
ProcessCall(
|
|
'flutter', const <String>['test', '--color'], plugin2Dir.path),
|
|
]),
|
|
);
|
|
|
|
cleanupPackages();
|
|
});
|
|
|
|
test('runs pub run test on non-Flutter packages', () async {
|
|
final Directory plugin1Dir = createFakePlugin('plugin1',
|
|
isFlutter: true,
|
|
withExtraFiles: <List<String>>[
|
|
<String>['test', 'empty_test.dart'],
|
|
]);
|
|
final Directory plugin2Dir = createFakePlugin('plugin2',
|
|
isFlutter: false,
|
|
withExtraFiles: <List<String>>[
|
|
<String>['test', 'empty_test.dart'],
|
|
]);
|
|
|
|
await runner.run(<String>['test', '--enable-experiment=exp1']);
|
|
|
|
expect(
|
|
processRunner.recordedCalls,
|
|
orderedEquals(<ProcessCall>[
|
|
ProcessCall(
|
|
'flutter',
|
|
const <String>['test', '--color', '--enable-experiment=exp1'],
|
|
plugin1Dir.path),
|
|
ProcessCall('pub', const <String>['get'], plugin2Dir.path),
|
|
ProcessCall(
|
|
'pub',
|
|
const <String>['run', '--enable-experiment=exp1', 'test'],
|
|
plugin2Dir.path),
|
|
]),
|
|
);
|
|
|
|
cleanupPackages();
|
|
});
|
|
|
|
test('runs on Chrome for web plugins', () async {
|
|
final Directory pluginDir = createFakePlugin(
|
|
'plugin',
|
|
withExtraFiles: <List<String>>[
|
|
<String>['test', 'empty_test.dart'],
|
|
],
|
|
isFlutter: true,
|
|
isWebPlugin: true,
|
|
);
|
|
|
|
await runner.run(<String>['test']);
|
|
|
|
expect(
|
|
processRunner.recordedCalls,
|
|
orderedEquals(<ProcessCall>[
|
|
ProcessCall(
|
|
'flutter',
|
|
const <String>['test', '--color', '--platform=chrome'],
|
|
pluginDir.path),
|
|
]),
|
|
);
|
|
});
|
|
|
|
test('enable-experiment flag', () async {
|
|
final Directory plugin1Dir = createFakePlugin('plugin1',
|
|
isFlutter: true,
|
|
withExtraFiles: <List<String>>[
|
|
<String>['test', 'empty_test.dart'],
|
|
]);
|
|
final Directory plugin2Dir = createFakePlugin('plugin2',
|
|
isFlutter: false,
|
|
withExtraFiles: <List<String>>[
|
|
<String>['test', 'empty_test.dart'],
|
|
]);
|
|
|
|
await runner.run(<String>['test', '--enable-experiment=exp1']);
|
|
|
|
expect(
|
|
processRunner.recordedCalls,
|
|
orderedEquals(<ProcessCall>[
|
|
ProcessCall(
|
|
'flutter',
|
|
const <String>['test', '--color', '--enable-experiment=exp1'],
|
|
plugin1Dir.path),
|
|
ProcessCall('pub', const <String>['get'], plugin2Dir.path),
|
|
ProcessCall(
|
|
'pub',
|
|
const <String>['run', '--enable-experiment=exp1', 'test'],
|
|
plugin2Dir.path),
|
|
]),
|
|
);
|
|
|
|
cleanupPackages();
|
|
});
|
|
});
|
|
}
|