mirror of
https://github.com/flutter/flutter.git
synced 2025-06-03 00:51:18 +00:00

* Roll engine to b6df7a637498ca9beda1fa9cd7210e3202ea599f. Changes since last roll: ``` b6df7a637 Roll dart to 290c576264faa096a0b3206c71b2435309d9f904. (#4771) a6764dbd5 Add sources for Fuchsia target. (#4763) 2d5900615 [fuchsia] Remove unused header file. (#4769) 9717063b7 Revert "Roll dart to c080951d45e79cd25df98036c4be835b284a269c. (#4767)" (#4768) 9a9814312 Roll dart to c080951d45e79cd25df98036c4be835b284a269c. (#4767) e74e8b35c [async] Update includes of async headers to new path (#4760) e2c4b2760 Use Dart 2 camel case constants in the engine Dart libraries (#4766) 9c1e48434 Updates for Fuchsia roll. (#4765) 14c940e27 Switch from fxl::Mutex to std::mutex (#4764) debf82c0b Roll Garnet (#4759) 5bffdefbb Use weak pointers to the accesibility bridge from objects vended to the UIKit accessibility framework. (#4761) ```
90 lines
3.1 KiB
Dart
90 lines
3.1 KiB
Dart
// Copyright (c) 2016 The Chromium 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:async';
|
|
import 'dart:convert';
|
|
import 'dart:io';
|
|
|
|
import 'package:path/path.dart' as path;
|
|
|
|
import 'package:flutter_devicelab/framework/adb.dart';
|
|
import 'package:flutter_devicelab/framework/framework.dart';
|
|
import 'package:flutter_devicelab/framework/utils.dart';
|
|
|
|
void main() {
|
|
task(() async {
|
|
int vmServicePort;
|
|
|
|
final Device device = await devices.workingDevice;
|
|
await device.unlock();
|
|
final Directory appDir = dir(path.join(flutterDirectory.path, 'dev/integration_tests/ui'));
|
|
section('TEST WHETHER `flutter drive --route` WORKS');
|
|
await inDirectory(appDir, () async {
|
|
return await flutter(
|
|
'drive',
|
|
options: <String>['--verbose', '-d', device.deviceId, '--route', '/smuggle-it', 'lib/route.dart'],
|
|
canFail: false,
|
|
);
|
|
});
|
|
section('TEST WHETHER `flutter run --route` WORKS');
|
|
await inDirectory(appDir, () async {
|
|
final Completer<Null> ready = new Completer<Null>();
|
|
bool ok;
|
|
print('run: starting...');
|
|
final Process run = await startProcess(
|
|
path.join(flutterDirectory.path, 'bin', 'flutter'),
|
|
<String>['run', '--verbose', '-d', device.deviceId, '--route', '/smuggle-it', 'lib/route.dart'],
|
|
);
|
|
run.stdout
|
|
.transform(utf8.decoder)
|
|
.transform(const LineSplitter())
|
|
.listen((String line) {
|
|
print('run:stdout: $line');
|
|
if (lineContainsServicePort(line)) {
|
|
vmServicePort = parseServicePort(line);
|
|
print('service protocol connection available at port $vmServicePort');
|
|
print('run: ready!');
|
|
ready.complete();
|
|
ok ??= true;
|
|
}
|
|
});
|
|
run.stderr
|
|
.transform(utf8.decoder)
|
|
.transform(const LineSplitter())
|
|
.listen((String line) {
|
|
stderr.writeln('run:stderr: $line');
|
|
});
|
|
run.exitCode.then((int exitCode) { ok = false; });
|
|
await Future.any<dynamic>(<Future<dynamic>>[ ready.future, run.exitCode ]);
|
|
if (!ok)
|
|
throw 'Failed to run test app.';
|
|
print('drive: starting...');
|
|
final Process drive = await startProcess(
|
|
path.join(flutterDirectory.path, 'bin', 'flutter'),
|
|
<String>['drive', '--use-existing-app', 'http://127.0.0.1:$vmServicePort/', '--no-keep-app-running', 'lib/route.dart'],
|
|
);
|
|
drive.stdout
|
|
.transform(utf8.decoder)
|
|
.transform(const LineSplitter())
|
|
.listen((String line) {
|
|
print('drive:stdout: $line');
|
|
});
|
|
drive.stderr
|
|
.transform(utf8.decoder)
|
|
.transform(const LineSplitter())
|
|
.listen((String line) {
|
|
stderr.writeln('drive:stderr: $line');
|
|
});
|
|
int result;
|
|
result = await drive.exitCode;
|
|
if (result != 0)
|
|
throw 'Failed to drive test app (exit code $result).';
|
|
result = await run.exitCode;
|
|
if (result != 0)
|
|
throw 'Received unexpected exit code $result from run process.';
|
|
});
|
|
return new TaskResult.success(null);
|
|
});
|
|
}
|