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> 9 <title>LinuxPerfImporter tests</title> 10 <script src= 11 "http://closure-library.googlecode.com/svn/trunk/closure/goog/base.js"> 12 </script> 13 <script src="../shared/js/cr.js"></script> 14 <script src="../shared/js/cr/event_target.js"></script> 15 <script src="test_utils.js"></script> 16 <script src="timeline_model.js"></script> 17 <script src="linux_perf_importer.js"></script> 18 <script> 19 goog.require('goog.testing.jsunit'); 20 </script> 21 22 </head> 23 <body> 24 <script> 25 function testLineRE() { 26 var re = tracing._LinuxPerfImporterTestExports.lineRE; 27 var x = re.exec(' <idle>-0 [001] 4467.843475: sched_switch: ' + 28 'prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ==> ' + 29 'next_comm=SurfaceFlinger next_pid=178 next_prio=112'); 30 assertNotNull(x); 31 assertEquals('<idle>-0', x[1]); 32 assertEquals('001', x[2]); 33 assertEquals(undefined, x[3]); 34 assertEquals('4467.843475', x[4]); 35 assertEquals('sched_switch', x[5]); 36 assertEquals('prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ==> ' + 37 'next_comm=SurfaceFlinger next_pid=178 next_prio=112', x[6]); 38 39 var x = re.exec('Binder Thread #-647 [001] 260.464294: sched_switch: ' + 40 'prev_comm=Binder Thread # prev_pid=647 prev_prio=120 prev_state=D ==> ' + 41 'next_comm=.android.chrome next_pid=1562 next_prio=120'); 42 assertNotNull(x); 43 } 44 45 function testSchedSwitchRE() { 46 var re = tracing._LinuxPerfImporterTestExports.eventDefinitions['sched_switch'].format; 47 var x = re.exec('prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ' + 48 '==> next_comm=SurfaceFlinger next_pid=178 next_prio=112'); 49 assertNotNull(x); 50 assertEquals('swapper', x[1]); 51 assertEquals('0', x[2]); 52 assertEquals('120', x[3]); 53 assertEquals('R', x[4]); 54 assertEquals('SurfaceFlinger', x[5]); 55 assertEquals('178', x[6]); 56 assertEquals('112', x[7]); 57 58 var x = re.exec('prev_comm=.android.chrome prev_pid=1562 prev_prio=120 ' + 59 'prev_state=R ==> next_comm=Binder Thread # next_pid=195 next_prio=120'); 60 assertNotNull(x); 61 assertEquals('.android.chrome', x[1]); 62 assertEquals('Binder Thread #', x[5]); 63 64 var x = re.exec('prev_comm=Binder Thread # prev_pid=1562 prev_prio=120 ' + 65 'prev_state=R ==> next_comm=.android.chrome next_pid=195 next_prio=120'); 66 assertNotNull(x); 67 assertEquals('Binder Thread #', x[1]); 68 assertEquals('.android.chrome', x[5]); 69 } 70 71 function testSchedWakeupRE() { 72 var re = tracing._LinuxPerfImporterTestExports.eventDefinitions['sched_wakeup'].format; 73 var x = re.exec( 74 'comm=SensorService pid=207 prio=112 success=1 target_cpu=000'); 75 assertNotNull(x); 76 assertEquals('SensorService', x[1]); 77 assertEquals('207', x[2]); 78 assertEquals('112', x[3]); 79 assertEquals('1', x[4]); 80 assertEquals('000', x[5]); 81 } 82 83 function testTraceEventClockSyncRE() { 84 var re = tracing._LinuxPerfImporterTestExports.traceEventClockSyncRE; 85 var x = re.exec('trace_event_clock_sync: parent_ts=19581477508'); 86 assertNotNull(x); 87 assertEquals('19581477508', x[1]); 88 89 var x = re.exec('trace_event_clock_sync: parent_ts=123.456'); 90 assertNotNull(x); 91 assertEquals('123.456', x[1]); 92 } 93 94 function testCanImport() { 95 var lines = [ 96 '# tracer: nop', 97 '#', 98 '# TASK-PID CPU# TIMESTAMP FUNCTION', 99 '# | | | | |', 100 ' <idle>-0 [001] 4467.843475: sched_switch: ' + 101 'prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ==> ' + 102 'next_comm=SurfaceFlinger next_pid=178 next_prio=112', 103 104 ' SurfaceFlinger-178 [001] 4467.843536: sched_switch: ' + 105 'prev_comm=SurfaceFlinger prev_pid=178 prev_prio=112 prev_state=S ' + 106 '==> next_comm=kworker/u:2 next_pid=2844 next_prio=120', 107 108 ' kworker/u:2-2844 [001] 4467.843567: sched_switch: ' + 109 'prev_comm=kworker/u:2 prev_pid=2844 prev_prio=120 prev_state=S ' + 110 '==> next_comm=swapper next_pid=0 next_prio=120', 111 112 ' <idle>-0 [001] 4467.844208: sched_switch: ' + 113 'prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ==> ' + 114 'next_comm=kworker/u:2 next_pid=2844 next_prio=120' 115 ]; 116 assertTrue(tracing.LinuxPerfImporter.canImport(lines.join('\n'))); 117 118 var lines = [ 119 ' <idle>-0 [001] 4467.843475: sched_switch: ' + 120 'prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ==> ' + 121 'next_comm=SurfaceFlinger next_pid=178 next_prio=112' 122 ]; 123 assertTrue(tracing.LinuxPerfImporter.canImport(lines.join('\n'))); 124 125 var lines = [ 126 ' <idle>-0 [001] 4467.843475: sched_switch: ' + 127 'prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ==> ' + 128 'next_comm=SurfaceFlinger next_pid=178 next_prio=112', 129 130 ' SurfaceFlinger-178 [001] 4467.843536: sched_switch: ' + 131 'prev_comm=SurfaceFlinger prev_pid=178 prev_prio=112 ' + 132 'prev_state=S ==> next_comm=kworker/u:2 next_pid=2844 ' + 133 'next_prio=120' 134 ]; 135 assertTrue(tracing.LinuxPerfImporter.canImport(lines.join('\n'))); 136 137 var lines = [ 138 'SomeRandomText', 139 'More random text' 140 ]; 141 assertFalse(tracing.LinuxPerfImporter.canImport(lines.join('\n'))); 142 } 143 144 function testImportOneSequence() { 145 var lines = [ 146 ' <idle>-0 [001] 4467.843475: sched_switch: ' + 147 'prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ==> ' + 148 'next_comm=SurfaceFlinger next_pid=178 next_prio=112', 149 150 ' SurfaceFlinger-178 [001] 4467.843536: sched_switch: ' + 151 'prev_comm=SurfaceFlinger prev_pid=178 prev_prio=112 ' + 152 'prev_state=S ==> next_comm=kworker/u:2 next_pid=2844 ' + 153 'next_prio=120', 154 155 ' kworker/u:2-2844 [001] 4467.843567: sched_switch: ' + 156 'prev_comm=kworker/u:2 prev_pid=2844 prev_prio=120 ' + 157 'prev_state=S ==> next_comm=swapper next_pid=0 next_prio=120' 158 ]; 159 var m = new tracing.TimelineModel(lines.join('\n'), false); 160 assertEquals(0, m.importErrors.length); 161 162 var c = m.cpus[1]; 163 assertEquals(2, c.slices.length); 164 165 assertEquals('SurfaceFlinger', c.slices[0].title); 166 assertEquals(4467843.475, c.slices[0].start); 167 assertAlmostEquals(.536 - .475, c.slices[0].duration); 168 } 169 170 function testImportOneSequenceWithSchedWakeUp() { 171 // TODO(nduca): write test for this. 172 } 173 174 function testImportWithNewline() { 175 var lines = [ 176 '' 177 ]; 178 var m = new tracing.TimelineModel(lines.join('\n')); 179 assertEquals(0, m.importErrors.length); 180 } 181 182 function testClockSync() { 183 var lines = [ 184 ' <idle>-0 [001] 4467.843475: sched_switch: ' + 185 'prev_comm=swapper prev_pid=0 prev_prio=120 prev_state=R ' + 186 '==> next_comm=SurfaceFlinger next_pid=178 next_prio=112', 187 ' SurfaceFlinger-178 [001] 4467.843536: sched_switch: ' + 188 'prev_comm=SurfaceFlinger prev_pid=178 prev_prio=112 ' + 189 'prev_state=S ==> next_comm=kworker/u:2 next_pid=2844 ' + 190 'next_prio=120', 191 ' kworker/u:2-2844 [001] 4467.843567: sched_switch: ' + 192 'prev_comm=kworker/u:2 prev_pid=2844 prev_prio=120 ' + 193 'prev_state=S ==> next_comm=swapper next_pid=0 ' + 194 'next_prio=120', 195 ' kworker/u:2-2844 [001] 4467.843000: 0: ' + 196 'trace_event_clock_sync: parent_ts=0.1' 197 ]; 198 var m = new tracing.TimelineModel(lines.join('\n'), false); 199 assertEquals(0, m.importErrors.length); 200 201 var c = m.cpus[1]; 202 assertEquals(2, c.slices.length); 203 204 assertAlmostEquals((467.843475 - (467.843 - 0.1)) * 1000, c.slices[0].start); 205 } 206 207 function testClockSyncMarkWrite() { 208 var lines = [ 209 'systrace.sh-8170 [001] 15180.978813: sched_switch: ' + 210 'prev_comm=systrace.sh prev_pid=8170 prev_prio=120 ' + 211 'prev_state=x ==> next_comm=kworker/1:0 next_pid=7873 ' + 212 'next_prio=120', 213 ' kworker/1:0-7873 [001] 15180.978836: sched_switch: ' + 214 'prev_comm=kworker/1:0 prev_pid=7873 prev_prio=120 ' + 215 'prev_state=S ==> next_comm=debugd next_pid=4404 next_prio=120', 216 ' debugd-4404 [001] 15180.979010: sched_switch: prev_comm=debugd ' + 217 'prev_pid=4404 prev_prio=120 prev_state=S ==> ' + 218 'next_comm=dbus-daemon next_pid=510 next_prio=120', 219 'systrace.sh-8182 [000] 15186.203900: tracing_mark_write: ' + 220 'trace_event_clock_sync: parent_ts=0' 221 ]; 222 var m = new tracing.TimelineModel(lines.join('\n'), false); 223 assertEquals(0, m.importErrors.length); 224 225 var c = m.cpus[1]; 226 assertEquals(2, c.slices.length); 227 228 assertAlmostEquals((15180.978813 - 0) * 1000, c.slices[0].start); 229 } 230 231 232 function testImportWithoutClockSyncDeletesEverything() { 233 } 234 235 function testWorkQueueImport() { 236 var lines = [ 237 ' kworker/0:3-6880 [000] 2784.771958: workqueue_execute_start: ' + 238 'work struct ffff8800a5083a20: function intel_unpin_work_fn', 239 ' kworker/0:3-6880 [000] 2784.771966: workqueue_execute_end: ' + 240 'work struct ffff8800a5083a20', 241 ' kworker/1:2-7269 [001] 2784.805966: workqueue_execute_start: ' + 242 'work struct ffff88014fb0f158: function do_dbs_timer', 243 ' kworker/1:2-7269 [001] 2784.805975: workqueue_execute_end: ' + 244 'work struct ffff88014fb0f158' 245 ]; 246 var m = new tracing.TimelineModel(lines.join('\n'), false); 247 assertEquals(0, m.importErrors.length); 248 249 assertEquals(1, m.processes['6880'].threads['6880'].subRows.length); 250 assertEquals(1, m.processes['7269'].threads['7269'].subRows.length); 251 } 252 253 function testPowerStartImport() { 254 } 255 256 function testPowerFrequencyImport() { 257 var lines = [ 258 ' kworker/0:3-6880 [000] 2784.783015: power_frequency: ' + 259 'type=2 state=1000000 cpu_id=0', 260 ' kworker/1:2-7269 [001] 2784.788993: power_frequency: ' + 261 'type=2 state=800000 cpu_id=1', 262 ' kworker/1:2-7269 [001] 2784.993120: power_frequency: ' + 263 'type=2 state=1300000 cpu_id=1' 264 ]; 265 var m = new tracing.TimelineModel(lines.join('\n'), false); 266 assertEquals(0, m.importErrors.length); 267 268 var c0 = m.cpus[0]; 269 assertEquals(0, c0.slices.length); 270 assertEquals(1, c0.counters['Power Frequency'].samples.length); 271 272 var c1 = m.cpus[1]; 273 assertEquals(0, c1.slices.length); 274 assertEquals(2, c1.counters['Power Frequency'].samples.length); 275 } 276 277 function testCpuFrequencyImport() { 278 var lines = [ 279 ' kworker/1:0-9665 [001] 15051.007301: cpu_frequency: ' + 280 'state=800000 cpu_id=1', 281 ' kworker/1:0-9665 [001] 15051.010278: cpu_frequency: ' + 282 'state=1300000 cpu_id=1', 283 ' kworker/0:2-7972 [000] 15051.010278: cpu_frequency: ' + 284 'state=1000000 cpu_id=0', 285 ' kworker/0:2-7972 [000] 15051.020304: cpu_frequency: ' + 286 'state=800000 cpu_id=0' 287 ]; 288 var m = new tracing.TimelineModel(lines.join('\n'), false); 289 assertEquals(0, m.importErrors.length); 290 291 var c0 = m.cpus[0]; 292 assertEquals(0, c0.slices.length); 293 assertEquals(2, c0.counters['Clock Frequency'].samples.length); 294 295 var c1 = m.cpus[1]; 296 assertEquals(0, c1.slices.length); 297 assertEquals(2, c1.counters['Clock Frequency'].samples.length); 298 } 299 300 function testCpuIdleImport() { 301 var lines = [ 302 ' <idle>-0 [000] 15050.992883: cpu_idle: ' + 303 'state=1 cpu_id=0', 304 ' <idle>-0 [000] 15050.993027: cpu_idle: ' + 305 'state=4294967295 cpu_id=0', 306 ' <idle>-0 [001] 15050.993132: cpu_idle: ' + 307 'state=1 cpu_id=1', 308 ' <idle>-0 [001] 15050.993276: cpu_idle: ' + 309 'state=4294967295 cpu_id=1', 310 ' <idle>-0 [001] 15050.993279: cpu_idle: ' + 311 'state=3 cpu_id=1', 312 ' <idle>-0 [001] 15050.993457: cpu_idle: ' + 313 'state=4294967295 cpu_id=1', 314 ]; 315 var m = new tracing.TimelineModel(lines.join('\n'), false); 316 assertEquals(0, m.importErrors.length); 317 318 var c0 = m.cpus[0]; 319 assertEquals(0, c0.slices.length); 320 assertEquals(2, c0.counters['C-State'].samples.length); 321 322 var c1 = m.cpus[1]; 323 assertEquals(0, c1.slices.length); 324 assertEquals(4, c1.counters['C-State'].samples.length); 325 } 326 327 function testi915Import() { 328 var lines = [ 329 ' chrome-1223 [000] 2784.773556: i915_gem_object_pwrite: ' + 330 'obj=ffff88013f13fc00, offset=0, len=2984', 331 ' X-964 [000] 2784.774864: i915_flip_request: ' + 332 'plane=0, obj=ffff88013f0b9a00', 333 ' <idle>-0 [000] 2784.788644: i915_flip_complete: ' + 334 'plane=0, obj=ffff88013f0b9a00' 335 ]; 336 var m = new tracing.TimelineModel(lines.join('\n'), false); 337 assertEquals(0, m.importErrors.length); 338 339 assertEquals('i915_gem', m.processes['0'].threads['1'].name); 340 assertEquals(1, m.processes['0'].threads['1'].subRows.length); 341 342 assertEquals('i915_flip', m.processes['0'].threads['2'].name); 343 assertEquals(1, m.processes['0'].threads['1'].subRows.length); 344 345 assertAlmostEquals(2784.774864 * 1000.0, 346 m.processes['0'].threads['2'].subRows[0][0].start); 347 assertAlmostEquals((2784.788644 - 2784.774864) * 1000.0, 348 m.processes['0'].threads['2'].subRows[0][0].duration); 349 } 350 351 </script> 352 </body> 353 </html> 354