1 [ 2 { 3 "cmd": [ 4 "python", 5 "-u", 6 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 7 "--json-output", 8 "/path/to/tmp/json", 9 "ensure-directory", 10 "--mode", 11 "0777", 12 "[START_DIR]/tmp" 13 ], 14 "infra_step": true, 15 "name": "makedirs tmp_dir" 16 }, 17 { 18 "cmd": [ 19 "python", 20 "-u", 21 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 22 "--json-output", 23 "/path/to/tmp/json", 24 "copy", 25 "[START_DIR]/skia/infra/bots/assets/skp/VERSION", 26 "/path/to/tmp/" 27 ], 28 "infra_step": true, 29 "name": "Get skp VERSION" 30 }, 31 { 32 "cmd": [ 33 "python", 34 "-u", 35 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 36 "--json-output", 37 "/path/to/tmp/json", 38 "copy", 39 "42", 40 "[START_DIR]/tmp/SKP_VERSION" 41 ], 42 "infra_step": true, 43 "name": "write SKP_VERSION" 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 "copy", 53 "[START_DIR]/skia/infra/bots/assets/skimage/VERSION", 54 "/path/to/tmp/" 55 ], 56 "infra_step": true, 57 "name": "Get skimage VERSION" 58 }, 59 { 60 "cmd": [ 61 "python", 62 "-u", 63 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 64 "--json-output", 65 "/path/to/tmp/json", 66 "copy", 67 "42", 68 "[START_DIR]/tmp/SK_IMAGE_VERSION" 69 ], 70 "infra_step": true, 71 "name": "write SK_IMAGE_VERSION" 72 }, 73 { 74 "cmd": [ 75 "python", 76 "-u", 77 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 78 "--json-output", 79 "/path/to/tmp/json", 80 "copy", 81 "[START_DIR]/skia/infra/bots/assets/svg/VERSION", 82 "/path/to/tmp/" 83 ], 84 "infra_step": true, 85 "name": "Get svg VERSION" 86 }, 87 { 88 "cmd": [ 89 "python", 90 "-u", 91 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 92 "--json-output", 93 "/path/to/tmp/json", 94 "copy", 95 "42", 96 "[START_DIR]/tmp/SVG_VERSION" 97 ], 98 "infra_step": true, 99 "name": "write SVG_VERSION" 100 }, 101 { 102 "cmd": [ 103 "python", 104 "-u", 105 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 106 "--json-output", 107 "/path/to/tmp/json", 108 "rmtree", 109 "[START_DIR]/test" 110 ], 111 "infra_step": true, 112 "name": "rmtree test" 113 }, 114 { 115 "cmd": [ 116 "python", 117 "-u", 118 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 119 "--json-output", 120 "/path/to/tmp/json", 121 "ensure-directory", 122 "--mode", 123 "0777", 124 "[START_DIR]/test" 125 ], 126 "infra_step": true, 127 "name": "makedirs test" 128 }, 129 { 130 "cmd": [ 131 "python", 132 "-u", 133 "\nimport contextlib\nimport math\nimport socket\nimport sys\nimport time\nimport urllib2\n\nHASHES_URL = sys.argv[1]\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[2], '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", 134 "https://example.com/hashes.txt", 135 "[START_DIR]/tmp/uninteresting_hashes.txt" 136 ], 137 "env": { 138 "CHROME_HEADLESS": "1", 139 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]" 140 }, 141 "infra_step": true, 142 "name": "get uninteresting hashes", 143 "~followup_annotations": [ 144 "@@@STEP_LOG_LINE (a] python.inline@@@@", 145 "@@@STEP_LOG_LINE (a] python.inline@import contextlib@@@", 146 "@@@STEP_LOG_LINE (a] python.inline@import math@@@", 147 "@@@STEP_LOG_LINE (a] python.inline@import socket@@@", 148 "@@@STEP_LOG_LINE (a] python.inline@import sys@@@", 149 "@@@STEP_LOG_LINE (a] python.inline@import time@@@", 150 "@@@STEP_LOG_LINE (a] python.inline@import urllib2@@@", 151 "@@@STEP_LOG_LINE (a] python.inline@@@@", 152 "@@@STEP_LOG_LINE (a] python.inline@HASHES_URL = sys.argv[1]@@@", 153 "@@@STEP_LOG_LINE (a] python.inline@RETRIES = 5@@@", 154 "@@@STEP_LOG_LINE (a] python.inline@TIMEOUT = 60@@@", 155 "@@@STEP_LOG_LINE (a] python.inline@WAIT_BASE = 15@@@", 156 "@@@STEP_LOG_LINE (a] python.inline@@@@", 157 "@@@STEP_LOG_LINE (a] python.inline@socket.setdefaulttimeout(TIMEOUT)@@@", 158 "@@@STEP_LOG_LINE (a] python.inline@for retry in range(RETRIES):@@@", 159 "@@@STEP_LOG_LINE (a] python.inline@ try:@@@", 160 "@@@STEP_LOG_LINE (a] python.inline@ with contextlib.closing(@@@", 161 "@@@STEP_LOG_LINE (a] python.inline@ urllib2.urlopen(HASHES_URL, timeout=TIMEOUT)) as w:@@@", 162 "@@@STEP_LOG_LINE (a] python.inline@ hashes = w.read()@@@", 163 "@@@STEP_LOG_LINE (a] python.inline@ with open(sys.argv[2], 'w') as f:@@@", 164 "@@@STEP_LOG_LINE (a] python.inline@ f.write(hashes)@@@", 165 "@@@STEP_LOG_LINE (a] python.inline@ break@@@", 166 "@@@STEP_LOG_LINE (a] python.inline@ except Exception as e:@@@", 167 "@@@STEP_LOG_LINE (a] python.inline@ print 'Failed to get uninteresting hashes from %s:' % HASHES_URL@@@", 168 "@@@STEP_LOG_LINE (a] python.inline@ print e@@@", 169 "@@@STEP_LOG_LINE (a] python.inline@ if retry == RETRIES:@@@", 170 "@@@STEP_LOG_LINE (a] python.inline@ raise@@@", 171 "@@@STEP_LOG_LINE (a] python.inline@ waittime = WAIT_BASE * math.pow(2, retry)@@@", 172 "@@@STEP_LOG_LINE (a] python.inline@ print 'Retry in %d seconds.' % waittime@@@", 173 "@@@STEP_LOG_LINE (a] python.inline@ time.sleep(waittime)@@@", 174 "@@@STEP_LOG_END (a] python.inline@@@" 175 ] 176 }, 177 { 178 "cmd": [ 179 "python", 180 "-u", 181 "import os\nprint os.environ.get('SWARMING_BOT_ID', '')\n" 182 ], 183 "name": "get swarming bot id", 184 "stdout": "/path/to/tmp/", 185 "~followup_annotations": [ 186 "@@@STEP_LOG_LINE (a] python.inline@import os@@@", 187 "@@@STEP_LOG_LINE (a] python.inline@print os.environ.get('SWARMING_BOT_ID', '')@@@", 188 "@@@STEP_LOG_END (a] python.inline@@@" 189 ] 190 }, 191 { 192 "cmd": [ 193 "python", 194 "-u", 195 "import os\nprint os.environ.get('SWARMING_TASK_ID', '')\n" 196 ], 197 "name": "get swarming task id", 198 "stdout": "/path/to/tmp/", 199 "~followup_annotations": [ 200 "@@@STEP_LOG_LINE (a] python.inline@import os@@@", 201 "@@@STEP_LOG_LINE (a] python.inline@print os.environ.get('SWARMING_TASK_ID', '')@@@", 202 "@@@STEP_LOG_END (a] python.inline@@@" 203 ] 204 }, 205 { 206 "cmd": [ 207 "[START_DIR]/build/dm", 208 "--resourcePath", 209 "[START_DIR]/skia/resources", 210 "--skps", 211 "[START_DIR]/skp", 212 "--images", 213 "[START_DIR]/skimage/dm", 214 "--colorImages", 215 "[START_DIR]/skimage/colorspace", 216 "--nameByHash", 217 "--properties", 218 "gitHash", 219 "abc123", 220 "builder", 221 "Test-Win8-Clang-Golo-CPU-AVX-x86-Debug-All", 222 "buildbucket_build_id", 223 "123454321", 224 "issue", 225 "456789", 226 "patchset", 227 "12", 228 "patch_storage", 229 "gerrit", 230 "swarming_bot_id", 231 "", 232 "swarming_task_id", 233 "", 234 "--svgs", 235 "[START_DIR]/svg", 236 "--key", 237 "arch", 238 "x86", 239 "compiler", 240 "Clang", 241 "configuration", 242 "Debug", 243 "cpu_or_gpu", 244 "CPU", 245 "cpu_or_gpu_value", 246 "AVX", 247 "model", 248 "Golo", 249 "os", 250 "Win8", 251 "--uninterestingHashesFile", 252 "[START_DIR]/tmp/uninteresting_hashes.txt", 253 "--writePath", 254 "[START_DIR]/[SWARM_OUT_DIR]", 255 "--dont_write", 256 "pdf", 257 "--randomProcessorTest", 258 "--threads", 259 "4", 260 "--nogpu", 261 "--config", 262 "8888", 263 "--src", 264 "tests", 265 "gm", 266 "image", 267 "colorImage", 268 "--blacklist", 269 "_", 270 "image", 271 "gen_platf", 272 "pal8os2v2.bmp", 273 "_", 274 "image", 275 "gen_platf", 276 "pal8os2v2-16.bmp", 277 "_", 278 "image", 279 "gen_platf", 280 "rgba32abf.bmp", 281 "_", 282 "image", 283 "gen_platf", 284 "rgb24prof.bmp", 285 "_", 286 "image", 287 "gen_platf", 288 "rgb24lprof.bmp", 289 "_", 290 "image", 291 "gen_platf", 292 "8bpp-pixeldata-cropped.bmp", 293 "_", 294 "image", 295 "gen_platf", 296 "4bpp-pixeldata-cropped.bmp", 297 "_", 298 "image", 299 "gen_platf", 300 "32bpp-pixeldata-cropped.bmp", 301 "_", 302 "image", 303 "gen_platf", 304 "24bpp-pixeldata-cropped.bmp", 305 "_", 306 "image", 307 "gen_platf", 308 "testimgari.jpg", 309 "_", 310 "image", 311 "gen_platf", 312 "rle8-height-negative.bmp", 313 "_", 314 "image", 315 "gen_platf", 316 "rle4-height-negative.bmp", 317 "_", 318 "image", 319 "gen_platf", 320 "error", 321 "_", 322 "image", 323 "f16", 324 "_", 325 "_", 326 "image", 327 "_", 328 "abnormal.wbmp", 329 "_", 330 "image", 331 "_", 332 "interlaced1.png", 333 "_", 334 "image", 335 "_", 336 "interlaced2.png", 337 "_", 338 "image", 339 "_", 340 "interlaced3.png", 341 "_", 342 "image", 343 "_", 344 ".arw", 345 "_", 346 "image", 347 "_", 348 ".cr2", 349 "_", 350 "image", 351 "_", 352 ".dng", 353 "_", 354 "image", 355 "_", 356 ".nef", 357 "_", 358 "image", 359 "_", 360 ".nrw", 361 "_", 362 "image", 363 "_", 364 ".orf", 365 "_", 366 "image", 367 "_", 368 ".raf", 369 "_", 370 "image", 371 "_", 372 ".rw2", 373 "_", 374 "image", 375 "_", 376 ".pef", 377 "_", 378 "image", 379 "_", 380 ".srw", 381 "_", 382 "image", 383 "_", 384 ".ARW", 385 "_", 386 "image", 387 "_", 388 ".CR2", 389 "_", 390 "image", 391 "_", 392 ".DNG", 393 "_", 394 "image", 395 "_", 396 ".NEF", 397 "_", 398 "image", 399 "_", 400 ".NRW", 401 "_", 402 "image", 403 "_", 404 ".ORF", 405 "_", 406 "image", 407 "_", 408 ".RAF", 409 "_", 410 "image", 411 "_", 412 ".RW2", 413 "_", 414 "image", 415 "_", 416 ".PEF", 417 "_", 418 "image", 419 "_", 420 ".SRW", 421 "--nonativeFonts", 422 "--verbose" 423 ], 424 "env": { 425 "CHROME_HEADLESS": "1", 426 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]" 427 }, 428 "name": "dm" 429 }, 430 { 431 "jsonResult": null, 432 "name": "$result" 433 } 434 ]