gpu_summarizer_test.dart 950 Bytes
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
// Copyright 2014 The Flutter 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 'package:flutter_driver/flutter_driver.dart';
import 'package:flutter_driver/src/driver/gpu_sumarizer.dart';

import '../common.dart';

TimelineEvent newGPUTraceEvent(double ms) => TimelineEvent(<String, dynamic>{
  'name': 'GPUStart',
  'ph': 'b',
  'args': <String, String>{
    'FrameTimeMS': ms.toString()
  },
});

void main() {
  test('Can process GPU frame times.', () {
    final GpuSumarizer summarizer = GpuSumarizer(<TimelineEvent>[
      newGPUTraceEvent(4.233),
      newGPUTraceEvent(7.22),
      newGPUTraceEvent(9.1),
      newGPUTraceEvent(40.23),
    ]);

    expect(summarizer.computeAverageGPUTime(), closeTo(15.19, 0.1));
    expect(summarizer.computePercentileGPUTime(50.0), closeTo(9.1, 0.1));
    expect(summarizer.computeWorstGPUTime(), 40.23);
  });
}