| // Copyright 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:convert' show JSON; |
| |
| import 'package:test/test.dart'; |
| import 'package:flutter_driver/src/common.dart'; |
| import 'package:flutter_driver/flutter_driver.dart'; |
| |
| void main() { |
| group('TimelineSummary', () { |
| |
| TimelineSummary summarize(List<Map<String, dynamic>> testEvents) { |
| return new TimelineSummary.summarize(new Timeline.fromJson(<String, dynamic>{ |
| 'traceEvents': testEvents, |
| })); |
| } |
| |
| Map<String, dynamic> frame(int timeStamp, int duration) => <String, dynamic>{ |
| 'name': 'Frame', 'ph': 'X', 'ts': timeStamp, 'dur': duration |
| }; |
| |
| group('frame_count', () { |
| test('counts frames', () { |
| expect( |
| summarize(<Map<String, dynamic>>[ |
| frame(1000, 1000), |
| frame(3000, 2000), |
| ]).countFrames(), |
| 2 |
| ); |
| }); |
| }); |
| |
| group('average_frame_build_time_millis', () { |
| test('returns null when there is no data', () { |
| expect(summarize(<Map<String, dynamic>>[]).computeAverageFrameBuildTimeMillis(), isNull); |
| }); |
| |
| test('computes average frame build time in milliseconds', () { |
| expect( |
| summarize(<Map<String, dynamic>>[ |
| frame(1000, 1000), |
| frame(3000, 2000), |
| ]).computeAverageFrameBuildTimeMillis(), |
| 1.5 |
| ); |
| }); |
| }); |
| |
| group('worst_frame_build_time_millis', () { |
| test('returns null when there is no data', () { |
| expect(summarize(<Map<String, dynamic>>[]).computeWorstFrameBuildTimeMillis(), isNull); |
| }); |
| |
| test('computes worst frame build time in milliseconds', () { |
| expect( |
| summarize(<Map<String, dynamic>>[ |
| frame(1000, 1000), |
| frame(3000, 2000), |
| ]).computeWorstFrameBuildTimeMillis(), |
| 2.0 |
| ); |
| expect( |
| summarize(<Map<String, dynamic>>[ |
| frame(3000, 2000), |
| frame(1000, 1000), |
| ]).computeWorstFrameBuildTimeMillis(), |
| 2.0 |
| ); |
| }); |
| }); |
| |
| group('computeMissedFrameBuildBudgetCount', () { |
| test('computes the number of missed build budgets', () { |
| TimelineSummary summary = summarize(<Map<String, dynamic>>[ |
| frame(1000, 9000), |
| frame(11000, 1000), |
| frame(13000, 10000), |
| ]); |
| |
| expect(summary.countFrames(), 3); |
| expect(summary.computeMissedFrameBuildBudgetCount(), 2); |
| }); |
| }); |
| |
| group('summaryJson', () { |
| test('computes and returns summary as JSON', () { |
| expect( |
| summarize(<Map<String, dynamic>>[ |
| frame(1000, 9000), |
| frame(11000, 1000), |
| frame(13000, 11000), |
| ]).summaryJson, |
| <String, dynamic>{ |
| 'average_frame_build_time_millis': 7.0, |
| 'worst_frame_build_time_millis': 11.0, |
| 'missed_frame_build_budget_count': 2, |
| 'frame_count': 3, |
| 'frame_build_times': <int>[9000, 1000, 11000], |
| } |
| ); |
| }); |
| }); |
| |
| group('writeTimelineToFile', () { |
| setUp(() { |
| useMemoryFileSystemForTesting(); |
| }); |
| |
| tearDown(() { |
| restoreFileSystem(); |
| }); |
| |
| test('writes timeline to JSON file', () async { |
| await summarize(<Map<String, String>>[<String, String>{'foo': 'bar'}]) |
| .writeTimelineToFile('test', destinationDirectory: '/temp'); |
| String written = |
| await fs.file('/temp/test.timeline.json').readAsString(); |
| expect(written, '{"traceEvents":[{"foo":"bar"}]}'); |
| }); |
| |
| test('writes summary to JSON file', () async { |
| await summarize(<Map<String, dynamic>>[ |
| frame(1000, 9000), |
| frame(11000, 1000), |
| frame(13000, 11000), |
| ]).writeSummaryToFile('test', destinationDirectory: '/temp'); |
| String written = |
| await fs.file('/temp/test.timeline_summary.json').readAsString(); |
| expect(JSON.decode(written), <String, dynamic>{ |
| 'average_frame_build_time_millis': 7.0, |
| 'worst_frame_build_time_millis': 11.0, |
| 'missed_frame_build_budget_count': 2, |
| 'frame_count': 3, |
| 'frame_build_times': <int>[9000, 1000, 11000], |
| }); |
| }); |
| }); |
| }); |
| } |