Unverified Commit 1c2d3f32 authored by Ian Hickson's avatar Ian Hickson Committed by GitHub

Shut down gradle at the end of each task (#20968)

Apparently Gradle leaks memory and it's causing failures.
parent 53b63581
...@@ -108,6 +108,12 @@ Android SDK at `.../engine/src/third_party/android_tools/sdk`. ...@@ -108,6 +108,12 @@ Android SDK at `.../engine/src/third_party/android_tools/sdk`.
You can find where your Android SDK is using `flutter doctor`. You can find where your Android SDK is using `flutter doctor`.
## Warnings
Running devicelab will do things to your environment.
Notably, it will start and stop gradle, for instance.
## Running all tests ## Running all tests
To run all tests defined in `manifest.yaml`, use option `-a` (`--all`): To run all tests defined in `manifest.yaml`, use option `-a` (`--all`):
......
...@@ -6,6 +6,7 @@ import 'dart:async'; ...@@ -6,6 +6,7 @@ import 'dart:async';
import 'dart:convert'; import 'dart:convert';
import 'dart:io'; import 'dart:io';
import 'package:path/path.dart' as path;
import 'package:vm_service_client/vm_service_client.dart'; import 'package:vm_service_client/vm_service_client.dart';
import 'package:flutter_devicelab/framework/utils.dart'; import 'package:flutter_devicelab/framework/utils.dart';
...@@ -81,6 +82,7 @@ Future<Map<String, dynamic>> runTask(String taskName, { bool silent = false }) a ...@@ -81,6 +82,7 @@ Future<Map<String, dynamic>> runTask(String taskName, { bool silent = false }) a
} finally { } finally {
if (!runnerFinished) if (!runnerFinished)
runner.kill(ProcessSignal.sigkill); runner.kill(ProcessSignal.sigkill);
await cleanupSystem();
await stdoutSub.cancel(); await stdoutSub.cancel();
await stderrSub.cancel(); await stderrSub.cancel();
} }
...@@ -125,3 +127,40 @@ Future<VMIsolateRef> _connectToRunnerIsolate(int vmServicePort) async { ...@@ -125,3 +127,40 @@ Future<VMIsolateRef> _connectToRunnerIsolate(int vmServicePort) async {
} }
} }
} }
Future<void> cleanupSystem() async {
print('\n\nCleaning up system after task...');
final String javaHome = await findJavaHome();
if (javaHome != null) {
// To shut gradle down, we have to call "gradlew --stop".
// To call gradlew, we need to have a gradle-wrapper.properties file along
// with a shell script, a .jar file, etc. We get these from various places
// as you see in the code below, and we save them all into a temporary dir
// which we can then delete after.
// All the steps below are somewhat tolerant of errors, because it doesn't
// really matter if this succeeds every time or not.
print('\nTelling Gradle to shut down (JAVA_HOME=$javaHome)');
final String gradlewBinaryName = Platform.isWindows ? 'gradlew.bat' : 'gradlew';
final Directory tempDir = Directory.systemTemp.createTempSync('flutter_devicelab_shutdown_gradle.');
recursiveCopy(new Directory(path.join(flutterDirectory.path, 'bin', 'cache', 'artifacts', 'gradle_wrapper')), tempDir);
copy(new File(path.join(path.join(flutterDirectory.path, 'packages', 'flutter_tools'), 'templates', 'create', 'android.tmpl', 'gradle', 'wrapper', 'gradle-wrapper.properties')), new Directory(path.join(tempDir.path, 'gradle', 'wrapper')));
if (!Platform.isWindows) {
await exec(
'chmod',
<String>['a+x', path.join(tempDir.path, gradlewBinaryName)],
canFail: true,
);
}
await exec(
path.join(tempDir.path, gradlewBinaryName),
<String>['--stop'],
environment: <String, String>{ 'JAVA_HOME': javaHome },
workingDirectory: tempDir.path,
canFail: true,
);
rmTree(tempDir);
print('\n');
} else {
print('Could not determine JAVA_HOME; not shutting down Gradle.');
}
}
\ No newline at end of file
...@@ -236,7 +236,7 @@ Future<Process> startProcess( ...@@ -236,7 +236,7 @@ Future<Process> startProcess(
_runningProcesses.add(processInfo); _runningProcesses.add(processInfo);
process.exitCode.then((int exitCode) { process.exitCode.then((int exitCode) {
print('exitcode: $exitCode'); print('"$executable" exit code: $exitCode');
_runningProcesses.remove(processInfo); _runningProcesses.remove(processInfo);
}); });
...@@ -266,8 +266,9 @@ Future<int> exec( ...@@ -266,8 +266,9 @@ Future<int> exec(
List<String> arguments, { List<String> arguments, {
Map<String, String> environment, Map<String, String> environment,
bool canFail = false, // as in, whether failures are ok. False means that they are fatal. bool canFail = false, // as in, whether failures are ok. False means that they are fatal.
String workingDirectory,
}) async { }) async {
final Process process = await startProcess(executable, arguments, environment: environment); final Process process = await startProcess(executable, arguments, environment: environment, workingDirectory: workingDirectory);
final Completer<Null> stdoutDone = new Completer<Null>(); final Completer<Null> stdoutDone = new Completer<Null>();
final Completer<Null> stderrDone = new Completer<Null>(); final Completer<Null> stderrDone = new Completer<Null>();
...@@ -288,7 +289,7 @@ Future<int> exec( ...@@ -288,7 +289,7 @@ Future<int> exec(
final int exitCode = await process.exitCode; final int exitCode = await process.exitCode;
if (exitCode != 0 && !canFail) if (exitCode != 0 && !canFail)
fail('Executable failed with exit code $exitCode.'); fail('Executable "$executable" failed with exit code $exitCode.');
return exitCode; return exitCode;
} }
...@@ -301,8 +302,9 @@ Future<String> eval( ...@@ -301,8 +302,9 @@ Future<String> eval(
List<String> arguments, { List<String> arguments, {
Map<String, String> environment, Map<String, String> environment,
bool canFail = false, // as in, whether failures are ok. False means that they are fatal. bool canFail = false, // as in, whether failures are ok. False means that they are fatal.
String workingDirectory,
}) async { }) async {
final Process process = await startProcess(executable, arguments, environment: environment); final Process process = await startProcess(executable, arguments, environment: environment, workingDirectory: workingDirectory);
final StringBuffer output = new StringBuffer(); final StringBuffer output = new StringBuffer();
final Completer<Null> stdoutDone = new Completer<Null>(); final Completer<Null> stdoutDone = new Completer<Null>();
...@@ -325,7 +327,7 @@ Future<String> eval( ...@@ -325,7 +327,7 @@ Future<String> eval(
final int exitCode = await process.exitCode; final int exitCode = await process.exitCode;
if (exitCode != 0 && !canFail) if (exitCode != 0 && !canFail)
fail('Executable failed with exit code $exitCode.'); fail('Executable "$executable" failed with exit code $exitCode.');
return output.toString().trimRight(); return output.toString().trimRight();
} }
......
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