blob: dfd8fd0f0b0ab2c947d4cd7daa3c42bf5d1876b0 [file] [log] [blame]
// Copyright 2020 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 'dart:io';
import 'package:test/test.dart';
import 'package:process_runner/process_runner.dart';
import 'fake_process_manager.dart';
void main() {
FakeProcessManager fakeProcessManager = FakeProcessManager((String value) {});
ProcessRunner processRunner = ProcessRunner(processManager: fakeProcessManager);
ProcessPool processPool = ProcessPool(processRunner: processRunner);
setUp(() {
fakeProcessManager = FakeProcessManager((String value) {});
processRunner = ProcessRunner(processManager: fakeProcessManager);
processPool = ProcessPool(processRunner: processRunner, printReport: null);
});
tearDown(() {});
group('Ouput Capture', () {
test('startWorkers works', () async {
final Map<List<String>, List<ProcessResult>> calls = <List<String>, List<ProcessResult>>{
<String>['command', 'arg1', 'arg2']: <ProcessResult>[
ProcessResult(0, 0, 'output1', ''),
],
};
fakeProcessManager.fakeResults = calls;
final List<WorkerJob> jobs = <WorkerJob>[
WorkerJob(<String>['command', 'arg1', 'arg2'], name: 'job 1'),
];
await for (final WorkerJob _ in processPool.startWorkers(jobs)) {}
fakeProcessManager.verifyCalls(calls.keys);
});
test('runToCompletion works', () async {
final Map<List<String>, List<ProcessResult>> calls = <List<String>, List<ProcessResult>>{
<String>['command', 'arg1', 'arg2']: <ProcessResult>[
ProcessResult(0, 0, 'output1', ''),
],
};
fakeProcessManager.fakeResults = calls;
final List<WorkerJob> jobs = <WorkerJob>[
WorkerJob(<String>['command', 'arg1', 'arg2'], name: 'job 1'),
];
await processPool.runToCompletion(jobs);
fakeProcessManager.verifyCalls(calls.keys);
});
test('failed tests report results', () async {
final Map<List<String>, List<ProcessResult>> calls = <List<String>, List<ProcessResult>>{
<String>['command', 'arg1', 'arg2']: <ProcessResult>[
ProcessResult(0, -1, 'output1', 'stderr1'),
],
};
fakeProcessManager.fakeResults = calls;
final List<WorkerJob> jobs = <WorkerJob>[
WorkerJob(<String>['command', 'arg1', 'arg2'], name: 'job 1'),
];
final List<WorkerJob> completed = await processPool.runToCompletion(jobs);
expect(completed.first.result.exitCode, equals(-1));
expect(completed.first.result.stdout, equals('output1'));
expect(completed.first.result.stderr, equals('stderr1'));
expect(completed.first.result.output, equals('output1stderr1'));
});
});
}