timeline_test.dart 1.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10
// 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 'package:test/test.dart';
import 'package:flutter_driver/src/timeline.dart';

void main() {
  group('Timeline', () {
    test('parses JSON', () {
pq's avatar
pq committed
11 12 13
      Timeline timeline = new Timeline.fromJson(<String, dynamic>{
        'traceEvents': <Map<String, dynamic>>[
          <String, dynamic>{
14 15 16 17 18 19 20 21
            'name': 'test event',
            'cat': 'test category',
            'ph': 'B',
            'pid': 123,
            'tid': 234,
            'dur': 345,
            'ts': 456,
            'tts': 567,
pq's avatar
pq committed
22
            'args': <String, dynamic>{
23 24 25 26
              'arg1': true,
            }
          },
          // Tests that we don't choke on missing data
pq's avatar
pq committed
27
          <String, dynamic>{}
28 29 30 31 32 33 34 35 36 37 38 39 40 41
        ]
      });

      expect(timeline.events, hasLength(2));

      TimelineEvent e1 = timeline.events[0];
      expect(e1.name, 'test event');
      expect(e1.category, 'test category');
      expect(e1.phase, 'B');
      expect(e1.processId, 123);
      expect(e1.threadId, 234);
      expect(e1.duration, const Duration(microseconds: 345));
      expect(e1.timestampMicros, 456);
      expect(e1.threadTimestampMicros, 567);
pq's avatar
pq committed
42
      expect(e1.arguments, <String, dynamic>{ 'arg1': true });
43 44 45 46 47 48 49 50 51 52 53 54 55 56

      TimelineEvent e2 = timeline.events[1];
      expect(e2.name, isNull);
      expect(e2.category, isNull);
      expect(e2.phase, isNull);
      expect(e2.processId, isNull);
      expect(e2.threadId, isNull);
      expect(e2.duration, isNull);
      expect(e2.timestampMicros, isNull);
      expect(e2.threadTimestampMicros, isNull);
      expect(e2.arguments, isNull);
    });
  });
}