Commit 2e8315e8 authored by Hans Muller's avatar Hans Muller

Generate a Gallery demo transition-durations performance histogram (#3859)

parent 2aab6b56
...@@ -3,8 +3,12 @@ ...@@ -3,8 +3,12 @@
// found in the LICENSE file. // found in the LICENSE file.
import 'dart:async'; import 'dart:async';
import 'dart:convert' show JsonEncoder;
import 'package:file/file.dart';
import 'package:file/io.dart';
import 'package:flutter_driver/flutter_driver.dart'; import 'package:flutter_driver/flutter_driver.dart';
import 'package:path/path.dart' as path;
import 'package:test/test.dart'; import 'package:test/test.dart';
// Warning: the following strings must be kept in sync with GalleryHome. // Warning: the following strings must be kept in sync with GalleryHome.
...@@ -46,6 +50,41 @@ const List<String> demoNames = const <String>[ ...@@ -46,6 +50,41 @@ const List<String> demoNames = const <String>[
'Typography' 'Typography'
]; ];
Future<Null> saveDurationsHistogram(List<Map<String, dynamic>> events) async {
final Map<String, List<int>> durations = new Map<String, List<int>>();
Map<String, dynamic> startEvent;
// Save the duration of the first frame after each 'Start Transition' event.
for (Map<String, dynamic> event in events) {
final String eventName = event['name'];
if (eventName == 'Start Transition') {
assert(startEvent == null);
startEvent = event;
} else if (startEvent != null && eventName == 'Frame') {
final String routeName = startEvent['args']['to'];
durations[routeName] ??= new List<int>();
durations[routeName].add(event['dur']);
startEvent = null;
}
}
// Verify that the durations data is valid.
if (durations.keys.isEmpty)
throw 'no "Start Transition" timeline events found';
for(String routeName in durations.keys) {
if (durations[routeName] == null || durations[routeName].length != 2)
throw 'invalid timeline data for $routeName transition';
}
// Save the durations Map to a file.
final String destinationDirectory = 'build';
final FileSystem fs = new LocalFileSystem();
await fs.directory(destinationDirectory).create(recursive: true);
final File file = fs.file(path.join(destinationDirectory, 'transition_durations.timeline.json'));
await file.writeAsString(new JsonEncoder.withIndent(' ').convert(durations));
}
void main() { void main() {
group('flutter gallery transitions', () { group('flutter gallery transitions', () {
FlutterDriver driver; FlutterDriver driver;
...@@ -81,13 +120,14 @@ void main() { ...@@ -81,13 +120,14 @@ void main() {
} }
}, },
streams: const <TimelineStream>[ streams: const <TimelineStream>[
TimelineStream.dart, TimelineStream.dart
TimelineStream.gc,
TimelineStream.compiler
]); ]);
new TimelineSummary.summarize(timeline)
..writeSummaryToFile('transitions_perf', pretty: true) // Save the duration (in microseconds) of the first timeline Frame event
..writeTimelineToFile('transitions_perf', pretty: true); // that follows a 'Start Transition' event. The Gallery app adds a
}, timeout: new Timeout(new Duration(minutes: 15))); // 'Start Transition' event when a demo is launched (see GalleryItem).
saveDurationsHistogram(timeline.json['traceEvents']);
}, timeout: new Timeout(new Duration(minutes: 5)));
}); });
} }
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