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

## Description Print actionable warnings if `flutter drive` (where most of our performance benchmarks come from) is run in debug mode and it tries to gather benchmarks using `traceAction`. ## Related Issues https://github.com/flutter/flutter/issues/30625 ## Tests I added the following tests: * drive_perf_debug_warning devicelab test
51 lines
1.5 KiB
Dart
51 lines
1.5 KiB
Dart
// Copyright 2019 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 'package:flutter_devicelab/framework/adb.dart';
|
|
import 'package:flutter_devicelab/framework/framework.dart';
|
|
import 'package:flutter_devicelab/framework/utils.dart';
|
|
|
|
Future<String> _runWithMode(String mode, String deviceId) {
|
|
return evalFlutter('drive', options: <String>[
|
|
mode,
|
|
'-t',
|
|
'test_driver/scroll_perf.dart',
|
|
'-d',
|
|
deviceId,
|
|
]);
|
|
}
|
|
|
|
Future<TaskResult> run() async {
|
|
cd('${flutterDirectory.path}/examples/flutter_gallery');
|
|
final Device device = await devices.workingDevice;
|
|
await device.unlock();
|
|
final String deviceId = device.deviceId;
|
|
await flutter('packages', options: <String>['get']);
|
|
|
|
const String warningPiece = 'THIS BENCHMARK IS BEING RUN IN DEBUG MODE';
|
|
|
|
final String debugOutput = await _runWithMode('--debug', deviceId);
|
|
if (!debugOutput.contains(warningPiece)) {
|
|
return TaskResult.failure(
|
|
'Could not find the following warning message piece: $warningPiece'
|
|
);
|
|
}
|
|
|
|
final String profileOutput = await _runWithMode('--profile', deviceId);
|
|
if (profileOutput.contains(warningPiece)) {
|
|
return TaskResult.failure(
|
|
'Unexpected warning message piece in profile mode: $warningPiece'
|
|
);
|
|
}
|
|
|
|
return TaskResult.success(null);
|
|
}
|
|
|
|
Future<void> main() async {
|
|
deviceOperatingSystem = DeviceOperatingSystem.android;
|
|
await task(run);
|
|
}
|