Generate a Gallery demo transition-durations performance histogram (#3859)
This commit is contained in:
parent
2aab6b565c
commit
2e8315e8f5
@ -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>[
|
|||||||
'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() {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
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)));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user