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]/cache/work" 13 ], 14 "infra_step": true, 15 "name": "makedirs checkout_path" 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 "remove", 25 "[START_DIR]/cache/work/.gclient_entries" 26 ], 27 "infra_step": true, 28 "name": "remove [START_DIR]/cache/work/.gclient_entries" 29 }, 30 { 31 "cmd": [ 32 "python", 33 "-u", 34 "RECIPE_MODULE[depot_tools::bot_update]/resources/bot_update.py", 35 "--spec-path", 36 "cache_dir = '[START_DIR]/cache/git'\nsolutions = [{'deps_file': '.DEPS.git', 'managed': False, 'name': 'skia', 'url': 'https://skia.googlesource.com/skia.git'}]", 37 "--patch_root", 38 "skia", 39 "--revision_mapping_file", 40 "{\"got_revision\": \"skia\"}", 41 "--git-cache-dir", 42 "[START_DIR]/cache/git", 43 "--cleanup-dir", 44 "[CLEANUP]/bot_update", 45 "--output_json", 46 "/path/to/tmp/json", 47 "--patch_ref", 48 "https://skia.googlesource.com/skia.git@89/456789/12", 49 "--revision", 50 "skia@abc123" 51 ], 52 "cwd": "[START_DIR]/cache/work", 53 "env_prefixes": { 54 "PATH": [ 55 "RECIPE_PACKAGE_REPO[depot_tools]" 56 ] 57 }, 58 "infra_step": true, 59 "name": "bot_update", 60 "~followup_annotations": [ 61 "@@@STEP_TEXT@Some step text@@@", 62 "@@@STEP_LOG_LINE@json.output@{@@@", 63 "@@@STEP_LOG_LINE@json.output@ \"did_run\": true, @@@", 64 "@@@STEP_LOG_LINE@json.output@ \"fixed_revisions\": {@@@", 65 "@@@STEP_LOG_LINE@json.output@ \"skia\": \"abc123\"@@@", 66 "@@@STEP_LOG_LINE@json.output@ }, @@@", 67 "@@@STEP_LOG_LINE@json.output@ \"manifest\": {@@@", 68 "@@@STEP_LOG_LINE@json.output@ \"skia\": {@@@", 69 "@@@STEP_LOG_LINE@json.output@ \"repository\": \"https://fake.org/skia.git\", @@@", 70 "@@@STEP_LOG_LINE@json.output@ \"revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@", 71 "@@@STEP_LOG_LINE@json.output@ }@@@", 72 "@@@STEP_LOG_LINE@json.output@ }, @@@", 73 "@@@STEP_LOG_LINE@json.output@ \"patch_failure\": false, @@@", 74 "@@@STEP_LOG_LINE@json.output@ \"patch_root\": \"skia\", @@@", 75 "@@@STEP_LOG_LINE@json.output@ \"properties\": {@@@", 76 "@@@STEP_LOG_LINE@json.output@ \"got_revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\", @@@", 77 "@@@STEP_LOG_LINE@json.output@ \"got_revision_cp\": \"refs/heads/master@{#164710}\"@@@", 78 "@@@STEP_LOG_LINE@json.output@ }, @@@", 79 "@@@STEP_LOG_LINE@json.output@ \"root\": \"skia\", @@@", 80 "@@@STEP_LOG_LINE@json.output@ \"source_manifest\": {@@@", 81 "@@@STEP_LOG_LINE@json.output@ \"directories\": {@@@", 82 "@@@STEP_LOG_LINE@json.output@ \"skia\": {@@@", 83 "@@@STEP_LOG_LINE@json.output@ \"git_checkout\": {@@@", 84 "@@@STEP_LOG_LINE@json.output@ \"repo_url\": \"https://fake.org/skia.git\", @@@", 85 "@@@STEP_LOG_LINE@json.output@ \"revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@", 86 "@@@STEP_LOG_LINE@json.output@ }@@@", 87 "@@@STEP_LOG_LINE@json.output@ }@@@", 88 "@@@STEP_LOG_LINE@json.output@ }, @@@", 89 "@@@STEP_LOG_LINE@json.output@ \"version\": 0@@@", 90 "@@@STEP_LOG_LINE@json.output@ }, @@@", 91 "@@@STEP_LOG_LINE@json.output@ \"step_text\": \"Some step text\"@@@", 92 "@@@STEP_LOG_LINE@json.output@}@@@", 93 "@@@STEP_LOG_END@json.output@@@", 94 "@@@SET_BUILD_PROPERTY@got_revision@\"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@", 95 "@@@SET_BUILD_PROPERTY@got_revision_cp@\"refs/heads/master@{#164710}\"@@@" 96 ] 97 }, 98 { 99 "cmd": [ 100 "python", 101 "-u", 102 "RECIPE_MODULE[recipe_engine::file]/resources/fileutil.py", 103 "--json-output", 104 "/path/to/tmp/json", 105 "ensure-directory", 106 "--mode", 107 "0777", 108 "[START_DIR]/[SWARM_OUT_DIR]" 109 ], 110 "infra_step": true, 111 "name": "mkdirs out_dir" 112 }, 113 { 114 "cmd": [ 115 "python", 116 "-u", 117 "import errno\nimport os\nimport shutil\nimport sys\n\ncopy_dest = sys.argv[1]\nbase_dir = sys.argv[2]\nbundle_name = sys.argv[3]\nout_dir = sys.argv[4]\n\n# Clean out old binaries (if any)\ntry:\n shutil.rmtree(copy_dest)\nexcept OSError as e:\n if e.errno != errno.ENOENT:\n raise\n\n# Make folder\ntry:\n os.makedirs(copy_dest)\nexcept OSError as e:\n if e.errno != errno.EEXIST:\n raise\n\n# Copy binaries (canvaskit.js and canvaskit.wasm) to where the karma tests\n# expect them ($SKIA_ROOT/experimental/canvaskit/canvaskit/bin/)\ndest = os.path.join(copy_dest, 'canvaskit.js')\nshutil.copyfile(os.path.join(base_dir, 'canvaskit.js'), dest)\nos.chmod(dest, 0o644) # important, otherwise non-privileged docker can't read.\n\nif bundle_name:\n dest = os.path.join(copy_dest, bundle_name)\n shutil.copyfile(os.path.join(base_dir, bundle_name), dest)\n os.chmod(dest, 0o644) # important, otherwise non-privileged docker can't read.\n\n# Prepare output folder, api.file.ensure_directory doesn't touch\n# the permissions of the out directory if it already exists.\nos.chmod(out_dir, 0o777) # important, otherwise non-privileged docker can't write.\n", 118 "[START_DIR]/cache/work/skia/experimental/canvaskit/canvaskit/bin", 119 "[START_DIR]/build", 120 "canvaskit.wasm", 121 "[START_DIR]/[SWARM_OUT_DIR]" 122 ], 123 "infra_step": true, 124 "name": "Set up for docker", 125 "~followup_annotations": [ 126 "@@@STEP_LOG_LINE@python.inline@import errno@@@", 127 "@@@STEP_LOG_LINE@python.inline@import os@@@", 128 "@@@STEP_LOG_LINE@python.inline@import shutil@@@", 129 "@@@STEP_LOG_LINE@python.inline@import sys@@@", 130 "@@@STEP_LOG_LINE@python.inline@@@@", 131 "@@@STEP_LOG_LINE@python.inline@copy_dest = sys.argv[1]@@@", 132 "@@@STEP_LOG_LINE@python.inline@base_dir = sys.argv[2]@@@", 133 "@@@STEP_LOG_LINE@python.inline@bundle_name = sys.argv[3]@@@", 134 "@@@STEP_LOG_LINE@python.inline@out_dir = sys.argv[4]@@@", 135 "@@@STEP_LOG_LINE@python.inline@@@@", 136 "@@@STEP_LOG_LINE@python.inline@# Clean out old binaries (if any)@@@", 137 "@@@STEP_LOG_LINE@python.inline@try:@@@", 138 "@@@STEP_LOG_LINE@python.inline@ shutil.rmtree(copy_dest)@@@", 139 "@@@STEP_LOG_LINE@python.inline@except OSError as e:@@@", 140 "@@@STEP_LOG_LINE@python.inline@ if e.errno != errno.ENOENT:@@@", 141 "@@@STEP_LOG_LINE@python.inline@ raise@@@", 142 "@@@STEP_LOG_LINE@python.inline@@@@", 143 "@@@STEP_LOG_LINE@python.inline@# Make folder@@@", 144 "@@@STEP_LOG_LINE@python.inline@try:@@@", 145 "@@@STEP_LOG_LINE@python.inline@ os.makedirs(copy_dest)@@@", 146 "@@@STEP_LOG_LINE@python.inline@except OSError as e:@@@", 147 "@@@STEP_LOG_LINE@python.inline@ if e.errno != errno.EEXIST:@@@", 148 "@@@STEP_LOG_LINE@python.inline@ raise@@@", 149 "@@@STEP_LOG_LINE@python.inline@@@@", 150 "@@@STEP_LOG_LINE@python.inline@# Copy binaries (canvaskit.js and canvaskit.wasm) to where the karma tests@@@", 151 "@@@STEP_LOG_LINE@python.inline@# expect them ($SKIA_ROOT/experimental/canvaskit/canvaskit/bin/)@@@", 152 "@@@STEP_LOG_LINE@python.inline@dest = os.path.join(copy_dest, 'canvaskit.js')@@@", 153 "@@@STEP_LOG_LINE@python.inline@shutil.copyfile(os.path.join(base_dir, 'canvaskit.js'), dest)@@@", 154 "@@@STEP_LOG_LINE@python.inline@os.chmod(dest, 0o644) # important, otherwise non-privileged docker can't read.@@@", 155 "@@@STEP_LOG_LINE@python.inline@@@@", 156 "@@@STEP_LOG_LINE@python.inline@if bundle_name:@@@", 157 "@@@STEP_LOG_LINE@python.inline@ dest = os.path.join(copy_dest, bundle_name)@@@", 158 "@@@STEP_LOG_LINE@python.inline@ shutil.copyfile(os.path.join(base_dir, bundle_name), dest)@@@", 159 "@@@STEP_LOG_LINE@python.inline@ os.chmod(dest, 0o644) # important, otherwise non-privileged docker can't read.@@@", 160 "@@@STEP_LOG_LINE@python.inline@@@@", 161 "@@@STEP_LOG_LINE@python.inline@# Prepare output folder, api.file.ensure_directory doesn't touch@@@", 162 "@@@STEP_LOG_LINE@python.inline@# the permissions of the out directory if it already exists.@@@", 163 "@@@STEP_LOG_LINE@python.inline@os.chmod(out_dir, 0o777) # important, otherwise non-privileged docker can't write.@@@", 164 "@@@STEP_LOG_END@python.inline@@@" 165 ] 166 }, 167 { 168 "cmd": [ 169 "python", 170 "-u", 171 "import os\nprint os.environ.get('SWARMING_BOT_ID', '')\n" 172 ], 173 "name": "get swarming bot id", 174 "stdout": "/path/to/tmp/", 175 "~followup_annotations": [ 176 "@@@STEP_LOG_LINE@python.inline@import os@@@", 177 "@@@STEP_LOG_LINE@python.inline@print os.environ.get('SWARMING_BOT_ID', '')@@@", 178 "@@@STEP_LOG_END@python.inline@@@" 179 ] 180 }, 181 { 182 "cmd": [ 183 "python", 184 "-u", 185 "import os\nprint os.environ.get('SWARMING_TASK_ID', '')\n" 186 ], 187 "name": "get swarming task id", 188 "stdout": "/path/to/tmp/", 189 "~followup_annotations": [ 190 "@@@STEP_LOG_LINE@python.inline@import os@@@", 191 "@@@STEP_LOG_LINE@python.inline@print os.environ.get('SWARMING_TASK_ID', '')@@@", 192 "@@@STEP_LOG_END@python.inline@@@" 193 ] 194 }, 195 { 196 "cmd": [ 197 "docker", 198 "run", 199 "--shm-size=2gb", 200 "--rm", 201 "--volume", 202 "[START_DIR]/cache/work:/SRC", 203 "--volume", 204 "[START_DIR]/[SWARM_OUT_DIR]:/OUT", 205 "gcr.io/skia-public/perf-karma-chrome-tests:68.0.3440.106_v6", 206 "/SRC/skia/infra/canvaskit/perf_canvaskit.sh", 207 "--builder", 208 "Perf-Debian9-EMCC-GCE-GPU-AVX2-wasm-Release-All-CanvasKit", 209 "--git_hash", 210 "abc123", 211 "--buildbucket_build_id", 212 "", 213 "--bot_id", 214 "", 215 "--task_id", 216 "", 217 "--browser", 218 "Chrome", 219 "--config", 220 "Release", 221 "--source_type", 222 "canvaskit", 223 "--issue", 224 "1234", 225 "--patchset", 226 "7", 227 "--patch_storage", 228 "gerrit" 229 ], 230 "env": { 231 "CHROME_HEADLESS": "1", 232 "DOCKER_CONFIG": "/home/chrome-bot/.docker", 233 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]" 234 }, 235 "name": "Performance tests of canvaskit with Docker" 236 }, 237 { 238 "jsonResult": null, 239 "name": "$result" 240 } 241]