Html程序  |  206行  |  10.88 KB

<!DOCTYPE html>
<html>
<!--
Copyright (c) 2012 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.
-->
<head>
<title>LinuxPerfGestureParser tests</title>
<script src="base.js"></script>
</head>
<body>
<script>
'use strict';

base.require('unittest');
base.require('test_utils');
base.require('linux_perf_importer');

function testGestureImport() {
  var lines = [
          '<...>-1837  [000] ...1 875292.741648: tracing_mark_write: ' +
          'log: start: TimerLogOutputs',
          '<...>-1837  [000] ...1 875292.741651: tracing_mark_write: ' +
          'log: end: TimerLogOutputs',
          '<...>-1837  [000] ...1 875292.742796: tracing_mark_write: ' +
          'log: start: LogTimerCallback',
          '<...>-1837  [000] ...1 875292.742802: tracing_mark_write: ' +
          'log: end: LogTimerCallback',
          '<...>-1837  [000] ...1 875292.742805: tracing_mark_write: ' +
          'HandleTimer: start: LoggingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742809: tracing_mark_write: ' +
          'HandleTimer: start: AppleTrackpadFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742814: tracing_mark_write: ' +
          'HandleTimer: start: Cr48ProfileSensorFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742818: tracing_mark_write: ' +
          'HandleTimer: start: T5R2CorrectingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742822: tracing_mark_write: ' +
          'HandleTimer: start: StuckButtonInhibitorFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742825: tracing_mark_write: ' +
          'HandleTimer: start: IntegralGestureFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742829: tracing_mark_write: ' +
          'HandleTimer: start: ScalingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742833: tracing_mark_write: ' +
          'HandleTimer: start: SplitCorrectingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742836: tracing_mark_write: ' +
          'HandleTimer: start: AccelFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742840: tracing_mark_write: ' +
          'HandleTimer: start: SensorJumpFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742843: tracing_mark_write: ' +
          'HandleTimer: start: BoxFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742846: tracing_mark_write: ' +
          'HandleTimer: start: LookaheadFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742853: tracing_mark_write: ' +
          'SyncInterpret: start: IirFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742861: tracing_mark_write: ' +
          'SyncInterpret: start: PalmClassifyingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742872: tracing_mark_write: ' +
          'SyncInterpret: start: ClickWiggleFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742881: tracing_mark_write: ' +
          'SyncInterpret: start: FlingStopFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742887: tracing_mark_write: ' +
          'SyncInterpret: start: ImmediateInterpreter',
          '<...>-1837  [000] ...1 875292.742906: tracing_mark_write: ' +
          'SyncInterpret: end: ImmediateInterpreter',
          '<...>-1837  [000] ...1 875292.742910: tracing_mark_write: ' +
          'SyncInterpret: end: FlingStopFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742914: tracing_mark_write: ' +
          'SyncInterpret: end: ClickWiggleFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742917: tracing_mark_write: ' +
          'SyncInterpret: end: PalmClassifyingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742921: tracing_mark_write: ' +
          'SyncInterpret: end: IirFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742926: tracing_mark_write: ' +
          'HandleTimer: end: LookaheadFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742929: tracing_mark_write: ' +
          'HandleTimer: end: BoxFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742932: tracing_mark_write: ' +
          'HandleTimer: end: SensorJumpFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742937: tracing_mark_write: ' +
          'HandleTimer: end: AccelFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742940: tracing_mark_write: ' +
          'HandleTimer: end: SplitCorrectingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742944: tracing_mark_write: ' +
          'HandleTimer: end: ScalingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742949: tracing_mark_write: ' +
          'HandleTimer: end: IntegralGestureFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742952: tracing_mark_write: ' +
          'HandleTimer: end: StuckButtonInhibitorFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742956: tracing_mark_write: ' +
          'HandleTimer: end: T5R2CorrectingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742959: tracing_mark_write: ' +
          'HandleTimer: end: Cr48ProfileSensorFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742962: tracing_mark_write: ' +
          'HandleTimer: end: AppleTrackpadFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742966: tracing_mark_write: ' +
          'HandleTimer: end: LoggingFilterInterpreter',
          '<...>-1837  [000] ...1 875292.742969: tracing_mark_write: ' +
          'log: start: TimerLogOutputs',
          '<...>-1837  [000] ...1 875292.742973: tracing_mark_write: ' +
          'log: end: TimerLogOutputs',
          '<...>-1837  [000] ...1 875292.795219: tracing_mark_write: ' +
          'log: start: LogHardwareState',
          '<...>-1837  [000] ...1 875292.795231: tracing_mark_write: ' +
          'log: end: LogHardwareState',
  ];
  var m = new tracing.TimelineModel(lines.join('\n'), false);
  assertEquals(0, m.importErrors.length);
  var threads = m.getAllThreads();
  assertEquals(1, threads.length);

  var gestureThread = threads[0];
  assertEquals('gesture', gestureThread.name);
  assertEquals(21, gestureThread.slices.length);
  assertEquals('touchpad_gesture', gestureThread.slices[0].category);
  assertEquals('GestureLog', gestureThread.slices[0].title);
  assertEquals('touchpad_gesture', gestureThread.slices[2].category);
  assertEquals('SyncInterpret', gestureThread.slices[2].title);
  assertEquals('touchpad_gesture', gestureThread.slices[7].category);
  assertEquals('HandleTimer', gestureThread.slices[7].title);
}

