1[ 2 { 3 "cmd": [ 4 "python", 5 "-u", 6 "import os\nprint os.environ.get('SWARMING_BOT_ID', '')\n" 7 ], 8 "name": "get swarming bot id", 9 "stdout": "/path/to/tmp/", 10 "~followup_annotations": [ 11 "@@@STEP_LOG_LINE@python.inline@import os@@@", 12 "@@@STEP_LOG_LINE@python.inline@print os.environ.get('SWARMING_BOT_ID', '')@@@", 13 "@@@STEP_LOG_END@python.inline@@@" 14 ] 15 }, 16 { 17 "cmd": [ 18 "/opt/infra-android/tools/adb", 19 "push", 20 "file.txt", 21 "file.txt" 22 ], 23 "cwd": "[START_DIR]/skia", 24 "env": { 25 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 26 "CHROME_HEADLESS": "1", 27 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 28 }, 29 "infra_step": true, 30 "name": "push file.txt file.txt" 31 }, 32 { 33 "cmd": [ 34 "python", 35 "-u", 36 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 37 "--json-output", 38 "/path/to/tmp/json", 39 "rmtree", 40 "results_dir" 41 ], 42 "infra_step": true, 43 "name": "rmtree results_dir" 44 }, 45 { 46 "cmd": [ 47 "python", 48 "-u", 49 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 50 "--json-output", 51 "/path/to/tmp/json", 52 "ensure-directory", 53 "--mode", 54 "0777", 55 "results_dir" 56 ], 57 "infra_step": true, 58 "name": "makedirs results_dir" 59 }, 60 { 61 "cmd": [ 62 "/opt/infra-android/tools/adb", 63 "shell", 64 "rm", 65 "-rf", 66 "device_results_dir" 67 ], 68 "cwd": "[START_DIR]/skia", 69 "env": { 70 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 71 "CHROME_HEADLESS": "1", 72 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 73 }, 74 "infra_step": true, 75 "name": "rm device_results_dir" 76 }, 77 { 78 "cmd": [ 79 "/opt/infra-android/tools/adb", 80 "shell", 81 "mkdir", 82 "-p", 83 "device_results_dir" 84 ], 85 "cwd": "[START_DIR]/skia", 86 "env": { 87 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 88 "CHROME_HEADLESS": "1", 89 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 90 }, 91 "infra_step": true, 92 "name": "mkdir device_results_dir" 93 }, 94 { 95 "cmd": [ 96 "/opt/infra-android/tools/adb", 97 "shell", 98 "mkdir", 99 "-p", 100 "/sdcard/revenge_of_the_skiabot/resources" 101 ], 102 "cwd": "[START_DIR]/skia", 103 "env": { 104 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 105 "CHROME_HEADLESS": "1", 106 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 107 }, 108 "infra_step": true, 109 "name": "mkdir /sdcard/revenge_of_the_skiabot/resources" 110 }, 111 { 112 "cmd": [ 113 "python", 114 "-u", 115 "\nimport os\nimport subprocess\nimport sys\nhost = sys.argv[1]\ndevice = sys.argv[2]\nfor d, _, fs in os.walk(host):\n p = os.path.relpath(d, host)\n if p != '.' and p.startswith('.'):\n continue\n for f in fs:\n print os.path.join(p,f)\n subprocess.check_call(['/opt/infra-android/tools/adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n", 116 "[START_DIR]/skia/resources", 117 "/sdcard/revenge_of_the_skiabot/resources" 118 ], 119 "env": { 120 "CHROME_HEADLESS": "1", 121 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 122 }, 123 "infra_step": true, 124 "name": "push [START_DIR]/skia/resources/* /sdcard/revenge_of_the_skiabot/resources", 125 "~followup_annotations": [ 126 "@@@STEP_LOG_LINE@python.inline@@@@", 127 "@@@STEP_LOG_LINE@python.inline@import os@@@", 128 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 129 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 130 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@", 131 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@", 132 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@", 133 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@", 134 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@", 135 "@@@STEP_LOG_LINE@python.inline@ continue@@@", 136 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@", 137 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@", 138 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['/opt/infra-android/tools/adb', 'push',@@@", 139 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@", 140 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@", 141 "@@@STEP_LOG_END@python.inline@@@" 142 ] 143 }, 144 { 145 "cmd": [ 146 "python", 147 "-u", 148 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 149 "--json-output", 150 "/path/to/tmp/json", 151 "copy", 152 "[START_DIR]/skia/infra/bots/assets/skp/VERSION", 153 "/path/to/tmp/" 154 ], 155 "infra_step": true, 156 "name": "Get skp VERSION" 157 }, 158 { 159 "cmd": [ 160 "python", 161 "-u", 162 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 163 "--json-output", 164 "/path/to/tmp/json", 165 "copy", 166 "42", 167 "[START_DIR]/tmp/SKP_VERSION" 168 ], 169 "infra_step": true, 170 "name": "write SKP_VERSION" 171 }, 172 { 173 "cmd": [ 174 "/opt/infra-android/tools/adb", 175 "shell", 176 "cat", 177 "/sdcard/revenge_of_the_skiabot/SKP_VERSION" 178 ], 179 "cwd": "[START_DIR]/skia", 180 "env": { 181 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 182 "CHROME_HEADLESS": "1", 183 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 184 }, 185 "infra_step": true, 186 "name": "read /sdcard/revenge_of_the_skiabot/SKP_VERSION", 187 "stdout": "/path/to/tmp/" 188 }, 189 { 190 "cmd": [ 191 "/opt/infra-android/tools/adb", 192 "shell", 193 "rm", 194 "-f", 195 "/sdcard/revenge_of_the_skiabot/SKP_VERSION" 196 ], 197 "cwd": "[START_DIR]/skia", 198 "env": { 199 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 200 "CHROME_HEADLESS": "1", 201 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 202 }, 203 "infra_step": true, 204 "name": "rm /sdcard/revenge_of_the_skiabot/SKP_VERSION" 205 }, 206 { 207 "cmd": [ 208 "/opt/infra-android/tools/adb", 209 "shell", 210 "rm", 211 "-rf", 212 "/sdcard/revenge_of_the_skiabot/skps" 213 ], 214 "cwd": "[START_DIR]/skia", 215 "env": { 216 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 217 "CHROME_HEADLESS": "1", 218 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 219 }, 220 "infra_step": true, 221 "name": "rm /sdcard/revenge_of_the_skiabot/skps" 222 }, 223 { 224 "cmd": [ 225 "/opt/infra-android/tools/adb", 226 "shell", 227 "mkdir", 228 "-p", 229 "/sdcard/revenge_of_the_skiabot/skps" 230 ], 231 "cwd": "[START_DIR]/skia", 232 "env": { 233 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 234 "CHROME_HEADLESS": "1", 235 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 236 }, 237 "infra_step": true, 238 "name": "mkdir /sdcard/revenge_of_the_skiabot/skps" 239 }, 240 { 241 "cmd": [ 242 "python", 243 "-u", 244 "\nimport os\nimport subprocess\nimport sys\nhost = sys.argv[1]\ndevice = sys.argv[2]\nfor d, _, fs in os.walk(host):\n p = os.path.relpath(d, host)\n if p != '.' and p.startswith('.'):\n continue\n for f in fs:\n print os.path.join(p,f)\n subprocess.check_call(['/opt/infra-android/tools/adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n", 245 "[START_DIR]/skp", 246 "/sdcard/revenge_of_the_skiabot/skps" 247 ], 248 "env": { 249 "CHROME_HEADLESS": "1", 250 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 251 }, 252 "infra_step": true, 253 "name": "push [START_DIR]/skp/* /sdcard/revenge_of_the_skiabot/skps", 254 "~followup_annotations": [ 255 "@@@STEP_LOG_LINE@python.inline@@@@", 256 "@@@STEP_LOG_LINE@python.inline@import os@@@", 257 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 258 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 259 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@", 260 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@", 261 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@", 262 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@", 263 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@", 264 "@@@STEP_LOG_LINE@python.inline@ continue@@@", 265 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@", 266 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@", 267 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['/opt/infra-android/tools/adb', 'push',@@@", 268 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@", 269 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@", 270 "@@@STEP_LOG_END@python.inline@@@" 271 ] 272 }, 273 { 274 "cmd": [ 275 "/opt/infra-android/tools/adb", 276 "push", 277 "[START_DIR]/tmp/SKP_VERSION", 278 "/sdcard/revenge_of_the_skiabot/SKP_VERSION" 279 ], 280 "cwd": "[START_DIR]/skia", 281 "env": { 282 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 283 "CHROME_HEADLESS": "1", 284 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 285 }, 286 "infra_step": true, 287 "name": "push [START_DIR]/tmp/SKP_VERSION /sdcard/revenge_of_the_skiabot/SKP_VERSION" 288 }, 289 { 290 "cmd": [ 291 "python", 292 "-u", 293 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 294 "--json-output", 295 "/path/to/tmp/json", 296 "copy", 297 "[START_DIR]/skia/infra/bots/assets/skimage/VERSION", 298 "/path/to/tmp/" 299 ], 300 "infra_step": true, 301 "name": "Get skimage VERSION" 302 }, 303 { 304 "cmd": [ 305 "python", 306 "-u", 307 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 308 "--json-output", 309 "/path/to/tmp/json", 310 "copy", 311 "42", 312 "[START_DIR]/tmp/SK_IMAGE_VERSION" 313 ], 314 "infra_step": true, 315 "name": "write SK_IMAGE_VERSION" 316 }, 317 { 318 "cmd": [ 319 "/opt/infra-android/tools/adb", 320 "shell", 321 "cat", 322 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 323 ], 324 "cwd": "[START_DIR]/skia", 325 "env": { 326 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 327 "CHROME_HEADLESS": "1", 328 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 329 }, 330 "infra_step": true, 331 "name": "read /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION", 332 "stdout": "/path/to/tmp/" 333 }, 334 { 335 "cmd": [ 336 "/opt/infra-android/tools/adb", 337 "shell", 338 "rm", 339 "-f", 340 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 341 ], 342 "cwd": "[START_DIR]/skia", 343 "env": { 344 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 345 "CHROME_HEADLESS": "1", 346 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 347 }, 348 "infra_step": true, 349 "name": "rm /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 350 }, 351 { 352 "cmd": [ 353 "/opt/infra-android/tools/adb", 354 "shell", 355 "rm", 356 "-rf", 357 "/sdcard/revenge_of_the_skiabot/images" 358 ], 359 "cwd": "[START_DIR]/skia", 360 "env": { 361 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 362 "CHROME_HEADLESS": "1", 363 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 364 }, 365 "infra_step": true, 366 "name": "rm /sdcard/revenge_of_the_skiabot/images" 367 }, 368 { 369 "cmd": [ 370 "/opt/infra-android/tools/adb", 371 "shell", 372 "mkdir", 373 "-p", 374 "/sdcard/revenge_of_the_skiabot/images" 375 ], 376 "cwd": "[START_DIR]/skia", 377 "env": { 378 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 379 "CHROME_HEADLESS": "1", 380 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 381 }, 382 "infra_step": true, 383 "name": "mkdir /sdcard/revenge_of_the_skiabot/images" 384 }, 385 { 386 "cmd": [ 387 "python", 388 "-u", 389 "\nimport os\nimport subprocess\nimport sys\nhost = sys.argv[1]\ndevice = sys.argv[2]\nfor d, _, fs in os.walk(host):\n p = os.path.relpath(d, host)\n if p != '.' and p.startswith('.'):\n continue\n for f in fs:\n print os.path.join(p,f)\n subprocess.check_call(['/opt/infra-android/tools/adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n", 390 "[START_DIR]/skimage", 391 "/sdcard/revenge_of_the_skiabot/images" 392 ], 393 "env": { 394 "CHROME_HEADLESS": "1", 395 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 396 }, 397 "infra_step": true, 398 "name": "push [START_DIR]/skimage/* /sdcard/revenge_of_the_skiabot/images", 399 "~followup_annotations": [ 400 "@@@STEP_LOG_LINE@python.inline@@@@", 401 "@@@STEP_LOG_LINE@python.inline@import os@@@", 402 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 403 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 404 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@", 405 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@", 406 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@", 407 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@", 408 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@", 409 "@@@STEP_LOG_LINE@python.inline@ continue@@@", 410 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@", 411 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@", 412 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['/opt/infra-android/tools/adb', 'push',@@@", 413 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@", 414 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@", 415 "@@@STEP_LOG_END@python.inline@@@" 416 ] 417 }, 418 { 419 "cmd": [ 420 "/opt/infra-android/tools/adb", 421 "push", 422 "[START_DIR]/tmp/SK_IMAGE_VERSION", 423 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 424 ], 425 "cwd": "[START_DIR]/skia", 426 "env": { 427 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 428 "CHROME_HEADLESS": "1", 429 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 430 }, 431 "infra_step": true, 432 "name": "push [START_DIR]/tmp/SK_IMAGE_VERSION /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 433 }, 434 { 435 "cmd": [ 436 "python", 437 "-u", 438 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 439 "--json-output", 440 "/path/to/tmp/json", 441 "copy", 442 "[START_DIR]/skia/infra/bots/assets/svg/VERSION", 443 "/path/to/tmp/" 444 ], 445 "infra_step": true, 446 "name": "Get svg VERSION" 447 }, 448 { 449 "cmd": [ 450 "python", 451 "-u", 452 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 453 "--json-output", 454 "/path/to/tmp/json", 455 "copy", 456 "42", 457 "[START_DIR]/tmp/SVG_VERSION" 458 ], 459 "infra_step": true, 460 "name": "write SVG_VERSION" 461 }, 462 { 463 "cmd": [ 464 "/opt/infra-android/tools/adb", 465 "shell", 466 "cat", 467 "/sdcard/revenge_of_the_skiabot/SVG_VERSION" 468 ], 469 "cwd": "[START_DIR]/skia", 470 "env": { 471 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 472 "CHROME_HEADLESS": "1", 473 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 474 }, 475 "infra_step": true, 476 "name": "read /sdcard/revenge_of_the_skiabot/SVG_VERSION", 477 "stdout": "/path/to/tmp/" 478 }, 479 { 480 "cmd": [ 481 "/opt/infra-android/tools/adb", 482 "shell", 483 "rm", 484 "-f", 485 "/sdcard/revenge_of_the_skiabot/SVG_VERSION" 486 ], 487 "cwd": "[START_DIR]/skia", 488 "env": { 489 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 490 "CHROME_HEADLESS": "1", 491 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 492 }, 493 "infra_step": true, 494 "name": "rm /sdcard/revenge_of_the_skiabot/SVG_VERSION" 495 }, 496 { 497 "cmd": [ 498 "/opt/infra-android/tools/adb", 499 "shell", 500 "rm", 501 "-rf", 502 "/sdcard/revenge_of_the_skiabot/svgs" 503 ], 504 "cwd": "[START_DIR]/skia", 505 "env": { 506 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 507 "CHROME_HEADLESS": "1", 508 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 509 }, 510 "infra_step": true, 511 "name": "rm /sdcard/revenge_of_the_skiabot/svgs" 512 }, 513 { 514 "cmd": [ 515 "/opt/infra-android/tools/adb", 516 "shell", 517 "mkdir", 518 "-p", 519 "/sdcard/revenge_of_the_skiabot/svgs" 520 ], 521 "cwd": "[START_DIR]/skia", 522 "env": { 523 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 524 "CHROME_HEADLESS": "1", 525 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 526 }, 527 "infra_step": true, 528 "name": "mkdir /sdcard/revenge_of_the_skiabot/svgs" 529 }, 530 { 531 "cmd": [ 532 "python", 533 "-u", 534 "\nimport os\nimport subprocess\nimport sys\nhost = sys.argv[1]\ndevice = sys.argv[2]\nfor d, _, fs in os.walk(host):\n p = os.path.relpath(d, host)\n if p != '.' and p.startswith('.'):\n continue\n for f in fs:\n print os.path.join(p,f)\n subprocess.check_call(['/opt/infra-android/tools/adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n", 535 "[START_DIR]/svg", 536 "/sdcard/revenge_of_the_skiabot/svgs" 537 ], 538 "env": { 539 "CHROME_HEADLESS": "1", 540 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 541 }, 542 "infra_step": true, 543 "name": "push [START_DIR]/svg/* /sdcard/revenge_of_the_skiabot/svgs", 544 "~followup_annotations": [ 545 "@@@STEP_LOG_LINE@python.inline@@@@", 546 "@@@STEP_LOG_LINE@python.inline@import os@@@", 547 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 548 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 549 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@", 550 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@", 551 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@", 552 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@", 553 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@", 554 "@@@STEP_LOG_LINE@python.inline@ continue@@@", 555 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@", 556 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@", 557 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['/opt/infra-android/tools/adb', 'push',@@@", 558 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@", 559 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@", 560 "@@@STEP_LOG_END@python.inline@@@" 561 ] 562 }, 563 { 564 "cmd": [ 565 "/opt/infra-android/tools/adb", 566 "push", 567 "[START_DIR]/tmp/SVG_VERSION", 568 "/sdcard/revenge_of_the_skiabot/SVG_VERSION" 569 ], 570 "cwd": "[START_DIR]/skia", 571 "env": { 572 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 573 "CHROME_HEADLESS": "1", 574 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 575 }, 576 "infra_step": true, 577 "name": "push [START_DIR]/tmp/SVG_VERSION /sdcard/revenge_of_the_skiabot/SVG_VERSION" 578 }, 579 { 580 "cmd": [ 581 "python", 582 "-u", 583 "\nimport os\nimport subprocess\nimport sys\nimport time\nADB = sys.argv[1]\ncpu = int(sys.argv[2])\nvalue = int(sys.argv[3])\n\nlog = subprocess.check_output([ADB, 'root'])\n# check for message like 'adbd cannot run as root in production builds'\nprint log\nif 'cannot' in log:\n raise Exception('adb root failed')\n\n# If we try to echo 1 to an already online cpu, adb returns exit code 1.\n# So, check the value before trying to write it.\nprior_status = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()\nif prior_status == str(value):\n print 'CPU %d online already %d' % (cpu, value)\n sys.exit()\n\nsubprocess.check_output([ADB, 'shell', 'echo %s > '\n '/sys/devices/system/cpu/cpu%d/online' % (value, cpu)])\nactual_status = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()\nif actual_status != str(value):\n raise Exception('(actual, expected) (%s, %d)'\n % (actual_status, value))\n", 584 "/opt/infra-android/tools/adb", 585 "0", 586 "1" 587 ], 588 "env": { 589 "CHROME_HEADLESS": "1", 590 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 591 }, 592 "infra_step": true, 593 "name": "Enabling CPU 0", 594 "timeout": 30, 595 "~followup_annotations": [ 596 "@@@STEP_LOG_LINE@python.inline@@@@", 597 "@@@STEP_LOG_LINE@python.inline@import os@@@", 598 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 599 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 600 "@@@STEP_LOG_LINE@python.inline@import time@@@", 601 "@@@STEP_LOG_LINE@python.inline@ADB = sys.argv[1]@@@", 602 "@@@STEP_LOG_LINE@python.inline@cpu = int(sys.argv[2])@@@", 603 "@@@STEP_LOG_LINE@python.inline@value = int(sys.argv[3])@@@", 604 "@@@STEP_LOG_LINE@python.inline@@@@", 605 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output([ADB, 'root'])@@@", 606 "@@@STEP_LOG_LINE@python.inline@# check for message like 'adbd cannot run as root in production builds'@@@", 607 "@@@STEP_LOG_LINE@python.inline@print log@@@", 608 "@@@STEP_LOG_LINE@python.inline@if 'cannot' in log:@@@", 609 "@@@STEP_LOG_LINE@python.inline@ raise Exception('adb root failed')@@@", 610 "@@@STEP_LOG_LINE@python.inline@@@@", 611 "@@@STEP_LOG_LINE@python.inline@# If we try to echo 1 to an already online cpu, adb returns exit code 1.@@@", 612 "@@@STEP_LOG_LINE@python.inline@# So, check the value before trying to write it.@@@", 613 "@@@STEP_LOG_LINE@python.inline@prior_status = subprocess.check_output([ADB, 'shell', 'cat '@@@", 614 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()@@@", 615 "@@@STEP_LOG_LINE@python.inline@if prior_status == str(value):@@@", 616 "@@@STEP_LOG_LINE@python.inline@ print 'CPU %d online already %d' % (cpu, value)@@@", 617 "@@@STEP_LOG_LINE@python.inline@ sys.exit()@@@", 618 "@@@STEP_LOG_LINE@python.inline@@@@", 619 "@@@STEP_LOG_LINE@python.inline@subprocess.check_output([ADB, 'shell', 'echo %s > '@@@", 620 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % (value, cpu)])@@@", 621 "@@@STEP_LOG_LINE@python.inline@actual_status = subprocess.check_output([ADB, 'shell', 'cat '@@@", 622 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()@@@", 623 "@@@STEP_LOG_LINE@python.inline@if actual_status != str(value):@@@", 624 "@@@STEP_LOG_LINE@python.inline@ raise Exception('(actual, expected) (%s, %d)'@@@", 625 "@@@STEP_LOG_LINE@python.inline@ % (actual_status, value))@@@", 626 "@@@STEP_LOG_END@python.inline@@@" 627 ] 628 }, 629 { 630 "cmd": [ 631 "python", 632 "-u", 633 "\nimport os\nimport subprocess\nimport sys\nimport time\nADB = sys.argv[1]\ncpu = int(sys.argv[2])\nvalue = int(sys.argv[3])\n\nlog = subprocess.check_output([ADB, 'root'])\n# check for message like 'adbd cannot run as root in production builds'\nprint log\nif 'cannot' in log:\n raise Exception('adb root failed')\n\n# If we try to echo 1 to an already online cpu, adb returns exit code 1.\n# So, check the value before trying to write it.\nprior_status = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()\nif prior_status == str(value):\n print 'CPU %d online already %d' % (cpu, value)\n sys.exit()\n\nsubprocess.check_output([ADB, 'shell', 'echo %s > '\n '/sys/devices/system/cpu/cpu%d/online' % (value, cpu)])\nactual_status = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()\nif actual_status != str(value):\n raise Exception('(actual, expected) (%s, %d)'\n % (actual_status, value))\n", 634 "/opt/infra-android/tools/adb", 635 "1", 636 "1" 637 ], 638 "env": { 639 "CHROME_HEADLESS": "1", 640 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 641 }, 642 "infra_step": true, 643 "name": "Enabling CPU 1", 644 "timeout": 30, 645 "~followup_annotations": [ 646 "@@@STEP_LOG_LINE@python.inline@@@@", 647 "@@@STEP_LOG_LINE@python.inline@import os@@@", 648 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 649 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 650 "@@@STEP_LOG_LINE@python.inline@import time@@@", 651 "@@@STEP_LOG_LINE@python.inline@ADB = sys.argv[1]@@@", 652 "@@@STEP_LOG_LINE@python.inline@cpu = int(sys.argv[2])@@@", 653 "@@@STEP_LOG_LINE@python.inline@value = int(sys.argv[3])@@@", 654 "@@@STEP_LOG_LINE@python.inline@@@@", 655 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output([ADB, 'root'])@@@", 656 "@@@STEP_LOG_LINE@python.inline@# check for message like 'adbd cannot run as root in production builds'@@@", 657 "@@@STEP_LOG_LINE@python.inline@print log@@@", 658 "@@@STEP_LOG_LINE@python.inline@if 'cannot' in log:@@@", 659 "@@@STEP_LOG_LINE@python.inline@ raise Exception('adb root failed')@@@", 660 "@@@STEP_LOG_LINE@python.inline@@@@", 661 "@@@STEP_LOG_LINE@python.inline@# If we try to echo 1 to an already online cpu, adb returns exit code 1.@@@", 662 "@@@STEP_LOG_LINE@python.inline@# So, check the value before trying to write it.@@@", 663 "@@@STEP_LOG_LINE@python.inline@prior_status = subprocess.check_output([ADB, 'shell', 'cat '@@@", 664 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()@@@", 665 "@@@STEP_LOG_LINE@python.inline@if prior_status == str(value):@@@", 666 "@@@STEP_LOG_LINE@python.inline@ print 'CPU %d online already %d' % (cpu, value)@@@", 667 "@@@STEP_LOG_LINE@python.inline@ sys.exit()@@@", 668 "@@@STEP_LOG_LINE@python.inline@@@@", 669 "@@@STEP_LOG_LINE@python.inline@subprocess.check_output([ADB, 'shell', 'echo %s > '@@@", 670 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % (value, cpu)])@@@", 671 "@@@STEP_LOG_LINE@python.inline@actual_status = subprocess.check_output([ADB, 'shell', 'cat '@@@", 672 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()@@@", 673 "@@@STEP_LOG_LINE@python.inline@if actual_status != str(value):@@@", 674 "@@@STEP_LOG_LINE@python.inline@ raise Exception('(actual, expected) (%s, %d)'@@@", 675 "@@@STEP_LOG_LINE@python.inline@ % (actual_status, value))@@@", 676 "@@@STEP_LOG_END@python.inline@@@" 677 ] 678 }, 679 { 680 "cmd": [ 681 "python", 682 "-u", 683 "\nimport os\nimport subprocess\nimport sys\nimport time\nADB = sys.argv[1]\ncpu = int(sys.argv[2])\nvalue = int(sys.argv[3])\n\nlog = subprocess.check_output([ADB, 'root'])\n# check for message like 'adbd cannot run as root in production builds'\nprint log\nif 'cannot' in log:\n raise Exception('adb root failed')\n\n# If we try to echo 1 to an already online cpu, adb returns exit code 1.\n# So, check the value before trying to write it.\nprior_status = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()\nif prior_status == str(value):\n print 'CPU %d online already %d' % (cpu, value)\n sys.exit()\n\nsubprocess.check_output([ADB, 'shell', 'echo %s > '\n '/sys/devices/system/cpu/cpu%d/online' % (value, cpu)])\nactual_status = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()\nif actual_status != str(value):\n raise Exception('(actual, expected) (%s, %d)'\n % (actual_status, value))\n", 684 "/opt/infra-android/tools/adb", 685 "2", 686 "1" 687 ], 688 "env": { 689 "CHROME_HEADLESS": "1", 690 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 691 }, 692 "infra_step": true, 693 "name": "Enabling CPU 2", 694 "timeout": 30, 695 "~followup_annotations": [ 696 "@@@STEP_LOG_LINE@python.inline@@@@", 697 "@@@STEP_LOG_LINE@python.inline@import os@@@", 698 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 699 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 700 "@@@STEP_LOG_LINE@python.inline@import time@@@", 701 "@@@STEP_LOG_LINE@python.inline@ADB = sys.argv[1]@@@", 702 "@@@STEP_LOG_LINE@python.inline@cpu = int(sys.argv[2])@@@", 703 "@@@STEP_LOG_LINE@python.inline@value = int(sys.argv[3])@@@", 704 "@@@STEP_LOG_LINE@python.inline@@@@", 705 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output([ADB, 'root'])@@@", 706 "@@@STEP_LOG_LINE@python.inline@# check for message like 'adbd cannot run as root in production builds'@@@", 707 "@@@STEP_LOG_LINE@python.inline@print log@@@", 708 "@@@STEP_LOG_LINE@python.inline@if 'cannot' in log:@@@", 709 "@@@STEP_LOG_LINE@python.inline@ raise Exception('adb root failed')@@@", 710 "@@@STEP_LOG_LINE@python.inline@@@@", 711 "@@@STEP_LOG_LINE@python.inline@# If we try to echo 1 to an already online cpu, adb returns exit code 1.@@@", 712 "@@@STEP_LOG_LINE@python.inline@# So, check the value before trying to write it.@@@", 713 "@@@STEP_LOG_LINE@python.inline@prior_status = subprocess.check_output([ADB, 'shell', 'cat '@@@", 714 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()@@@", 715 "@@@STEP_LOG_LINE@python.inline@if prior_status == str(value):@@@", 716 "@@@STEP_LOG_LINE@python.inline@ print 'CPU %d online already %d' % (cpu, value)@@@", 717 "@@@STEP_LOG_LINE@python.inline@ sys.exit()@@@", 718 "@@@STEP_LOG_LINE@python.inline@@@@", 719 "@@@STEP_LOG_LINE@python.inline@subprocess.check_output([ADB, 'shell', 'echo %s > '@@@", 720 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % (value, cpu)])@@@", 721 "@@@STEP_LOG_LINE@python.inline@actual_status = subprocess.check_output([ADB, 'shell', 'cat '@@@", 722 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()@@@", 723 "@@@STEP_LOG_LINE@python.inline@if actual_status != str(value):@@@", 724 "@@@STEP_LOG_LINE@python.inline@ raise Exception('(actual, expected) (%s, %d)'@@@", 725 "@@@STEP_LOG_LINE@python.inline@ % (actual_status, value))@@@", 726 "@@@STEP_LOG_END@python.inline@@@" 727 ] 728 }, 729 { 730 "cmd": [ 731 "python", 732 "-u", 733 "\nimport os\nimport subprocess\nimport sys\nimport time\nADB = sys.argv[1]\ncpu = int(sys.argv[2])\nvalue = int(sys.argv[3])\n\nlog = subprocess.check_output([ADB, 'root'])\n# check for message like 'adbd cannot run as root in production builds'\nprint log\nif 'cannot' in log:\n raise Exception('adb root failed')\n\n# If we try to echo 1 to an already online cpu, adb returns exit code 1.\n# So, check the value before trying to write it.\nprior_status = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()\nif prior_status == str(value):\n print 'CPU %d online already %d' % (cpu, value)\n sys.exit()\n\nsubprocess.check_output([ADB, 'shell', 'echo %s > '\n '/sys/devices/system/cpu/cpu%d/online' % (value, cpu)])\nactual_status = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()\nif actual_status != str(value):\n raise Exception('(actual, expected) (%s, %d)'\n % (actual_status, value))\n", 734 "/opt/infra-android/tools/adb", 735 "3", 736 "1" 737 ], 738 "env": { 739 "CHROME_HEADLESS": "1", 740 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 741 }, 742 "infra_step": true, 743 "name": "Enabling CPU 3", 744 "timeout": 30, 745 "~followup_annotations": [ 746 "@@@STEP_LOG_LINE@python.inline@@@@", 747 "@@@STEP_LOG_LINE@python.inline@import os@@@", 748 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 749 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 750 "@@@STEP_LOG_LINE@python.inline@import time@@@", 751 "@@@STEP_LOG_LINE@python.inline@ADB = sys.argv[1]@@@", 752 "@@@STEP_LOG_LINE@python.inline@cpu = int(sys.argv[2])@@@", 753 "@@@STEP_LOG_LINE@python.inline@value = int(sys.argv[3])@@@", 754 "@@@STEP_LOG_LINE@python.inline@@@@", 755 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output([ADB, 'root'])@@@", 756 "@@@STEP_LOG_LINE@python.inline@# check for message like 'adbd cannot run as root in production builds'@@@", 757 "@@@STEP_LOG_LINE@python.inline@print log@@@", 758 "@@@STEP_LOG_LINE@python.inline@if 'cannot' in log:@@@", 759 "@@@STEP_LOG_LINE@python.inline@ raise Exception('adb root failed')@@@", 760 "@@@STEP_LOG_LINE@python.inline@@@@", 761 "@@@STEP_LOG_LINE@python.inline@# If we try to echo 1 to an already online cpu, adb returns exit code 1.@@@", 762 "@@@STEP_LOG_LINE@python.inline@# So, check the value before trying to write it.@@@", 763 "@@@STEP_LOG_LINE@python.inline@prior_status = subprocess.check_output([ADB, 'shell', 'cat '@@@", 764 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()@@@", 765 "@@@STEP_LOG_LINE@python.inline@if prior_status == str(value):@@@", 766 "@@@STEP_LOG_LINE@python.inline@ print 'CPU %d online already %d' % (cpu, value)@@@", 767 "@@@STEP_LOG_LINE@python.inline@ sys.exit()@@@", 768 "@@@STEP_LOG_LINE@python.inline@@@@", 769 "@@@STEP_LOG_LINE@python.inline@subprocess.check_output([ADB, 'shell', 'echo %s > '@@@", 770 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % (value, cpu)])@@@", 771 "@@@STEP_LOG_LINE@python.inline@actual_status = subprocess.check_output([ADB, 'shell', 'cat '@@@", 772 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/online' % cpu]).strip()@@@", 773 "@@@STEP_LOG_LINE@python.inline@if actual_status != str(value):@@@", 774 "@@@STEP_LOG_LINE@python.inline@ raise Exception('(actual, expected) (%s, %d)'@@@", 775 "@@@STEP_LOG_LINE@python.inline@ % (actual_status, value))@@@", 776 "@@@STEP_LOG_END@python.inline@@@" 777 ] 778 }, 779 { 780 "cmd": [ 781 "python", 782 "-u", 783 "\nimport os\nimport subprocess\nimport sys\nimport time\nADB = sys.argv[1]\ncpu = int(sys.argv[2])\ngov = sys.argv[3]\n\nlog = subprocess.check_output([ADB, 'root'])\n# check for message like 'adbd cannot run as root in production builds'\nprint log\nif 'cannot' in log:\n raise Exception('adb root failed')\n\nsubprocess.check_output([ADB, 'shell', 'echo \"%s\" > '\n '/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor' % (gov, cpu)])\nactual_gov = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor' % cpu]).strip()\nif actual_gov != gov:\n raise Exception('(actual, expected) (%s, %s)'\n % (actual_gov, gov))\n", 784 "/opt/infra-android/tools/adb", 785 "4", 786 "ondemand" 787 ], 788 "env": { 789 "CHROME_HEADLESS": "1", 790 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 791 }, 792 "infra_step": true, 793 "name": "Set CPU 4's governor to ondemand", 794 "timeout": 30, 795 "~followup_annotations": [ 796 "@@@STEP_LOG_LINE@python.inline@@@@", 797 "@@@STEP_LOG_LINE@python.inline@import os@@@", 798 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 799 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 800 "@@@STEP_LOG_LINE@python.inline@import time@@@", 801 "@@@STEP_LOG_LINE@python.inline@ADB = sys.argv[1]@@@", 802 "@@@STEP_LOG_LINE@python.inline@cpu = int(sys.argv[2])@@@", 803 "@@@STEP_LOG_LINE@python.inline@gov = sys.argv[3]@@@", 804 "@@@STEP_LOG_LINE@python.inline@@@@", 805 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output([ADB, 'root'])@@@", 806 "@@@STEP_LOG_LINE@python.inline@# check for message like 'adbd cannot run as root in production builds'@@@", 807 "@@@STEP_LOG_LINE@python.inline@print log@@@", 808 "@@@STEP_LOG_LINE@python.inline@if 'cannot' in log:@@@", 809 "@@@STEP_LOG_LINE@python.inline@ raise Exception('adb root failed')@@@", 810 "@@@STEP_LOG_LINE@python.inline@@@@", 811 "@@@STEP_LOG_LINE@python.inline@subprocess.check_output([ADB, 'shell', 'echo \"%s\" > '@@@", 812 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor' % (gov, cpu)])@@@", 813 "@@@STEP_LOG_LINE@python.inline@actual_gov = subprocess.check_output([ADB, 'shell', 'cat '@@@", 814 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor' % cpu]).strip()@@@", 815 "@@@STEP_LOG_LINE@python.inline@if actual_gov != gov:@@@", 816 "@@@STEP_LOG_LINE@python.inline@ raise Exception('(actual, expected) (%s, %s)'@@@", 817 "@@@STEP_LOG_LINE@python.inline@ % (actual_gov, gov))@@@", 818 "@@@STEP_LOG_END@python.inline@@@" 819 ] 820 }, 821 { 822 "cmd": [ 823 "python", 824 "-u", 825 "\nimport os\nimport subprocess\nimport sys\nimport time\nADB = sys.argv[1]\ncpu = int(sys.argv[2])\ngov = sys.argv[3]\n\nlog = subprocess.check_output([ADB, 'root'])\n# check for message like 'adbd cannot run as root in production builds'\nprint log\nif 'cannot' in log:\n raise Exception('adb root failed')\n\nsubprocess.check_output([ADB, 'shell', 'echo \"%s\" > '\n '/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor' % (gov, cpu)])\nactual_gov = subprocess.check_output([ADB, 'shell', 'cat '\n '/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor' % cpu]).strip()\nif actual_gov != gov:\n raise Exception('(actual, expected) (%s, %s)'\n % (actual_gov, gov))\n", 826 "/opt/infra-android/tools/adb", 827 "0", 828 "ondemand" 829 ], 830 "env": { 831 "CHROME_HEADLESS": "1", 832 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 833 }, 834 "infra_step": true, 835 "name": "Set CPU 0's governor to ondemand", 836 "timeout": 30, 837 "~followup_annotations": [ 838 "@@@STEP_LOG_LINE@python.inline@@@@", 839 "@@@STEP_LOG_LINE@python.inline@import os@@@", 840 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 841 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 842 "@@@STEP_LOG_LINE@python.inline@import time@@@", 843 "@@@STEP_LOG_LINE@python.inline@ADB = sys.argv[1]@@@", 844 "@@@STEP_LOG_LINE@python.inline@cpu = int(sys.argv[2])@@@", 845 "@@@STEP_LOG_LINE@python.inline@gov = sys.argv[3]@@@", 846 "@@@STEP_LOG_LINE@python.inline@@@@", 847 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output([ADB, 'root'])@@@", 848 "@@@STEP_LOG_LINE@python.inline@# check for message like 'adbd cannot run as root in production builds'@@@", 849 "@@@STEP_LOG_LINE@python.inline@print log@@@", 850 "@@@STEP_LOG_LINE@python.inline@if 'cannot' in log:@@@", 851 "@@@STEP_LOG_LINE@python.inline@ raise Exception('adb root failed')@@@", 852 "@@@STEP_LOG_LINE@python.inline@@@@", 853 "@@@STEP_LOG_LINE@python.inline@subprocess.check_output([ADB, 'shell', 'echo \"%s\" > '@@@", 854 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor' % (gov, cpu)])@@@", 855 "@@@STEP_LOG_LINE@python.inline@actual_gov = subprocess.check_output([ADB, 'shell', 'cat '@@@", 856 "@@@STEP_LOG_LINE@python.inline@ '/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor' % cpu]).strip()@@@", 857 "@@@STEP_LOG_LINE@python.inline@if actual_gov != gov:@@@", 858 "@@@STEP_LOG_LINE@python.inline@ raise Exception('(actual, expected) (%s, %s)'@@@", 859 "@@@STEP_LOG_LINE@python.inline@ % (actual_gov, gov))@@@", 860 "@@@STEP_LOG_END@python.inline@@@" 861 ] 862 }, 863 { 864 "cmd": [ 865 "/opt/infra-android/tools/adb", 866 "push", 867 "[START_DIR]/build/dm", 868 "/data/local/tmp/" 869 ], 870 "cwd": "[START_DIR]/skia", 871 "env": { 872 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 873 "CHROME_HEADLESS": "1", 874 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 875 }, 876 "infra_step": true, 877 "name": "push dm" 878 }, 879 { 880 "cmd": [ 881 "python", 882 "-u", 883 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 884 "--json-output", 885 "/path/to/tmp/json", 886 "copy", 887 "set -x; /data/local/tmp/dm --some-flag; echo $? >/data/local/tmp/rc", 888 "[START_DIR]/tmp/dm.sh" 889 ], 890 "infra_step": true, 891 "name": "write dm.sh" 892 }, 893 { 894 "cmd": [ 895 "/opt/infra-android/tools/adb", 896 "push", 897 "[START_DIR]/tmp/dm.sh", 898 "/data/local/tmp/" 899 ], 900 "cwd": "[START_DIR]/skia", 901 "env": { 902 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 903 "CHROME_HEADLESS": "1", 904 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 905 }, 906 "infra_step": true, 907 "name": "push dm.sh" 908 }, 909 { 910 "cmd": [ 911 "/opt/infra-android/tools/adb", 912 "logcat", 913 "-c" 914 ], 915 "cwd": "[START_DIR]/skia", 916 "env": { 917 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 918 "CHROME_HEADLESS": "1", 919 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 920 }, 921 "infra_step": true, 922 "name": "clear log" 923 }, 924 { 925 "cmd": [ 926 "python", 927 "-u", 928 "\nimport subprocess\nimport sys\nbin_dir = sys.argv[1]\nsh = sys.argv[2]\nsubprocess.check_call(['/opt/infra-android/tools/adb', 'shell', 'sh', bin_dir + sh])\ntry:\n sys.exit(int(subprocess.check_output(['/opt/infra-android/tools/adb', 'shell', 'cat',\n bin_dir + 'rc'])))\nexcept ValueError:\n print \"Couldn't read the return code. Probably killed for OOM.\"\n sys.exit(1)\n", 929 "/data/local/tmp/", 930 "dm.sh" 931 ], 932 "name": "dm", 933 "~followup_annotations": [ 934 "@@@STEP_LOG_LINE@python.inline@@@@", 935 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 936 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 937 "@@@STEP_LOG_LINE@python.inline@bin_dir = sys.argv[1]@@@", 938 "@@@STEP_LOG_LINE@python.inline@sh = sys.argv[2]@@@", 939 "@@@STEP_LOG_LINE@python.inline@subprocess.check_call(['/opt/infra-android/tools/adb', 'shell', 'sh', bin_dir + sh])@@@", 940 "@@@STEP_LOG_LINE@python.inline@try:@@@", 941 "@@@STEP_LOG_LINE@python.inline@ sys.exit(int(subprocess.check_output(['/opt/infra-android/tools/adb', 'shell', 'cat',@@@", 942 "@@@STEP_LOG_LINE@python.inline@ bin_dir + 'rc'])))@@@", 943 "@@@STEP_LOG_LINE@python.inline@except ValueError:@@@", 944 "@@@STEP_LOG_LINE@python.inline@ print \"Couldn't read the return code. Probably killed for OOM.\"@@@", 945 "@@@STEP_LOG_LINE@python.inline@ sys.exit(1)@@@", 946 "@@@STEP_LOG_END@python.inline@@@" 947 ] 948 }, 949 { 950 "cmd": [], 951 "name": "adb pull" 952 }, 953 { 954 "cmd": [ 955 "/opt/infra-android/tools/adb", 956 "pull", 957 "/sdcard/revenge_of_the_skiabot/dm_out", 958 "[CLEANUP]/adb_pull_tmp_1" 959 ], 960 "cwd": "[START_DIR]/skia", 961 "env": { 962 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 963 "CHROME_HEADLESS": "1", 964 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 965 }, 966 "infra_step": true, 967 "name": "adb pull.pull /sdcard/revenge_of_the_skiabot/dm_out", 968 "~followup_annotations": [ 969 "@@@STEP_NEST_LEVEL@1@@@" 970 ] 971 }, 972 { 973 "cmd": [ 974 "python", 975 "-u", 976 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 977 "--json-output", 978 "/path/to/tmp/json", 979 "glob", 980 "[CLEANUP]/adb_pull_tmp_1", 981 "dm_out/*" 982 ], 983 "infra_step": true, 984 "name": "adb pull.list pulled files", 985 "stdout": "/path/to/tmp/", 986 "~followup_annotations": [ 987 "@@@STEP_NEST_LEVEL@1@@@", 988 "@@@STEP_LOG_LINE@glob@[CLEANUP]/adb_pull_tmp_1/1.png@@@", 989 "@@@STEP_LOG_LINE@glob@[CLEANUP]/adb_pull_tmp_1/2.png@@@", 990 "@@@STEP_LOG_END@glob@@@" 991 ] 992 }, 993 { 994 "cmd": [ 995 "python", 996 "-u", 997 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 998 "--json-output", 999 "/path/to/tmp/json", 1000 "copy", 1001 "[CLEANUP]/adb_pull_tmp_1/1.png", 1002 "[START_DIR]/[SWARM_OUT_DIR]" 1003 ], 1004 "infra_step": true, 1005 "name": "adb pull.copy 1.png", 1006 "~followup_annotations": [ 1007 "@@@STEP_NEST_LEVEL@1@@@" 1008 ] 1009 }, 1010 { 1011 "cmd": [ 1012 "python", 1013 "-u", 1014 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 1015 "--json-output", 1016 "/path/to/tmp/json", 1017 "copy", 1018 "[CLEANUP]/adb_pull_tmp_1/2.png", 1019 "[START_DIR]/[SWARM_OUT_DIR]" 1020 ], 1021 "infra_step": true, 1022 "name": "adb pull.copy 2.png", 1023 "~followup_annotations": [ 1024 "@@@STEP_NEST_LEVEL@1@@@" 1025 ] 1026 }, 1027 { 1028 "cmd": [ 1029 "python", 1030 "-u", 1031 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 1032 "--json-output", 1033 "/path/to/tmp/json", 1034 "rmtree", 1035 "[CLEANUP]/adb_pull_tmp_1" 1036 ], 1037 "infra_step": true, 1038 "name": "adb pull.rmtree [CLEANUP]/adb_pull_tmp_1", 1039 "~followup_annotations": [ 1040 "@@@STEP_NEST_LEVEL@1@@@" 1041 ] 1042 }, 1043 { 1044 "cmd": [ 1045 "python", 1046 "-u", 1047 "\nimport os\nimport subprocess\nimport sys\nout = sys.argv[1]\nlog = subprocess.check_output(['/opt/infra-android/tools/adb', 'logcat', '-d'])\nfor line in log.split('\\n'):\n tokens = line.split()\n if len(tokens) == 11 and tokens[-7] == 'F' and tokens[-3] == 'pc':\n addr, path = tokens[-2:]\n local = os.path.join(out, os.path.basename(path))\n if os.path.exists(local):\n sym = subprocess.check_output(['addr2line', '-Cfpe', local, addr])\n line = line.replace(addr, addr + ' ' + sym.strip())\n print line\n", 1048 "[START_DIR]/build" 1049 ], 1050 "env": { 1051 "CHROME_HEADLESS": "1", 1052 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 1053 }, 1054 "infra_step": true, 1055 "name": "dump log", 1056 "timeout": 300, 1057 "~followup_annotations": [ 1058 "@@@STEP_LOG_LINE@python.inline@@@@", 1059 "@@@STEP_LOG_LINE@python.inline@import os@@@", 1060 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 1061 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 1062 "@@@STEP_LOG_LINE@python.inline@out = sys.argv[1]@@@", 1063 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output(['/opt/infra-android/tools/adb', 'logcat', '-d'])@@@", 1064 "@@@STEP_LOG_LINE@python.inline@for line in log.split('\\n'):@@@", 1065 "@@@STEP_LOG_LINE@python.inline@ tokens = line.split()@@@", 1066 "@@@STEP_LOG_LINE@python.inline@ if len(tokens) == 11 and tokens[-7] == 'F' and tokens[-3] == 'pc':@@@", 1067 "@@@STEP_LOG_LINE@python.inline@ addr, path = tokens[-2:]@@@", 1068 "@@@STEP_LOG_LINE@python.inline@ local = os.path.join(out, os.path.basename(path))@@@", 1069 "@@@STEP_LOG_LINE@python.inline@ if os.path.exists(local):@@@", 1070 "@@@STEP_LOG_LINE@python.inline@ sym = subprocess.check_output(['addr2line', '-Cfpe', local, addr])@@@", 1071 "@@@STEP_LOG_LINE@python.inline@ line = line.replace(addr, addr + ' ' + sym.strip())@@@", 1072 "@@@STEP_LOG_LINE@python.inline@ print line@@@", 1073 "@@@STEP_LOG_END@python.inline@@@" 1074 ] 1075 }, 1076 { 1077 "cmd": [ 1078 "/opt/infra-android/tools/adb", 1079 "kill-server" 1080 ], 1081 "cwd": "[START_DIR]/skia", 1082 "env": { 1083 "ADB_VENDOR_KEYS": "/home/chrome-bot/.android/chrome_infrastructure_adbkey", 1084 "CHROME_HEADLESS": "1", 1085 "PATH": "<PATH>:RECIPE_REPO[depot_tools]" 1086 }, 1087 "infra_step": true, 1088 "name": "kill adb server" 1089 }, 1090 { 1091 "jsonResult": null, 1092 "name": "$result" 1093 } 1094]