1[ 2 { 3 "cmd": [ 4 "adb", 5 "shell", 6 "mkdir", 7 "-p", 8 "/sdcard/revenge_of_the_skiabot/resources" 9 ], 10 "cwd": "[START_DIR]/skia", 11 "env": { 12 "BUILDTYPE": "Debug", 13 "CHROME_HEADLESS": "1", 14 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 15 "SKIA_OUT": "[START_DIR]/out" 16 }, 17 "infra_step": true, 18 "name": "mkdir /sdcard/revenge_of_the_skiabot/resources" 19 }, 20 { 21 "cmd": [ 22 "python", 23 "-u", 24 "\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(['adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n", 25 "[START_DIR]/skia/resources", 26 "/sdcard/revenge_of_the_skiabot/resources" 27 ], 28 "env": { 29 "BUILDTYPE": "Debug", 30 "CHROME_HEADLESS": "1", 31 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 32 "SKIA_OUT": "[START_DIR]/out" 33 }, 34 "infra_step": true, 35 "name": "push [START_DIR]/skia/resources/* /sdcard/revenge_of_the_skiabot/resources", 36 "~followup_annotations": [ 37 "@@@STEP_LOG_LINE@python.inline@@@@", 38 "@@@STEP_LOG_LINE@python.inline@import os@@@", 39 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 40 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 41 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@", 42 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@", 43 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@", 44 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@", 45 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@", 46 "@@@STEP_LOG_LINE@python.inline@ continue@@@", 47 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@", 48 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@", 49 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['adb', 'push',@@@", 50 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@", 51 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@", 52 "@@@STEP_LOG_END@python.inline@@@" 53 ] 54 }, 55 { 56 "cmd": [ 57 "python", 58 "-u", 59 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 60 "--json-output", 61 "/path/to/tmp/json", 62 "copy", 63 "[START_DIR]/skia/infra/bots/assets/skp/VERSION", 64 "/path/to/tmp/" 65 ], 66 "infra_step": true, 67 "name": "Get downloaded SKP VERSION" 68 }, 69 { 70 "cmd": [ 71 "python", 72 "-u", 73 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 74 "--json-output", 75 "/path/to/tmp/json", 76 "copy", 77 "42", 78 "[START_DIR]/tmp/SKP_VERSION" 79 ], 80 "infra_step": true, 81 "name": "write SKP_VERSION" 82 }, 83 { 84 "cmd": [ 85 "adb", 86 "shell", 87 "cat", 88 "/sdcard/revenge_of_the_skiabot/SKP_VERSION" 89 ], 90 "cwd": "[START_DIR]/skia", 91 "env": { 92 "BUILDTYPE": "Debug", 93 "CHROME_HEADLESS": "1", 94 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 95 "SKIA_OUT": "[START_DIR]/out" 96 }, 97 "infra_step": true, 98 "name": "read /sdcard/revenge_of_the_skiabot/SKP_VERSION", 99 "stdout": "/path/to/tmp/" 100 }, 101 { 102 "cmd": [ 103 "adb", 104 "shell", 105 "rm", 106 "-f", 107 "/sdcard/revenge_of_the_skiabot/SKP_VERSION" 108 ], 109 "cwd": "[START_DIR]/skia", 110 "env": { 111 "BUILDTYPE": "Debug", 112 "CHROME_HEADLESS": "1", 113 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 114 "SKIA_OUT": "[START_DIR]/out" 115 }, 116 "infra_step": true, 117 "name": "rm /sdcard/revenge_of_the_skiabot/SKP_VERSION" 118 }, 119 { 120 "cmd": [ 121 "adb", 122 "shell", 123 "rm", 124 "-rf", 125 "/sdcard/revenge_of_the_skiabot/skps" 126 ], 127 "cwd": "[START_DIR]/skia", 128 "env": { 129 "BUILDTYPE": "Debug", 130 "CHROME_HEADLESS": "1", 131 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 132 "SKIA_OUT": "[START_DIR]/out" 133 }, 134 "infra_step": true, 135 "name": "rm /sdcard/revenge_of_the_skiabot/skps" 136 }, 137 { 138 "cmd": [ 139 "adb", 140 "shell", 141 "mkdir", 142 "-p", 143 "/sdcard/revenge_of_the_skiabot/skps" 144 ], 145 "cwd": "[START_DIR]/skia", 146 "env": { 147 "BUILDTYPE": "Debug", 148 "CHROME_HEADLESS": "1", 149 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 150 "SKIA_OUT": "[START_DIR]/out" 151 }, 152 "infra_step": true, 153 "name": "mkdir /sdcard/revenge_of_the_skiabot/skps" 154 }, 155 { 156 "cmd": [ 157 "python", 158 "-u", 159 "\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(['adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n", 160 "[START_DIR]/skp", 161 "/sdcard/revenge_of_the_skiabot/skps" 162 ], 163 "env": { 164 "BUILDTYPE": "Debug", 165 "CHROME_HEADLESS": "1", 166 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 167 "SKIA_OUT": "[START_DIR]/out" 168 }, 169 "infra_step": true, 170 "name": "push [START_DIR]/skp/* /sdcard/revenge_of_the_skiabot/skps", 171 "~followup_annotations": [ 172 "@@@STEP_LOG_LINE@python.inline@@@@", 173 "@@@STEP_LOG_LINE@python.inline@import os@@@", 174 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 175 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 176 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@", 177 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@", 178 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@", 179 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@", 180 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@", 181 "@@@STEP_LOG_LINE@python.inline@ continue@@@", 182 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@", 183 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@", 184 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['adb', 'push',@@@", 185 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@", 186 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@", 187 "@@@STEP_LOG_END@python.inline@@@" 188 ] 189 }, 190 { 191 "cmd": [ 192 "adb", 193 "push", 194 "[START_DIR]/tmp/SKP_VERSION", 195 "/sdcard/revenge_of_the_skiabot/SKP_VERSION" 196 ], 197 "cwd": "[START_DIR]/skia", 198 "env": { 199 "BUILDTYPE": "Debug", 200 "CHROME_HEADLESS": "1", 201 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 202 "SKIA_OUT": "[START_DIR]/out" 203 }, 204 "infra_step": true, 205 "name": "push [START_DIR]/tmp/SKP_VERSION /sdcard/revenge_of_the_skiabot/SKP_VERSION" 206 }, 207 { 208 "cmd": [ 209 "python", 210 "-u", 211 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 212 "--json-output", 213 "/path/to/tmp/json", 214 "copy", 215 "[START_DIR]/skia/infra/bots/assets/skimage/VERSION", 216 "/path/to/tmp/" 217 ], 218 "infra_step": true, 219 "name": "Get downloaded skimage VERSION" 220 }, 221 { 222 "cmd": [ 223 "python", 224 "-u", 225 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 226 "--json-output", 227 "/path/to/tmp/json", 228 "copy", 229 "42", 230 "[START_DIR]/tmp/SK_IMAGE_VERSION" 231 ], 232 "infra_step": true, 233 "name": "write SK_IMAGE_VERSION" 234 }, 235 { 236 "cmd": [ 237 "adb", 238 "shell", 239 "cat", 240 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 241 ], 242 "cwd": "[START_DIR]/skia", 243 "env": { 244 "BUILDTYPE": "Debug", 245 "CHROME_HEADLESS": "1", 246 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 247 "SKIA_OUT": "[START_DIR]/out" 248 }, 249 "infra_step": true, 250 "name": "read /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION", 251 "stdout": "/path/to/tmp/" 252 }, 253 { 254 "cmd": [ 255 "adb", 256 "shell", 257 "rm", 258 "-f", 259 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 260 ], 261 "cwd": "[START_DIR]/skia", 262 "env": { 263 "BUILDTYPE": "Debug", 264 "CHROME_HEADLESS": "1", 265 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 266 "SKIA_OUT": "[START_DIR]/out" 267 }, 268 "infra_step": true, 269 "name": "rm /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 270 }, 271 { 272 "cmd": [ 273 "adb", 274 "shell", 275 "rm", 276 "-rf", 277 "/sdcard/revenge_of_the_skiabot/images" 278 ], 279 "cwd": "[START_DIR]/skia", 280 "env": { 281 "BUILDTYPE": "Debug", 282 "CHROME_HEADLESS": "1", 283 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 284 "SKIA_OUT": "[START_DIR]/out" 285 }, 286 "infra_step": true, 287 "name": "rm /sdcard/revenge_of_the_skiabot/images" 288 }, 289 { 290 "cmd": [ 291 "adb", 292 "shell", 293 "mkdir", 294 "-p", 295 "/sdcard/revenge_of_the_skiabot/images" 296 ], 297 "cwd": "[START_DIR]/skia", 298 "env": { 299 "BUILDTYPE": "Debug", 300 "CHROME_HEADLESS": "1", 301 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 302 "SKIA_OUT": "[START_DIR]/out" 303 }, 304 "infra_step": true, 305 "name": "mkdir /sdcard/revenge_of_the_skiabot/images" 306 }, 307 { 308 "cmd": [ 309 "python", 310 "-u", 311 "\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(['adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n", 312 "[START_DIR]/skimage", 313 "/sdcard/revenge_of_the_skiabot/images" 314 ], 315 "env": { 316 "BUILDTYPE": "Debug", 317 "CHROME_HEADLESS": "1", 318 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 319 "SKIA_OUT": "[START_DIR]/out" 320 }, 321 "infra_step": true, 322 "name": "push [START_DIR]/skimage/* /sdcard/revenge_of_the_skiabot/images", 323 "~followup_annotations": [ 324 "@@@STEP_LOG_LINE@python.inline@@@@", 325 "@@@STEP_LOG_LINE@python.inline@import os@@@", 326 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 327 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 328 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@", 329 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@", 330 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@", 331 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@", 332 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@", 333 "@@@STEP_LOG_LINE@python.inline@ continue@@@", 334 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@", 335 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@", 336 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['adb', 'push',@@@", 337 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@", 338 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@", 339 "@@@STEP_LOG_END@python.inline@@@" 340 ] 341 }, 342 { 343 "cmd": [ 344 "adb", 345 "push", 346 "[START_DIR]/tmp/SK_IMAGE_VERSION", 347 "/sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 348 ], 349 "cwd": "[START_DIR]/skia", 350 "env": { 351 "BUILDTYPE": "Debug", 352 "CHROME_HEADLESS": "1", 353 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 354 "SKIA_OUT": "[START_DIR]/out" 355 }, 356 "infra_step": true, 357 "name": "push [START_DIR]/tmp/SK_IMAGE_VERSION /sdcard/revenge_of_the_skiabot/SK_IMAGE_VERSION" 358 }, 359 { 360 "cmd": [ 361 "python", 362 "-u", 363 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 364 "--json-output", 365 "/path/to/tmp/json", 366 "copy", 367 "[START_DIR]/skia/infra/bots/assets/svg/VERSION", 368 "/path/to/tmp/" 369 ], 370 "infra_step": true, 371 "name": "Get downloaded SVG VERSION" 372 }, 373 { 374 "cmd": [ 375 "python", 376 "-u", 377 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 378 "--json-output", 379 "/path/to/tmp/json", 380 "copy", 381 "42", 382 "[START_DIR]/tmp/SVG_VERSION" 383 ], 384 "infra_step": true, 385 "name": "write SVG_VERSION" 386 }, 387 { 388 "cmd": [ 389 "adb", 390 "shell", 391 "cat", 392 "/sdcard/revenge_of_the_skiabot/SVG_VERSION" 393 ], 394 "cwd": "[START_DIR]/skia", 395 "env": { 396 "BUILDTYPE": "Debug", 397 "CHROME_HEADLESS": "1", 398 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 399 "SKIA_OUT": "[START_DIR]/out" 400 }, 401 "infra_step": true, 402 "name": "read /sdcard/revenge_of_the_skiabot/SVG_VERSION", 403 "stdout": "/path/to/tmp/" 404 }, 405 { 406 "cmd": [ 407 "adb", 408 "shell", 409 "rm", 410 "-f", 411 "/sdcard/revenge_of_the_skiabot/SVG_VERSION" 412 ], 413 "cwd": "[START_DIR]/skia", 414 "env": { 415 "BUILDTYPE": "Debug", 416 "CHROME_HEADLESS": "1", 417 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 418 "SKIA_OUT": "[START_DIR]/out" 419 }, 420 "infra_step": true, 421 "name": "rm /sdcard/revenge_of_the_skiabot/SVG_VERSION" 422 }, 423 { 424 "cmd": [ 425 "adb", 426 "shell", 427 "rm", 428 "-rf", 429 "/sdcard/revenge_of_the_skiabot/svgs" 430 ], 431 "cwd": "[START_DIR]/skia", 432 "env": { 433 "BUILDTYPE": "Debug", 434 "CHROME_HEADLESS": "1", 435 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 436 "SKIA_OUT": "[START_DIR]/out" 437 }, 438 "infra_step": true, 439 "name": "rm /sdcard/revenge_of_the_skiabot/svgs" 440 }, 441 { 442 "cmd": [ 443 "adb", 444 "shell", 445 "mkdir", 446 "-p", 447 "/sdcard/revenge_of_the_skiabot/svgs" 448 ], 449 "cwd": "[START_DIR]/skia", 450 "env": { 451 "BUILDTYPE": "Debug", 452 "CHROME_HEADLESS": "1", 453 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 454 "SKIA_OUT": "[START_DIR]/out" 455 }, 456 "infra_step": true, 457 "name": "mkdir /sdcard/revenge_of_the_skiabot/svgs" 458 }, 459 { 460 "cmd": [ 461 "python", 462 "-u", 463 "\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(['adb', 'push',\n os.path.realpath(os.path.join(host, p, f)),\n os.path.join(device, p, f)])\n", 464 "[START_DIR]/svg", 465 "/sdcard/revenge_of_the_skiabot/svgs" 466 ], 467 "env": { 468 "BUILDTYPE": "Debug", 469 "CHROME_HEADLESS": "1", 470 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 471 "SKIA_OUT": "[START_DIR]/out" 472 }, 473 "infra_step": true, 474 "name": "push [START_DIR]/svg/* /sdcard/revenge_of_the_skiabot/svgs", 475 "~followup_annotations": [ 476 "@@@STEP_LOG_LINE@python.inline@@@@", 477 "@@@STEP_LOG_LINE@python.inline@import os@@@", 478 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 479 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 480 "@@@STEP_LOG_LINE@python.inline@host = sys.argv[1]@@@", 481 "@@@STEP_LOG_LINE@python.inline@device = sys.argv[2]@@@", 482 "@@@STEP_LOG_LINE@python.inline@for d, _, fs in os.walk(host):@@@", 483 "@@@STEP_LOG_LINE@python.inline@ p = os.path.relpath(d, host)@@@", 484 "@@@STEP_LOG_LINE@python.inline@ if p != '.' and p.startswith('.'):@@@", 485 "@@@STEP_LOG_LINE@python.inline@ continue@@@", 486 "@@@STEP_LOG_LINE@python.inline@ for f in fs:@@@", 487 "@@@STEP_LOG_LINE@python.inline@ print os.path.join(p,f)@@@", 488 "@@@STEP_LOG_LINE@python.inline@ subprocess.check_call(['adb', 'push',@@@", 489 "@@@STEP_LOG_LINE@python.inline@ os.path.realpath(os.path.join(host, p, f)),@@@", 490 "@@@STEP_LOG_LINE@python.inline@ os.path.join(device, p, f)])@@@", 491 "@@@STEP_LOG_END@python.inline@@@" 492 ] 493 }, 494 { 495 "cmd": [ 496 "adb", 497 "push", 498 "[START_DIR]/tmp/SVG_VERSION", 499 "/sdcard/revenge_of_the_skiabot/SVG_VERSION" 500 ], 501 "cwd": "[START_DIR]/skia", 502 "env": { 503 "BUILDTYPE": "Debug", 504 "CHROME_HEADLESS": "1", 505 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 506 "SKIA_OUT": "[START_DIR]/out" 507 }, 508 "infra_step": true, 509 "name": "push [START_DIR]/tmp/SVG_VERSION /sdcard/revenge_of_the_skiabot/SVG_VERSION" 510 }, 511 { 512 "cmd": [ 513 "python", 514 "-u", 515 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 516 "--json-output", 517 "/path/to/tmp/json", 518 "rmtree", 519 "[CUSTOM_[SWARM_OUT_DIR]]/dm" 520 ], 521 "infra_step": true, 522 "name": "rmtree dm" 523 }, 524 { 525 "cmd": [ 526 "python", 527 "-u", 528 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 529 "--json-output", 530 "/path/to/tmp/json", 531 "ensure-directory", 532 "--mode", 533 "0777", 534 "[CUSTOM_[SWARM_OUT_DIR]]/dm" 535 ], 536 "infra_step": true, 537 "name": "makedirs dm" 538 }, 539 { 540 "cmd": [ 541 "adb", 542 "shell", 543 "rm", 544 "-rf", 545 "/sdcard/revenge_of_the_skiabot/dm_out" 546 ], 547 "cwd": "[START_DIR]/skia", 548 "env": { 549 "BUILDTYPE": "Debug", 550 "CHROME_HEADLESS": "1", 551 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 552 "SKIA_OUT": "[START_DIR]/out" 553 }, 554 "infra_step": true, 555 "name": "rm /sdcard/revenge_of_the_skiabot/dm_out" 556 }, 557 { 558 "cmd": [ 559 "adb", 560 "shell", 561 "mkdir", 562 "-p", 563 "/sdcard/revenge_of_the_skiabot/dm_out" 564 ], 565 "cwd": "[START_DIR]/skia", 566 "env": { 567 "BUILDTYPE": "Debug", 568 "CHROME_HEADLESS": "1", 569 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 570 "SKIA_OUT": "[START_DIR]/out" 571 }, 572 "infra_step": true, 573 "name": "mkdir /sdcard/revenge_of_the_skiabot/dm_out" 574 }, 575 { 576 "cmd": [ 577 "python", 578 "-u", 579 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 580 "--json-output", 581 "/path/to/tmp/json", 582 "ensure-directory", 583 "--mode", 584 "0777", 585 "[START_DIR]/tmp" 586 ], 587 "infra_step": true, 588 "name": "makedirs tmp_dir" 589 }, 590 { 591 "cmd": [ 592 "python", 593 "-u", 594 "\nimport contextlib\nimport math\nimport socket\nimport sys\nimport time\nimport urllib2\n\nHASHES_URL = 'https://storage.googleapis.com/skia-infra-gm/hash_files/gold-prod-hashes.txt'\nRETRIES = 5\nTIMEOUT = 60\nWAIT_BASE = 15\n\nsocket.setdefaulttimeout(TIMEOUT)\nfor retry in range(RETRIES):\n try:\n with contextlib.closing(\n urllib2.urlopen(HASHES_URL, timeout=TIMEOUT)) as w:\n hashes = w.read()\n with open(sys.argv[1], 'w') as f:\n f.write(hashes)\n break\n except Exception as e:\n print 'Failed to get uninteresting hashes from %s:' % HASHES_URL\n print e\n if retry == RETRIES:\n raise\n waittime = WAIT_BASE * math.pow(2, retry)\n print 'Retry in %d seconds.' % waittime\n time.sleep(waittime)\n", 595 "[START_DIR]/tmp/uninteresting_hashes.txt" 596 ], 597 "env": { 598 "BUILDTYPE": "Debug", 599 "CHROME_HEADLESS": "1", 600 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 601 "SKIA_OUT": "[START_DIR]/out" 602 }, 603 "infra_step": true, 604 "name": "get uninteresting hashes", 605 "~followup_annotations": [ 606 "step returned non-zero exit code: 1", 607 "@@@STEP_LOG_LINE@python.inline@@@@", 608 "@@@STEP_LOG_LINE@python.inline@import contextlib@@@", 609 "@@@STEP_LOG_LINE@python.inline@import math@@@", 610 "@@@STEP_LOG_LINE@python.inline@import socket@@@", 611 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 612 "@@@STEP_LOG_LINE@python.inline@import time@@@", 613 "@@@STEP_LOG_LINE@python.inline@import urllib2@@@", 614 "@@@STEP_LOG_LINE@python.inline@@@@", 615 "@@@STEP_LOG_LINE@python.inline@HASHES_URL = 'https://storage.googleapis.com/skia-infra-gm/hash_files/gold-prod-hashes.txt'@@@", 616 "@@@STEP_LOG_LINE@python.inline@RETRIES = 5@@@", 617 "@@@STEP_LOG_LINE@python.inline@TIMEOUT = 60@@@", 618 "@@@STEP_LOG_LINE@python.inline@WAIT_BASE = 15@@@", 619 "@@@STEP_LOG_LINE@python.inline@@@@", 620 "@@@STEP_LOG_LINE@python.inline@socket.setdefaulttimeout(TIMEOUT)@@@", 621 "@@@STEP_LOG_LINE@python.inline@for retry in range(RETRIES):@@@", 622 "@@@STEP_LOG_LINE@python.inline@ try:@@@", 623 "@@@STEP_LOG_LINE@python.inline@ with contextlib.closing(@@@", 624 "@@@STEP_LOG_LINE@python.inline@ urllib2.urlopen(HASHES_URL, timeout=TIMEOUT)) as w:@@@", 625 "@@@STEP_LOG_LINE@python.inline@ hashes = w.read()@@@", 626 "@@@STEP_LOG_LINE@python.inline@ with open(sys.argv[1], 'w') as f:@@@", 627 "@@@STEP_LOG_LINE@python.inline@ f.write(hashes)@@@", 628 "@@@STEP_LOG_LINE@python.inline@ break@@@", 629 "@@@STEP_LOG_LINE@python.inline@ except Exception as e:@@@", 630 "@@@STEP_LOG_LINE@python.inline@ print 'Failed to get uninteresting hashes from %s:' % HASHES_URL@@@", 631 "@@@STEP_LOG_LINE@python.inline@ print e@@@", 632 "@@@STEP_LOG_LINE@python.inline@ if retry == RETRIES:@@@", 633 "@@@STEP_LOG_LINE@python.inline@ raise@@@", 634 "@@@STEP_LOG_LINE@python.inline@ waittime = WAIT_BASE * math.pow(2, retry)@@@", 635 "@@@STEP_LOG_LINE@python.inline@ print 'Retry in %d seconds.' % waittime@@@", 636 "@@@STEP_LOG_LINE@python.inline@ time.sleep(waittime)@@@", 637 "@@@STEP_LOG_END@python.inline@@@", 638 "@@@STEP_EXCEPTION@@@" 639 ] 640 }, 641 { 642 "cmd": [ 643 "adb", 644 "push", 645 "[START_DIR]/tmp/uninteresting_hashes.txt", 646 "/sdcard/revenge_of_the_skiabot/uninteresting_hashes.txt" 647 ], 648 "cwd": "[START_DIR]/skia", 649 "env": { 650 "BUILDTYPE": "Debug", 651 "CHROME_HEADLESS": "1", 652 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 653 "SKIA_OUT": "[START_DIR]/out" 654 }, 655 "infra_step": true, 656 "name": "push [START_DIR]/tmp/uninteresting_hashes.txt /sdcard/revenge_of_the_skiabot/uninteresting_hashes.txt" 657 }, 658 { 659 "cmd": [ 660 "python", 661 "-u", 662 "import os\nprint os.environ.get('SWARMING_BOT_ID', '')\n" 663 ], 664 "name": "get swarming bot id", 665 "stdout": "/path/to/tmp/", 666 "~followup_annotations": [ 667 "@@@STEP_LOG_LINE@python.inline@import os@@@", 668 "@@@STEP_LOG_LINE@python.inline@print os.environ.get('SWARMING_BOT_ID', '')@@@", 669 "@@@STEP_LOG_END@python.inline@@@" 670 ] 671 }, 672 { 673 "cmd": [ 674 "python", 675 "-u", 676 "import os\nprint os.environ.get('SWARMING_TASK_ID', '')\n" 677 ], 678 "name": "get swarming task id", 679 "stdout": "/path/to/tmp/", 680 "~followup_annotations": [ 681 "@@@STEP_LOG_LINE@python.inline@import os@@@", 682 "@@@STEP_LOG_LINE@python.inline@print os.environ.get('SWARMING_TASK_ID', '')@@@", 683 "@@@STEP_LOG_END@python.inline@@@" 684 ] 685 }, 686 { 687 "cmd": [ 688 "adb", 689 "push", 690 "[START_DIR]/out/Debug/dm", 691 "/data/local/tmp/" 692 ], 693 "cwd": "[START_DIR]/skia", 694 "env": { 695 "BUILDTYPE": "Debug", 696 "CHROME_HEADLESS": "1", 697 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 698 "SKIA_OUT": "[START_DIR]/out" 699 }, 700 "infra_step": true, 701 "name": "push dm" 702 }, 703 { 704 "cmd": [ 705 "python", 706 "-u", 707 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 708 "--json-output", 709 "/path/to/tmp/json", 710 "copy", 711 "set -x; /data/local/tmp/dm --undefok --resourcePath /sdcard/revenge_of_the_skiabot/resources --skps /sdcard/revenge_of_the_skiabot/skps --images /sdcard/revenge_of_the_skiabot/images/dm --colorImages /sdcard/revenge_of_the_skiabot/images/colorspace --nameByHash --properties gitHash abc123 builder Test-Android-Clang-Nexus7-GPU-Tegra3-arm-Debug-Android swarming_bot_id \"\" swarming_task_id \"\" --svgs /sdcard/revenge_of_the_skiabot/svgs --key arch arm compiler Clang configuration Debug cpu_or_gpu GPU cpu_or_gpu_value Tegra3 extra_config Android model Nexus7 os Android --uninterestingHashesFile /sdcard/revenge_of_the_skiabot/uninteresting_hashes.txt --writePath /sdcard/revenge_of_the_skiabot/dm_out --nocpu --randomProcessorTest --config 8888 srgb gles glesdft glessrgb serialize-8888 tiles_rt-8888 pic-8888 --src tests gm image colorImage svg --blacklist glessrgb image _ _ _ test _ GrShape serialize-8888 gm _ bleed_image serialize-8888 gm _ c_gms serialize-8888 gm _ colortype serialize-8888 gm _ colortype_xfermodes serialize-8888 gm _ drawfilter serialize-8888 gm _ fontmgr_bounds_0.75_0 serialize-8888 gm _ fontmgr_bounds_1_-0.25 serialize-8888 gm _ fontmgr_bounds serialize-8888 gm _ fontmgr_match serialize-8888 gm _ fontmgr_iter serialize-8888 gm _ imagemasksubset serialize-8888 gm _ bitmapfilters serialize-8888 gm _ bitmapshaders serialize-8888 gm _ bleed serialize-8888 gm _ bleed_alpha_bmp serialize-8888 gm _ bleed_alpha_bmp_shader serialize-8888 gm _ convex_poly_clip serialize-8888 gm _ extractalpha serialize-8888 gm _ filterbitmap_checkerboard_32_32_g8 serialize-8888 gm _ filterbitmap_image_mandrill_64 serialize-8888 gm _ shadows serialize-8888 gm _ simpleaaclip_aaclip serialize-8888 gm _ composeshader_bitmap serialize-8888 gm _ scaled_tilemodes_npot serialize-8888 gm _ scaled_tilemodes serialize-8888 gm _ typefacerendering_pfaMac serialize-8888 gm _ parsedpaths serialize-8888 gm _ ImageGeneratorExternal_rect serialize-8888 gm _ ImageGeneratorExternal_shader serialize-8888 gm _ shadow_utils serialize-8888 gm _ makecolorspace serialize-8888 gm _ bleed_alpha_image serialize-8888 gm _ bleed_alpha_image_shader serialize-8888 gm _ verylargebitmap serialize-8888 gm _ verylarge_picture_image pic-8888 gm _ drawfilter pic-8888 gm _ image-cacherator-from-picture serialize-8888 gm _ image-cacherator-from-picture pic-8888 gm _ image-cacherator-from-raster serialize-8888 gm _ image-cacherator-from-raster pic-8888 gm _ image-cacherator-from-ctable serialize-8888 gm _ image-cacherator-from-ctable pic-8888 gm _ gamut serialize-8888 gm _ gamut pic-8888 gm _ complexclip4_bw serialize-8888 gm _ complexclip4_bw pic-8888 gm _ complexclip4_aa serialize-8888 gm _ complexclip4_aa tiles_rt-8888 gm _ complexclip4_bw tiles_rt-8888 gm _ complexclip4_aa _ image _ interlaced1.png _ image _ interlaced2.png _ image _ interlaced3.png _ image _ .arw _ image _ .cr2 _ image _ .dng _ image _ .nef _ image _ .nrw _ image _ .orf _ image _ .raf _ image _ .rw2 _ image _ .pef _ image _ .srw _ image _ .ARW _ image _ .CR2 _ image _ .DNG _ image _ .NEF _ image _ .NRW _ image _ .ORF _ image _ .RAF _ image _ .RW2 _ image _ .PEF _ image _ .SRW; echo $? >/data/local/tmp/rc", 712 "[START_DIR]/tmp/dm.sh" 713 ], 714 "env": { 715 "BUILDTYPE": "Debug", 716 "CHROME_HEADLESS": "1", 717 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 718 "SKIA_OUT": "[START_DIR]/out" 719 }, 720 "infra_step": true, 721 "name": "write dm.sh" 722 }, 723 { 724 "cmd": [ 725 "adb", 726 "push", 727 "[START_DIR]/tmp/dm.sh", 728 "/data/local/tmp/" 729 ], 730 "cwd": "[START_DIR]/skia", 731 "env": { 732 "BUILDTYPE": "Debug", 733 "CHROME_HEADLESS": "1", 734 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 735 "SKIA_OUT": "[START_DIR]/out" 736 }, 737 "infra_step": true, 738 "name": "push dm.sh" 739 }, 740 { 741 "cmd": [ 742 "adb", 743 "logcat", 744 "-c" 745 ], 746 "cwd": "[START_DIR]/skia", 747 "env": { 748 "BUILDTYPE": "Debug", 749 "CHROME_HEADLESS": "1", 750 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 751 "SKIA_OUT": "[START_DIR]/out" 752 }, 753 "infra_step": true, 754 "name": "clear log" 755 }, 756 { 757 "cmd": [ 758 "python", 759 "-u", 760 "\nimport subprocess\nimport sys\nbin_dir = sys.argv[1]\nsh = sys.argv[2]\nsubprocess.check_call(['adb', 'shell', 'sh', bin_dir + sh])\ntry:\n sys.exit(int(subprocess.check_output(['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", 761 "/data/local/tmp/", 762 "dm.sh" 763 ], 764 "env": { 765 "BUILDTYPE": "Debug", 766 "CHROME_HEADLESS": "1", 767 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 768 "SKIA_OUT": "[START_DIR]/out" 769 }, 770 "name": "dm", 771 "~followup_annotations": [ 772 "@@@STEP_LOG_LINE@python.inline@@@@", 773 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 774 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 775 "@@@STEP_LOG_LINE@python.inline@bin_dir = sys.argv[1]@@@", 776 "@@@STEP_LOG_LINE@python.inline@sh = sys.argv[2]@@@", 777 "@@@STEP_LOG_LINE@python.inline@subprocess.check_call(['adb', 'shell', 'sh', bin_dir + sh])@@@", 778 "@@@STEP_LOG_LINE@python.inline@try:@@@", 779 "@@@STEP_LOG_LINE@python.inline@ sys.exit(int(subprocess.check_output(['adb', 'shell', 'cat',@@@", 780 "@@@STEP_LOG_LINE@python.inline@ bin_dir + 'rc'])))@@@", 781 "@@@STEP_LOG_LINE@python.inline@except ValueError:@@@", 782 "@@@STEP_LOG_LINE@python.inline@ print \"Couldn't read the return code. Probably killed for OOM.\"@@@", 783 "@@@STEP_LOG_LINE@python.inline@ sys.exit(1)@@@", 784 "@@@STEP_LOG_END@python.inline@@@" 785 ] 786 }, 787 { 788 "cmd": [ 789 "adb", 790 "pull", 791 "/sdcard/revenge_of_the_skiabot/dm_out", 792 "[CUSTOM_[SWARM_OUT_DIR]]/dm" 793 ], 794 "cwd": "[START_DIR]/skia", 795 "env": { 796 "BUILDTYPE": "Debug", 797 "CHROME_HEADLESS": "1", 798 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 799 "SKIA_OUT": "[START_DIR]/out" 800 }, 801 "infra_step": true, 802 "name": "pull /sdcard/revenge_of_the_skiabot/dm_out [CUSTOM_[SWARM_OUT_DIR]]/dm" 803 }, 804 { 805 "cmd": [ 806 "python", 807 "-u", 808 "\nimport os\nimport subprocess\nimport sys\nout = sys.argv[1]\nlog = subprocess.check_output(['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", 809 "[START_DIR]/out/Debug" 810 ], 811 "env": { 812 "BUILDTYPE": "Debug", 813 "CHROME_HEADLESS": "1", 814 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 815 "SKIA_OUT": "[START_DIR]/out" 816 }, 817 "infra_step": true, 818 "name": "dump log", 819 "~followup_annotations": [ 820 "@@@STEP_LOG_LINE@python.inline@@@@", 821 "@@@STEP_LOG_LINE@python.inline@import os@@@", 822 "@@@STEP_LOG_LINE@python.inline@import subprocess@@@", 823 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 824 "@@@STEP_LOG_LINE@python.inline@out = sys.argv[1]@@@", 825 "@@@STEP_LOG_LINE@python.inline@log = subprocess.check_output(['adb', 'logcat', '-d'])@@@", 826 "@@@STEP_LOG_LINE@python.inline@for line in log.split('\\n'):@@@", 827 "@@@STEP_LOG_LINE@python.inline@ tokens = line.split()@@@", 828 "@@@STEP_LOG_LINE@python.inline@ if len(tokens) == 11 and tokens[-7] == 'F' and tokens[-3] == 'pc':@@@", 829 "@@@STEP_LOG_LINE@python.inline@ addr, path = tokens[-2:]@@@", 830 "@@@STEP_LOG_LINE@python.inline@ local = os.path.join(out, os.path.basename(path))@@@", 831 "@@@STEP_LOG_LINE@python.inline@ if os.path.exists(local):@@@", 832 "@@@STEP_LOG_LINE@python.inline@ sym = subprocess.check_output(['addr2line', '-Cfpe', local, addr])@@@", 833 "@@@STEP_LOG_LINE@python.inline@ line = line.replace(addr, addr + ' ' + sym.strip())@@@", 834 "@@@STEP_LOG_LINE@python.inline@ print line@@@", 835 "@@@STEP_LOG_END@python.inline@@@" 836 ] 837 }, 838 { 839 "cmd": [ 840 "adb", 841 "kill-server" 842 ], 843 "cwd": "[START_DIR]/skia", 844 "env": { 845 "BUILDTYPE": "Debug", 846 "CHROME_HEADLESS": "1", 847 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 848 "SKIA_OUT": "[START_DIR]/out" 849 }, 850 "infra_step": true, 851 "name": "kill adb server" 852 }, 853 { 854 "name": "$result", 855 "recipe_result": null, 856 "status_code": 0 857 } 858]