function testUnusualStart() {
  var lines = [
          'X-30368 [000] ...1 1819362.481867: tracing_mark_write: ' +
          'SyncInterpret: start: IirFilterInterpreter',
          'X-30368 [000] ...1 1819362.481881: tracing_mark_write: ' +
          'SyncInterpret: start: PalmClassifyingFilterInterpreter',
          'X-30368 [000] ...1 1819362.481894: tracing_mark_write: ' +
          'SyncInterpret: start: ClickWiggleFilterInterpreter',
          'X-30368 [000] ...1 1819362.481905: tracing_mark_write: ' +
          'SyncInterpret: start: FlingStopFilterInterpreter',
          'X-30368 [000] ...1 1819362.481912: tracing_mark_write: ' +
          'SyncInterpret: start: ImmediateInterpreter',
          'X-30368 [000] ...1 1819362.481933: tracing_mark_write: ' +
          'SyncInterpret: end: ImmediateInterpreter',
          'X-30368 [000] ...1 1819362.481938: tracing_mark_write: ' +
          'SyncInterpret: end: FlingStopFilterInterpreter',
          'X-30368 [000] ...1 1819362.481943: tracing_mark_write: ' +
          'SyncInterpret: end: ClickWiggleFilterInterpreter',
          'X-30368 [000] ...1 1819362.481947: tracing_mark_write: ' +
          'SyncInterpret: end: PalmClassifyingFilterInterpreter',
          'X-30368 [000] ...1 1819362.481952: tracing_mark_write: ' +
          'SyncInterpret: end: IirFilterInterpreter',
          'X-30368 [000] ...1 1819362.481958: tracing_mark_write: ' +
          'HandleTimer: end: LookaheadFilterInterpreter',
          'X-30368 [000] ...1 1819362.481962: tracing_mark_write: ' +
          'HandleTimer: end: BoxFilterInterpreter',
          'X-30368 [000] ...1 1819362.481967: tracing_mark_write: ' +
          'HandleTimer: end: SensorJumpFilterInterpreter',
          'X-30368 [000] ...1 1819362.481973: tracing_mark_write: ' +
          'HandleTimer: end: AccelFilterInterpreter',
          'X-30368 [000] ...1 1819362.481977: tracing_mark_write: ' +
          'HandleTimer: end: SplitCorrectingFilterInterpreter',
          'X-30368 [000] ...1 1819362.481982: tracing_mark_write: ' +
          'HandleTimer: end: ScalingFilterInterpreter',
          'X-30368 [000] ...1 1819362.481988: tracing_mark_write: ' +
          'HandleTimer: end: IntegralGestureFilterInterpreter',
          'X-30368 [000] ...1 1819362.481993: tracing_mark_write: ' +
          'HandleTimer: end: StuckButtonInhibitorFilterInterpreter',
          'X-30368 [000] ...1 1819362.481998: tracing_mark_write: ' +
          'HandleTimer: end: T5R2CorrectingFilterInterpreter',
          'X-30368 [000] ...1 1819362.482033: tracing_mark_write: ' +
          'HandleTimer: end: Cr48ProfileSensorFilterInterpreter',
          'X-30368 [000] ...1 1819362.482038: tracing_mark_write: ' +
          'HandleTimer: end: AppleTrackpadFilterInterpreter',
          'X-30368 [000] ...1 1819362.482043: tracing_mark_write: ' +
          'HandleTimer: end: LoggingFilterInterpreter',
          'X-30368 [000] ...1 1819362.482047: tracing_mark_write: ' +
          'log: start: TimerLogOutputs',
          'X-30368 [000] ...1 1819362.482053: tracing_mark_write: ' +
          'log: end: TimerLogOutputs',
  ];
  var m = new tracing.TimelineModel(lines.join('\n'), false);
  assertEquals(0, m.importErrors.length);
  var threads = m.getAllThreads();
  assertEquals(1, threads.length);
}

function testImportError() {
  var lines = [
          'X-30368 [000] ...1 1819362.481912: tracing_mark_write: ' +
          'SyncInterpret: start: ImmediateInterpreter',
          'X-30368 [000] ...1 1819362.481958: tracing_mark_write: ' +
          'HandleTimer: end: LookaheadFilterInterpreter',
          'X-30368 [000] ...1 1819362.481962: tracing_mark_write: ' +
          'HandleTimer: end: BoxFilterInterpreter',
          'X-30368 [000] ...1 1819362.481967: tracing_mark_write: ' +
          'HandleTimer: end: SensorJumpFilterInterpreter',
          'X-30368 [000] ...1 1819362.481973: tracing_mark_write: ' +
          'HandleTimer: end: AccelFilterInterpreter',
          'X-30368 [000] ...1 1819362.481977: tracing_mark_write: ' +
          'HandleTimer: end: SplitCorrectingFilterInterpreter',
          'X-30368 [000] ...1 1819362.481982: tracing_mark_write: ' +
          'HandleTimer: end: ScalingFilterInterpreter',
          'X-30368 [000] ...1 1819362.481988: tracing_mark_write: ' +
          'HandleTimer: end: IntegralGestureFilterInterpreter',
  ];
  var m = new tracing.TimelineModel(lines.join('\n'), false);
  assertEquals(7, m.importErrors.length);
}

</script>
</body>
</html>