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 "[CUSTOM_/_B_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 "[CUSTOM_/_B_WORK]/.gclient_entries" 26 ], 27 "infra_step": true, 28 "name": "remove [CUSTOM_/_B_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 = '[CUSTOM_/_B_CACHE]'\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 "[CUSTOM_/_B_CACHE]", 43 "--cleanup-dir", 44 "[CLEANUP]/bot_update", 45 "--output_json", 46 "/path/to/tmp/json", 47 "--revision", 48 "skia@abc123" 49 ], 50 "cwd": "[CUSTOM_/_B_WORK]", 51 "env_prefixes": { 52 "PATH": [ 53 "RECIPE_PACKAGE_REPO[depot_tools]" 54 ] 55 }, 56 "infra_step": true, 57 "name": "bot_update", 58 "~followup_annotations": [ 59 "@@@STEP_TEXT@Some step text@@@", 60 "@@@STEP_LOG_LINE (a] json.output@{@@@", 61 "@@@STEP_LOG_LINE (a] json.output@ \"did_run\": true, @@@", 62 "@@@STEP_LOG_LINE (a] json.output@ \"fixed_revisions\": {@@@", 63 "@@@STEP_LOG_LINE (a] json.output@ \"skia\": \"abc123\"@@@", 64 "@@@STEP_LOG_LINE (a] json.output@ }, @@@", 65 "@@@STEP_LOG_LINE (a] json.output@ \"manifest\": {@@@", 66 "@@@STEP_LOG_LINE (a] json.output@ \"skia\": {@@@", 67 "@@@STEP_LOG_LINE (a] json.output@ \"repository\": \"https://fake.org/skia.git\", @@@", 68 "@@@STEP_LOG_LINE (a] json.output@ \"revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@", 69 "@@@STEP_LOG_LINE (a] json.output@ }@@@", 70 "@@@STEP_LOG_LINE (a] json.output@ }, @@@", 71 "@@@STEP_LOG_LINE (a] json.output@ \"patch_failure\": false, @@@", 72 "@@@STEP_LOG_LINE (a] json.output@ \"patch_root\": \"skia\", @@@", 73 "@@@STEP_LOG_LINE (a] json.output@ \"properties\": {@@@", 74 "@@@STEP_LOG_LINE (a] json.output@ \"got_revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\", @@@", 75 "@@@STEP_LOG_LINE (a] json.output@ \"got_revision_cp\": \"refs/heads/master@{#164710}\"@@@", 76 "@@@STEP_LOG_LINE (a] json.output@ }, @@@", 77 "@@@STEP_LOG_LINE (a] json.output@ \"root\": \"skia\", @@@", 78 "@@@STEP_LOG_LINE (a] json.output@ \"source_manifest\": {@@@", 79 "@@@STEP_LOG_LINE (a] json.output@ \"directories\": {@@@", 80 "@@@STEP_LOG_LINE (a] json.output@ \"skia\": {@@@", 81 "@@@STEP_LOG_LINE (a] json.output@ \"git_checkout\": {@@@", 82 "@@@STEP_LOG_LINE (a] json.output@ \"repo_url\": \"https://fake.org/skia.git\", @@@", 83 "@@@STEP_LOG_LINE (a] json.output@ \"revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@", 84 "@@@STEP_LOG_LINE (a] json.output@ }@@@", 85 "@@@STEP_LOG_LINE (a] json.output@ }@@@", 86 "@@@STEP_LOG_LINE (a] json.output@ }, @@@", 87 "@@@STEP_LOG_LINE (a] json.output@ \"version\": 0@@@", 88 "@@@STEP_LOG_LINE (a] json.output@ }, @@@", 89 "@@@STEP_LOG_LINE (a] json.output@ \"step_text\": \"Some step text\"@@@", 90 "@@@STEP_LOG_LINE (a] json.output@}@@@", 91 "@@@STEP_LOG_END (a] json.output@@@", 92 "@@@SET_BUILD_PROPERTY@got_revision@\"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@", 93 "@@@SET_BUILD_PROPERTY@got_revision_cp@\"refs/heads/master@{#164710}\"@@@" 94 ] 95 }, 96 { 97 "cmd": [ 98 "python", 99 "-u", 100 "[CUSTOM_/_B_WORK]/skia/bin/fetch-gn" 101 ], 102 "cwd": "[CUSTOM_/_B_WORK]/skia", 103 "env": { 104 "BUILDTYPE": "Release", 105 "CHROME_HEADLESS": "1", 106 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 107 "SKIA_OUT": "[CUSTOM_/_B_WORK]/skia/out/Build-Debian9-GCC-arm-Release-Chromecast" 108 }, 109 "infra_step": true, 110 "name": "fetch-gn" 111 }, 112 { 113 "cmd": [ 114 "[CUSTOM_/_B_WORK]/skia/bin/gn", 115 "gen", 116 "[CUSTOM_/_B_WORK]/skia/out/Build-Debian9-GCC-arm-Release-Chromecast/Release", 117 "--args=ar=\"[START_DIR]/cast_toolchain/armv7a/bin/armv7a-cros-linux-gnueabi-ar\" cc=\"[START_DIR]/cast_toolchain/armv7a/bin/armv7a-cros-linux-gnueabi-gcc\" cxx=\"[START_DIR]/cast_toolchain/armv7a/bin/armv7a-cros-linux-gnueabi-g++\" extra_cflags=[\"-I[START_DIR]/chromebook_arm_gles/include\", \"-DMESA_EGL_NO_X11_HEADERS\", \"-DSK_NO_COMMAND_BUFFER\", \"-Wno-error=unused-function\", \"-g0\"] extra_ldflags=[\"-static-libstdc++\", \"-static-libgcc\", \"-L[START_DIR]/cast_toolchain/armv7a/lib\"] is_debug=false skia_enable_gpu=true skia_use_egl=true skia_use_fontconfig=false skia_use_icu=false skia_use_system_freetype2=false target_cpu=\"arm\"" 118 ], 119 "cwd": "[CUSTOM_/_B_WORK]/skia", 120 "env": { 121 "BUILDTYPE": "Release", 122 "CHROME_HEADLESS": "1", 123 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 124 "SKIA_OUT": "[CUSTOM_/_B_WORK]/skia/out/Build-Debian9-GCC-arm-Release-Chromecast" 125 }, 126 "name": "gn gen" 127 }, 128 { 129 "cmd": [ 130 "ninja", 131 "-k", 132 "0", 133 "-C", 134 "[CUSTOM_/_B_WORK]/skia/out/Build-Debian9-GCC-arm-Release-Chromecast/Release", 135 "nanobench", 136 "dm" 137 ], 138 "cwd": "[CUSTOM_/_B_WORK]/skia", 139 "env": { 140 "BUILDTYPE": "Release", 141 "CHROME_HEADLESS": "1", 142 "PATH": "<PATH>:RECIPE_PACKAGE_REPO[depot_tools]", 143 "SKIA_OUT": "[CUSTOM_/_B_WORK]/skia/out/Build-Debian9-GCC-arm-Release-Chromecast" 144 }, 145 "name": "ninja" 146 }, 147 { 148 "cmd": [ 149 "python", 150 "-u", 151 "import errno\nimport glob\nimport os\nimport shutil\nimport sys\n\nsrc = sys.argv[1]\ndst = sys.argv[2]\nbuild_products_whitelist = ['bookmaker', 'dm', 'dm.exe', 'dm.app', 'nanobench.app', 'get_images_from_skps', 'get_images_from_skps.exe', 'nanobench', 'nanobench.exe', 'skpbench', '*.so', '*.dll', '*.dylib', 'skia_launcher', 'skiaserve', 'lib/*.so']\n\ntry:\n os.makedirs(dst)\nexcept OSError as e:\n if e.errno != errno.EEXIST:\n raise\n\nfor pattern in build_products_whitelist:\n path = os.path.join(src, pattern)\n for f in glob.glob(path):\n dst_path = os.path.join(dst, os.path.relpath(f, src))\n if not os.path.isdir(os.path.dirname(dst_path)):\n os.makedirs(os.path.dirname(dst_path))\n print 'Copying build product %s to %s' % (f, dst_path)\n shutil.move(f, dst_path)\n", 152 "[CUSTOM_/_B_WORK]/skia/out/Build-Debian9-GCC-arm-Release-Chromecast/Release", 153 "[CUSTOM_[SWARM_OUT_DIR]]/out/Release" 154 ], 155 "infra_step": true, 156 "name": "copy build products", 157 "~followup_annotations": [ 158 "@@@STEP_LOG_LINE (a] python.inline@import errno@@@", 159 "@@@STEP_LOG_LINE (a] python.inline@import glob@@@", 160 "@@@STEP_LOG_LINE (a] python.inline@import os@@@", 161 "@@@STEP_LOG_LINE (a] python.inline@import shutil@@@", 162 "@@@STEP_LOG_LINE (a] python.inline@import sys@@@", 163 "@@@STEP_LOG_LINE (a] python.inline@@@@", 164 "@@@STEP_LOG_LINE (a] python.inline@src = sys.argv[1]@@@", 165 "@@@STEP_LOG_LINE (a] python.inline@dst = sys.argv[2]@@@", 166 "@@@STEP_LOG_LINE (a] python.inline@build_products_whitelist = ['bookmaker', 'dm', 'dm.exe', 'dm.app', 'nanobench.app', 'get_images_from_skps', 'get_images_from_skps.exe', 'nanobench', 'nanobench.exe', 'skpbench', '*.so', '*.dll', '*.dylib', 'skia_launcher', 'skiaserve', 'lib/*.so']@@@", 167 "@@@STEP_LOG_LINE (a] python.inline@@@@", 168 "@@@STEP_LOG_LINE (a] python.inline@try:@@@", 169 "@@@STEP_LOG_LINE (a] python.inline@ os.makedirs(dst)@@@", 170 "@@@STEP_LOG_LINE (a] python.inline@except OSError as e:@@@", 171 "@@@STEP_LOG_LINE (a] python.inline@ if e.errno != errno.EEXIST:@@@", 172 "@@@STEP_LOG_LINE (a] python.inline@ raise@@@", 173 "@@@STEP_LOG_LINE (a] python.inline@@@@", 174 "@@@STEP_LOG_LINE (a] python.inline@for pattern in build_products_whitelist:@@@", 175 "@@@STEP_LOG_LINE (a] python.inline@ path = os.path.join(src, pattern)@@@", 176 "@@@STEP_LOG_LINE (a] python.inline@ for f in glob.glob(path):@@@", 177 "@@@STEP_LOG_LINE (a] python.inline@ dst_path = os.path.join(dst, os.path.relpath(f, src))@@@", 178 "@@@STEP_LOG_LINE (a] python.inline@ if not os.path.isdir(os.path.dirname(dst_path)):@@@", 179 "@@@STEP_LOG_LINE (a] python.inline@ os.makedirs(os.path.dirname(dst_path))@@@", 180 "@@@STEP_LOG_LINE (a] python.inline@ print 'Copying build product %s to %s' % (f, dst_path)@@@", 181 "@@@STEP_LOG_LINE (a] python.inline@ shutil.move(f, dst_path)@@@", 182 "@@@STEP_LOG_END (a] python.inline@@@" 183 ] 184 }, 185 { 186 "name": "$result", 187 "recipe_result": null, 188 "status_code": 0 189 } 190 ]