Unverified Commit e8cd4827 authored by Jenn Magder's avatar Jenn Magder Committed by GitHub

Migrate fake_process_manager to null safety (#80018)

parent beec6106
...@@ -12,7 +12,7 @@ import 'package:flutter_tools/src/base/platform.dart'; ...@@ -12,7 +12,7 @@ import 'package:flutter_tools/src/base/platform.dart';
import 'package:test/fake.dart'; import 'package:test/fake.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
void main() { void main() {
testWithoutContext('AndroidDevice.stopApp handles a null ApplicationPackage', () async { testWithoutContext('AndroidDevice.stopApp handles a null ApplicationPackage', () async {
......
...@@ -22,7 +22,7 @@ import 'package:flutter_tools/src/project.dart'; ...@@ -22,7 +22,7 @@ import 'package:flutter_tools/src/project.dart';
import 'package:test/fake.dart'; import 'package:test/fake.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
void main() { void main() {
testWithoutContext('AndroidDevice stores the requested id', () { testWithoutContext('AndroidDevice stores the requested id', () {
......
...@@ -14,7 +14,6 @@ import 'package:mockito/mockito.dart'; ...@@ -14,7 +14,6 @@ import 'package:mockito/mockito.dart';
import 'package:fake_async/fake_async.dart'; import 'package:fake_async/fake_async.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart';
import '../../src/fake_process_manager.dart'; import '../../src/fake_process_manager.dart';
import '../../src/mocks.dart' show MockAndroidSdk; import '../../src/mocks.dart' show MockAndroidSdk;
......
...@@ -19,7 +19,7 @@ import 'package:path/path.dart' as path; // flutter_ignore: package_path_import ...@@ -19,7 +19,7 @@ import 'package:path/path.dart' as path; // flutter_ignore: package_path_import
import 'package:process/process.dart'; import 'package:process/process.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
class MockFile extends Mock implements File {} class MockFile extends Mock implements File {}
class MockFileSystem extends Mock implements FileSystem {} class MockFileSystem extends Mock implements FileSystem {}
......
...@@ -14,7 +14,7 @@ import 'package:flutter_tools/src/base/terminal.dart'; ...@@ -14,7 +14,7 @@ import 'package:flutter_tools/src/base/terminal.dart';
import 'package:mockito/mockito.dart'; import 'package:mockito/mockito.dart';
import 'package:fake_async/fake_async.dart'; import 'package:fake_async/fake_async.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
import '../../src/fakes.dart'; import '../../src/fakes.dart';
import '../../src/mocks.dart' show MockProcessManager, import '../../src/mocks.dart' show MockProcessManager,
flakyProcessFactory; flakyProcessFactory;
......
...@@ -18,7 +18,7 @@ import 'package:flutter_tools/src/build_system/exceptions.dart'; ...@@ -18,7 +18,7 @@ import 'package:flutter_tools/src/build_system/exceptions.dart';
import 'package:flutter_tools/src/convert.dart'; import 'package:flutter_tools/src/convert.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
void main() { void main() {
FileSystem fileSystem; FileSystem fileSystem;
......
...@@ -21,7 +21,7 @@ import 'package:meta/meta.dart'; ...@@ -21,7 +21,7 @@ import 'package:meta/meta.dart';
import 'package:mockito/mockito.dart'; import 'package:mockito/mockito.dart';
import '../../../src/common.dart'; import '../../../src/common.dart';
import '../../../src/context.dart'; import '../../../src/fake_process_manager.dart';
import '../../../src/fakes.dart'; import '../../../src/fakes.dart';
final Platform kNoAnsiPlatform = FakePlatform(stdoutSupportsAnsi: false); final Platform kNoAnsiPlatform = FakePlatform(stdoutSupportsAnsi: false);
......
...@@ -14,7 +14,7 @@ import 'package:flutter_tools/src/localizations/localizations_utils.dart'; ...@@ -14,7 +14,7 @@ import 'package:flutter_tools/src/localizations/localizations_utils.dart';
import 'package:mockito/mockito.dart'; import 'package:mockito/mockito.dart';
import '../../../src/common.dart'; import '../../../src/common.dart';
import '../../../src/context.dart'; import '../../../src/fake_process_manager.dart';
void main() { void main() {
// Verifies that values are correctly passed through the localizations // Verifies that values are correctly passed through the localizations
......
...@@ -14,7 +14,7 @@ import 'package:flutter_tools/src/compile.dart'; ...@@ -14,7 +14,7 @@ import 'package:flutter_tools/src/compile.dart';
import 'package:package_config/package_config.dart'; import 'package:package_config/package_config.dart';
import '../src/common.dart'; import '../src/common.dart';
import '../src/context.dart'; import '../src/fake_process_manager.dart';
void main() { void main() {
testWithoutContext('StdoutHandler can parse output for successful batch compilation', () async { testWithoutContext('StdoutHandler can parse output for successful batch compilation', () async {
......
...@@ -20,7 +20,7 @@ import 'package:package_config/package_config.dart'; ...@@ -20,7 +20,7 @@ import 'package:package_config/package_config.dart';
import 'package:process/process.dart'; import 'package:process/process.dart';
import '../src/common.dart'; import '../src/common.dart';
import '../src/context.dart'; import '../src/fake_process_manager.dart';
import '../src/fakes.dart'; import '../src/fakes.dart';
void main() { void main() {
......
...@@ -17,7 +17,6 @@ import 'package:flutter_tools/src/convert.dart'; ...@@ -17,7 +17,6 @@ import 'package:flutter_tools/src/convert.dart';
import 'package:package_config/package_config.dart'; import 'package:package_config/package_config.dart';
import '../src/common.dart'; import '../src/common.dart';
import '../src/context.dart';
import '../src/fake_process_manager.dart'; import '../src/fake_process_manager.dart';
import '../src/fakes.dart'; import '../src/fakes.dart';
......
...@@ -20,8 +20,8 @@ import 'package:http/http.dart'; ...@@ -20,8 +20,8 @@ import 'package:http/http.dart';
import 'package:http/testing.dart'; import 'package:http/testing.dart';
import '../src/common.dart'; import '../src/common.dart';
import '../src/context.dart';
import '../src/fake_http_client.dart'; import '../src/fake_http_client.dart';
import '../src/fake_process_manager.dart';
void main() { void main() {
BufferLogger logger; BufferLogger logger;
......
...@@ -15,7 +15,6 @@ import 'package:flutter_tools/src/build_system/build_system.dart'; ...@@ -15,7 +15,6 @@ import 'package:flutter_tools/src/build_system/build_system.dart';
import 'package:flutter_tools/src/build_system/targets/localizations.dart'; import 'package:flutter_tools/src/build_system/targets/localizations.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart';
import '../../src/fake_process_manager.dart'; import '../../src/fake_process_manager.dart';
import '../../src/fakes.dart'; import '../../src/fakes.dart';
......
...@@ -16,8 +16,8 @@ import 'package:flutter_tools/src/persistent_tool_state.dart'; ...@@ -16,8 +16,8 @@ import 'package:flutter_tools/src/persistent_tool_state.dart';
import 'package:flutter_tools/src/resident_runner.dart'; import 'package:flutter_tools/src/resident_runner.dart';
import '../src/common.dart'; import '../src/common.dart';
import '../src/context.dart';
import '../src/fake_http_client.dart'; import '../src/fake_http_client.dart';
import '../src/fake_process_manager.dart';
void main() { void main() {
BufferLogger logger; BufferLogger logger;
......
...@@ -15,7 +15,7 @@ import 'package:flutter_tools/src/version.dart'; ...@@ -15,7 +15,7 @@ import 'package:flutter_tools/src/version.dart';
import 'package:mockito/mockito.dart'; import 'package:mockito/mockito.dart';
import '../src/common.dart'; import '../src/common.dart';
import '../src/context.dart'; import '../src/fake_process_manager.dart';
import '../src/fakes.dart'; import '../src/fakes.dart';
/// Matches a doctor validation result. /// Matches a doctor validation result.
......
...@@ -13,7 +13,7 @@ import 'package:flutter_tools/src/fuchsia/fuchsia_sdk.dart'; ...@@ -13,7 +13,7 @@ import 'package:flutter_tools/src/fuchsia/fuchsia_sdk.dart';
import 'package:mockito/mockito.dart'; import 'package:mockito/mockito.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
void main() { void main() {
MockFuchsiaArtifacts mockFuchsiaArtifacts; MockFuchsiaArtifacts mockFuchsiaArtifacts;
......
...@@ -13,7 +13,7 @@ import 'package:flutter_tools/src/fuchsia/fuchsia_sdk.dart'; ...@@ -13,7 +13,7 @@ import 'package:flutter_tools/src/fuchsia/fuchsia_sdk.dart';
import 'package:test/fake.dart'; import 'package:test/fake.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
void main() { void main() {
FakeFuchsiaArtifacts fakeFuchsiaArtifacts; FakeFuchsiaArtifacts fakeFuchsiaArtifacts;
......
...@@ -15,7 +15,7 @@ import 'package:flutter_tools/src/ios/code_signing.dart'; ...@@ -15,7 +15,7 @@ import 'package:flutter_tools/src/ios/code_signing.dart';
import 'package:flutter_tools/src/globals_null_migrated.dart' as globals; import 'package:flutter_tools/src/globals_null_migrated.dart' as globals;
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
void main() { void main() {
group('Auto signing', () { group('Auto signing', () {
......
...@@ -28,7 +28,7 @@ import 'package:flutter_tools/src/macos/xcode.dart'; ...@@ -28,7 +28,7 @@ import 'package:flutter_tools/src/macos/xcode.dart';
import 'package:mockito/mockito.dart'; import 'package:mockito/mockito.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
void main() { void main() {
final FakePlatform macPlatform = FakePlatform(operatingSystem: 'macos'); final FakePlatform macPlatform = FakePlatform(operatingSystem: 'macos');
......
...@@ -20,7 +20,7 @@ import 'package:mockito/mockito.dart'; ...@@ -20,7 +20,7 @@ import 'package:mockito/mockito.dart';
import 'package:vm_service/vm_service.dart'; import 'package:vm_service/vm_service.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
import '../../src/fake_vm_services.dart'; import '../../src/fake_vm_services.dart';
void main() { void main() {
......
...@@ -10,7 +10,7 @@ import 'package:flutter_tools/src/ios/xcodeproj.dart'; ...@@ -10,7 +10,7 @@ import 'package:flutter_tools/src/ios/xcodeproj.dart';
import 'package:flutter_tools/src/macos/xcode.dart'; import 'package:flutter_tools/src/macos/xcode.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
import '../../src/fakes.dart'; import '../../src/fakes.dart';
void main() { void main() {
......
...@@ -17,7 +17,7 @@ import 'package:flutter_tools/src/project.dart'; ...@@ -17,7 +17,7 @@ import 'package:flutter_tools/src/project.dart';
import 'package:mockito/mockito.dart'; import 'package:mockito/mockito.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/fake_process_manager.dart';
import '../../src/fakes.dart'; import '../../src/fakes.dart';
final FakePlatform linux = FakePlatform( final FakePlatform linux = FakePlatform(
......
...@@ -16,7 +16,7 @@ import 'package:flutter_tools/src/resident_runner.dart'; ...@@ -16,7 +16,7 @@ import 'package:flutter_tools/src/resident_runner.dart';
import 'package:test/fake.dart'; import 'package:test/fake.dart';
import '../src/common.dart'; import '../src/common.dart';
import '../src/context.dart'; import '../src/fake_process_manager.dart';
import '../src/fake_vm_services.dart'; import '../src/fake_vm_services.dart';
final vm_service.Isolate isolate = vm_service.Isolate( final vm_service.Isolate isolate = vm_service.Isolate(
......
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
// @dart = 2.8
import 'dart:async'; import 'dart:async';
import 'dart:convert'; import 'dart:convert';
import 'dart:io' as io show ProcessSignal, Process, ProcessStartMode, ProcessResult, systemEncoding; import 'dart:io' as io show ProcessSignal, Process, ProcessStartMode, ProcessResult, systemEncoding;
...@@ -22,7 +20,7 @@ typedef VoidCallback = void Function(); ...@@ -22,7 +20,7 @@ typedef VoidCallback = void Function();
@immutable @immutable
class FakeCommand { class FakeCommand {
const FakeCommand({ const FakeCommand({
@required this.command, required this.command,
this.workingDirectory, this.workingDirectory,
this.environment, this.environment,
this.encoding, this.encoding,
...@@ -46,7 +44,7 @@ class FakeCommand { ...@@ -46,7 +44,7 @@ class FakeCommand {
/// be considered correct. /// be considered correct.
/// ///
/// If this is null, the working directory is ignored. /// If this is null, the working directory is ignored.
final String workingDirectory; final String? workingDirectory;
/// The environment that must be matched for this [FakeCommand] to be considered correct. /// The environment that must be matched for this [FakeCommand] to be considered correct.
/// ///
...@@ -54,13 +52,13 @@ class FakeCommand { ...@@ -54,13 +52,13 @@ class FakeCommand {
/// ///
/// Otherwise, each key in this environment must be present and must have a /// Otherwise, each key in this environment must be present and must have a
/// value that matches the one given here for the [FakeCommand] to match. /// value that matches the one given here for the [FakeCommand] to match.
final Map<String, String> environment; final Map<String, String>? environment;
/// The stdout and stderr encoding that must be matched for this [FakeCommand] /// The stdout and stderr encoding that must be matched for this [FakeCommand]
/// to be considered correct. /// to be considered correct.
/// ///
/// If this is null, then the encodings are ignored. /// If this is null, then the encodings are ignored.
final Encoding encoding; final Encoding? encoding;
/// The time to allow to elapse before returning the [exitCode], if this command /// The time to allow to elapse before returning the [exitCode], if this command
/// is "executed". /// is "executed".
...@@ -71,7 +69,7 @@ class FakeCommand { ...@@ -71,7 +69,7 @@ class FakeCommand {
/// A callback that is run after [duration] expires but before the [exitCode] /// A callback that is run after [duration] expires but before the [exitCode]
/// (and output) are passed back. /// (and output) are passed back.
final VoidCallback onRun; final VoidCallback? onRun;
/// The process' exit code. /// The process' exit code.
/// ///
...@@ -92,19 +90,19 @@ class FakeCommand { ...@@ -92,19 +90,19 @@ class FakeCommand {
/// If provided, allows the command completion to be blocked until the future /// If provided, allows the command completion to be blocked until the future
/// resolves. /// resolves.
final Completer<void> completer; final Completer<void>? completer;
/// An optional stdin sink that will be exposed through the resulting /// An optional stdin sink that will be exposed through the resulting
/// [FakeProcess]. /// [FakeProcess].
final IOSink stdin; final IOSink? stdin;
/// If provided, this exception will be thrown when the fake command is run. /// If provided, this exception will be thrown when the fake command is run.
final dynamic exception; final Object? exception;
void _matches( void _matches(
List<String> command, List<String> command,
String workingDirectory, String? workingDirectory,
Map<String, String> environment, Map<String, String>? environment,
Encoding encoding, Encoding encoding,
) { ) {
expect(command, equals(this.command)); expect(command, equals(this.command));
...@@ -126,7 +124,7 @@ class _FakeProcess implements io.Process { ...@@ -126,7 +124,7 @@ class _FakeProcess implements io.Process {
Duration duration, Duration duration,
this.pid, this.pid,
this._stderr, this._stderr,
this.stdin, IOSink? stdin,
this._stdout, this._stdout,
this._completer, this._completer,
) : exitCode = Future<void>.delayed(duration).then((void value) { ) : exitCode = Future<void>.delayed(duration).then((void value) {
...@@ -135,6 +133,7 @@ class _FakeProcess implements io.Process { ...@@ -135,6 +133,7 @@ class _FakeProcess implements io.Process {
} }
return _exitCode; return _exitCode;
}), }),
stdin = stdin ?? IOSink(StreamController<List<int>>().sink),
stderr = _stderr == null stderr = _stderr == null
? const Stream<List<int>>.empty() ? const Stream<List<int>>.empty()
: Stream<List<int>>.value(utf8.encode(_stderr)), : Stream<List<int>>.value(utf8.encode(_stderr)),
...@@ -143,7 +142,7 @@ class _FakeProcess implements io.Process { ...@@ -143,7 +142,7 @@ class _FakeProcess implements io.Process {
: Stream<List<int>>.value(utf8.encode(_stdout)); : Stream<List<int>>.value(utf8.encode(_stdout));
final int _exitCode; final int _exitCode;
final Completer<void> _completer; final Completer<void>? _completer;
@override @override
final Future<int> exitCode; final Future<int> exitCode;
...@@ -221,8 +220,8 @@ abstract class FakeProcessManager implements ProcessManager { ...@@ -221,8 +220,8 @@ abstract class FakeProcessManager implements ProcessManager {
@protected @protected
FakeCommand findCommand( FakeCommand findCommand(
List<String> command, List<String> command,
String workingDirectory, String? workingDirectory,
Map<String, String> environment, Map<String, String>? environment,
Encoding encoding, Encoding encoding,
); );
...@@ -230,17 +229,17 @@ abstract class FakeProcessManager implements ProcessManager { ...@@ -230,17 +229,17 @@ abstract class FakeProcessManager implements ProcessManager {
_FakeProcess _runCommand( _FakeProcess _runCommand(
List<String> command, List<String> command,
String workingDirectory, String? workingDirectory,
Map<String, String> environment, Map<String, String>? environment,
Encoding encoding, Encoding encoding,
) { ) {
_pid += 1; _pid += 1;
final FakeCommand fakeCommand = findCommand(command, workingDirectory, environment, encoding); final FakeCommand fakeCommand = findCommand(command, workingDirectory, environment, encoding);
if (fakeCommand.exception != null) { if (fakeCommand.exception != null) {
throw fakeCommand.exception; throw fakeCommand.exception!;
} }
if (fakeCommand.onRun != null) { if (fakeCommand.onRun != null) {
fakeCommand.onRun(); fakeCommand.onRun!();
} }
return _FakeProcess( return _FakeProcess(
fakeCommand.exitCode, fakeCommand.exitCode,
...@@ -256,8 +255,8 @@ abstract class FakeProcessManager implements ProcessManager { ...@@ -256,8 +255,8 @@ abstract class FakeProcessManager implements ProcessManager {
@override @override
Future<io.Process> start( Future<io.Process> start(
List<dynamic> command, { List<dynamic> command, {
String workingDirectory, String? workingDirectory,
Map<String, String> environment, Map<String, String>? environment,
bool includeParentEnvironment = true, // ignored bool includeParentEnvironment = true, // ignored
bool runInShell = false, // ignored bool runInShell = false, // ignored
io.ProcessStartMode mode = io.ProcessStartMode.normal, // ignored io.ProcessStartMode mode = io.ProcessStartMode.normal, // ignored
...@@ -275,8 +274,8 @@ abstract class FakeProcessManager implements ProcessManager { ...@@ -275,8 +274,8 @@ abstract class FakeProcessManager implements ProcessManager {
@override @override
Future<io.ProcessResult> run( Future<io.ProcessResult> run(
List<dynamic> command, { List<dynamic> command, {
String workingDirectory, String? workingDirectory,
Map<String, String> environment, Map<String, String>? environment,
bool includeParentEnvironment = true, // ignored bool includeParentEnvironment = true, // ignored
bool runInShell = false, // ignored bool runInShell = false, // ignored
Encoding stdoutEncoding = io.systemEncoding, Encoding stdoutEncoding = io.systemEncoding,
...@@ -295,8 +294,8 @@ abstract class FakeProcessManager implements ProcessManager { ...@@ -295,8 +294,8 @@ abstract class FakeProcessManager implements ProcessManager {
@override @override
io.ProcessResult runSync( io.ProcessResult runSync(
List<dynamic> command, { List<dynamic> command, {
String workingDirectory, String? workingDirectory,
Map<String, String> environment, Map<String, String>? environment,
bool includeParentEnvironment = true, // ignored bool includeParentEnvironment = true, // ignored
bool runInShell = false, // ignored bool runInShell = false, // ignored
Encoding stdoutEncoding = io.systemEncoding, // actual encoder is ignored Encoding stdoutEncoding = io.systemEncoding, // actual encoder is ignored
...@@ -313,18 +312,20 @@ abstract class FakeProcessManager implements ProcessManager { ...@@ -313,18 +312,20 @@ abstract class FakeProcessManager implements ProcessManager {
/// Returns false if executable in [excludedExecutables]. /// Returns false if executable in [excludedExecutables].
@override @override
bool canRun(dynamic executable, {String workingDirectory}) => !excludedExecutables.contains(executable); bool canRun(dynamic executable, {String? workingDirectory}) => !excludedExecutables.contains(executable);
Set<String> excludedExecutables = <String>{}; Set<String> excludedExecutables = <String>{};
@override @override
bool killPid(int pid, [io.ProcessSignal signal = io.ProcessSignal.sigterm]) { bool killPid(int pid, [io.ProcessSignal signal = io.ProcessSignal.sigterm]) {
// Killing a fake process has no effect unless it has an attached completer. // Killing a fake process has no effect unless it has an attached completer.
final _FakeProcess fakeProcess = _fakeRunningProcesses[pid]; final _FakeProcess? fakeProcess = _fakeRunningProcesses[pid];
if (fakeProcess == null) { if (fakeProcess == null) {
return false; return false;
} }
fakeProcess._completer.complete(); if (fakeProcess._completer != null) {
fakeProcess._completer!.complete();
}
return true; return true;
} }
} }
...@@ -335,8 +336,8 @@ class _FakeAnyProcessManager extends FakeProcessManager { ...@@ -335,8 +336,8 @@ class _FakeAnyProcessManager extends FakeProcessManager {
@override @override
FakeCommand findCommand( FakeCommand findCommand(
List<String> command, List<String> command,
String workingDirectory, String? workingDirectory,
Map<String, String> environment, Map<String, String>? environment,
Encoding encoding, Encoding encoding,
) { ) {
return FakeCommand( return FakeCommand(
...@@ -369,8 +370,8 @@ class _SequenceProcessManager extends FakeProcessManager { ...@@ -369,8 +370,8 @@ class _SequenceProcessManager extends FakeProcessManager {
@override @override
FakeCommand findCommand( FakeCommand findCommand(
List<String> command, List<String> command,
String workingDirectory, String? workingDirectory,
Map<String, String> environment, Map<String, String>? environment,
Encoding encoding, Encoding encoding,
) { ) {
expect(_commands, isNotEmpty, expect(_commands, isNotEmpty,
......
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