Commit c370b7de authored by Chris Bracken's avatar Chris Bracken Committed by GitHub

Add testOutputsDirectory (#6987)

Declares a top-level getter that returns the outputs directory to which
Flutter Driver tests can write any output files. Timeline data defaults
to this directory.
parent 09320580
...@@ -11,6 +11,9 @@ ...@@ -11,6 +11,9 @@
/// Protractor (Angular), Espresso (Android) or Earl Gray (iOS). /// Protractor (Angular), Espresso (Android) or Earl Gray (iOS).
library flutter_driver; library flutter_driver;
export 'src/common.dart' show
testOutputsDirectory;
export 'src/driver.dart' show export 'src/driver.dart' show
find, find,
CommonFinders, CommonFinders,
......
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
// 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.
import 'dart:io' show Platform;
import 'package:file/file.dart'; import 'package:file/file.dart';
import 'package:file/io.dart'; import 'package:file/io.dart';
...@@ -20,3 +22,10 @@ void useMemoryFileSystemForTesting() { ...@@ -20,3 +22,10 @@ void useMemoryFileSystemForTesting() {
void restoreFileSystem() { void restoreFileSystem() {
fs = new LocalFileSystem(); fs = new LocalFileSystem();
} }
/// Flutter Driver test ouputs directory.
///
/// Tests should write any output files to this directory. Defaults to the path
/// set in the FLUTTER_TEST_OUTPUTS_DIR environment variable, or `build` if
/// unset.
String get testOutputsDirectory => Platform.environment['FLUTTER_TEST_OUTPUTS_DIR'] ?? 'build';
...@@ -12,7 +12,6 @@ import 'package:path/path.dart' as path; ...@@ -12,7 +12,6 @@ import 'package:path/path.dart' as path;
import 'common.dart'; import 'common.dart';
import 'timeline.dart'; import 'timeline.dart';
const String _kDefaultDirectory = 'build';
final JsonEncoder _prettyEncoder = new JsonEncoder.withIndent(' '); final JsonEncoder _prettyEncoder = new JsonEncoder.withIndent(' ');
/// The maximum amount of time considered safe to spend for a frame's build /// The maximum amount of time considered safe to spend for a frame's build
...@@ -88,7 +87,8 @@ class TimelineSummary { ...@@ -88,7 +87,8 @@ class TimelineSummary {
/// Writes all of the recorded timeline data to a file. /// Writes all of the recorded timeline data to a file.
Future<Null> writeTimelineToFile(String traceName, Future<Null> writeTimelineToFile(String traceName,
{String destinationDirectory: _kDefaultDirectory, bool pretty: false}) async { {String destinationDirectory, bool pretty: false}) async {
destinationDirectory ??= testOutputsDirectory;
await fs.directory(destinationDirectory).create(recursive: true); await fs.directory(destinationDirectory).create(recursive: true);
File file = fs.file(path.join(destinationDirectory, '$traceName.timeline.json')); File file = fs.file(path.join(destinationDirectory, '$traceName.timeline.json'));
await file.writeAsString(_encodeJson(_timeline.json, pretty)); await file.writeAsString(_encodeJson(_timeline.json, pretty));
...@@ -96,7 +96,8 @@ class TimelineSummary { ...@@ -96,7 +96,8 @@ class TimelineSummary {
/// Writes [summaryJson] to a file. /// Writes [summaryJson] to a file.
Future<Null> writeSummaryToFile(String traceName, Future<Null> writeSummaryToFile(String traceName,
{String destinationDirectory: _kDefaultDirectory, bool pretty: false}) async { {String destinationDirectory, bool pretty: false}) async {
destinationDirectory ??= testOutputsDirectory;
await fs.directory(destinationDirectory).create(recursive: true); await fs.directory(destinationDirectory).create(recursive: true);
File file = fs.file(path.join(destinationDirectory, '$traceName.timeline_summary.json')); File file = fs.file(path.join(destinationDirectory, '$traceName.timeline_summary.json'));
await file.writeAsString(_encodeJson(summaryJson, pretty)); await file.writeAsString(_encodeJson(summaryJson, pretty));
......
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