1 <!DOCTYPE HTML> 2 <html> 3 <!-- 4 Copyright (c) 2012 The Chromium Authors. All rights reserved. 5 Use of this source code is governed by a BSD-style license that can be 6 found in the LICENSE file. 7 --> 8 <head i18n-values="dir:textdirection;"> 9 <title>TimelineView tests</title> 10 <link rel="stylesheet" href="overlay.css"> 11 <link rel="stylesheet" href="timeline.css"> 12 <link rel="stylesheet" href="timeline_analysis.css"> 13 <link rel="stylesheet" href="timeline_view.css"> 14 <link rel="stylesheet" href="../shared/css/tabs.css"> 15 <script src="http://closure-library.googlecode.com/svn/trunk/closure/goog/base.js"></script> 16 <script src="../shared/js/cr.js"></script> 17 <script src="../shared/js/cr/event_target.js"></script> 18 <script src="../shared/js/cr/ui.js"></script> 19 <script src="../shared/js/cr/ui/tabs.js"></script> 20 <script src="overlay.js"></script> 21 <script src="measuring_stick.js"></script> 22 <script src="profiling_view.js"></script> 23 <script src="timeline_analysis.js"></script> 24 <script src="timeline_view.js"></script> 25 <script src="timeline_model.js"></script> 26 <script src="linux_perf_importer.js"></script> 27 <script src="trace_event_importer.js"></script> 28 <script src="timeline.js"></script> 29 <script src="timeline_track.js"></script> 30 <script src="sorted_array_utils.js"></script> 31 <script src="fast_rect_renderer.js"></script> 32 <script src="test_utils.js"></script> 33 <script> 34 goog.require('goog.testing.jsunit'); 35 </script> 36 <style> 37 .timeline-view { 38 border: 1px solid black; 39 margin: 10px; 40 } 41 .timeline-find-dialog { 42 border: 1px solid black; 43 margin: 10px; 44 } 45 </style> 46 </head> 47 <body> 48 <script> 49 'use strict'; 50 51 function appendTestResult(title, el) { 52 var titleEl = document.createElement('div'); 53 titleEl.textContent = title; 54 titleEl.style.fontSize = '120%'; 55 titleEl.style.marginBottom = '0px'; 56 57 var groupEl = document.createElement('div'); 58 groupEl.style.marginBottom = '48px'; 59 groupEl.style.border = '1px solid black'; 60 61 groupEl.appendChild(el); 62 document.body.appendChild(titleEl); 63 document.body.appendChild(groupEl); 64 } 65 66 function testAnalyzeSingleSlice() { 67 var events = [ 68 {name: 'b', args: {}, pid: 52, ts: 629, cat: 'foo', tid: 53, ph: 'B'}, 69 {name: 'b', args: {}, pid: 52, ts: 631, cat: 'foo', tid: 53, ph: 'E'}, 70 ]; 71 var model = new tracing.TimelineModel(); 72 model.importEvents(events); 73 74 var t53track = new tracing.TimelineThreadTrack(); 75 t53track.thread = model.processes[52].threads[53]; 76 77 var selection = new tracing.TimelineSelection(); 78 t53track.addAllObjectsMatchingFilterToSelection( 79 new tracing.TimelineFilter('b'), selection); 80 assertEquals(1, selection.length); 81 82 var analysisEl = new tracing.TimelineAnalysisView(); 83 analysisEl.selection = selection; 84 85 appendTestResult("Single thread slice", analysisEl); 86 } 87 88 function testAnalyzeMultipleNonNestedSlices() { 89 var events = [ 90 {name: 'a', args: {}, pid: 52, ts: 520, cat: 'foo', tid: 53, ph: 'B'}, 91 {name: 'a', args: {}, pid: 52, ts: 560, cat: 'foo', tid: 53, ph: 'E'}, 92 {name: 'aa', args: {}, pid: 52, ts: 640, cat: 'foo', tid: 53, ph: 'B'}, 93 {name: 'aa', args: {}, pid: 52, ts: 700, cat: 'foo', tid: 53, ph: 'E'}, 94 ]; 95 var model = new tracing.TimelineModel(); 96 model.importEvents(events); 97 98 var t53track = new tracing.TimelineThreadTrack(); 99 t53track.thread = model.processes[52].threads[53]; 100 101 var selection = new tracing.TimelineSelection(); 102 t53track.addAllObjectsMatchingFilterToSelection( 103 new tracing.TimelineFilter('a'), selection); 104 assertEquals(2, selection.length); 105 106 var analysisEl = new tracing.TimelineAnalysisView(); 107 analysisEl.selection = selection; 108 109 appendTestResult("Multiple non nested thread slices", analysisEl); 110 } 111 112 </script> 113 </body> 114 </html> 115