2017-02-02 14:02:37 +00:00
[
{
"cmd" : [
"python" ,
"-u" ,
2017-07-07 21:36:58 +00:00
"RECIPE_MODULE[recipe_engine::file]\\resources\\fileutil.py" ,
"--json-output" ,
"/path/to/tmp/json" ,
"ensure-directory" ,
"--mode" ,
"0777" ,
"[CUSTOM_C:\\_B_WORK]"
2017-02-02 14:02:37 +00:00
] ,
2017-03-20 16:48:31 +00:00
"infra_step" : true ,
2017-07-07 21:36:58 +00:00
"name" : "makedirs checkout_path"
2017-02-02 14:02:37 +00:00
} ,
2017-04-19 18:39:21 +00:00
{
"cmd" : [
"python" ,
"-u" ,
2017-06-16 17:10:22 +00:00
"RECIPE_MODULE[recipe_engine::file]\\resources\\fileutil.py" ,
"--json-output" ,
"/path/to/tmp/json" ,
"remove" ,
2017-04-19 18:39:21 +00:00
"[CUSTOM_C:\\_B_WORK]\\.gclient_entries"
] ,
"infra_step" : true ,
2017-06-16 17:10:22 +00:00
"name" : "remove [CUSTOM_C:\\_B_WORK]\\.gclient_entries"
2017-04-19 18:39:21 +00:00
} ,
2017-02-02 14:02:37 +00:00
{
"cmd" : [
"python" ,
"-u" ,
"RECIPE_MODULE[depot_tools::bot_update]\\resources\\bot_update.py" ,
2017-09-22 19:43:36 +00:00
"--spec-path" ,
2017-02-02 14:02:37 +00:00
"cache_dir = '[CUSTOM_C:\\\\_B_CACHE]'\nsolutions = [{'deps_file': '.DEPS.git', 'managed': False, 'name': 'skia', 'url': 'https://skia.googlesource.com/skia.git'}]" ,
"--patch_root" ,
"skia" ,
"--revision_mapping_file" ,
2017-04-29 01:59:04 +00:00
"{\"got_revision\": \"skia\"}" ,
2017-02-02 14:02:37 +00:00
"--git-cache-dir" ,
"[CUSTOM_C:\\_B_CACHE]" ,
2017-06-08 23:13:19 +00:00
"--cleanup-dir" ,
"[CLEANUP]\\bot_update" ,
2017-02-02 14:02:37 +00:00
"--output_json" ,
"/path/to/tmp/json" ,
"--revision" ,
2017-05-03 12:32:29 +00:00
"skia@abc123"
2017-02-02 14:02:37 +00:00
] ,
"cwd" : "[CUSTOM_C:\\_B_WORK]" ,
2017-09-22 19:43:36 +00:00
"env_prefixes" : {
"PATH" : [
"RECIPE_PACKAGE_REPO[depot_tools]"
]
2017-02-02 14:02:37 +00:00
} ,
2017-03-20 16:48:31 +00:00
"infra_step" : true ,
2017-02-02 14:02:37 +00:00
"name" : "bot_update" ,
"~followup_annotations" : [
"@@@STEP_TEXT@Some step text@@@" ,
"@@@STEP_LOG_LINE@json.output@{@@@" ,
"@@@STEP_LOG_LINE@json.output@ \"did_run\": true, @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"fixed_revisions\": {@@@" ,
"@@@STEP_LOG_LINE@json.output@ \"skia\": \"abc123\"@@@" ,
"@@@STEP_LOG_LINE@json.output@ }, @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"manifest\": {@@@" ,
"@@@STEP_LOG_LINE@json.output@ \"skia\": {@@@" ,
"@@@STEP_LOG_LINE@json.output@ \"repository\": \"https://fake.org/skia.git\", @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@" ,
"@@@STEP_LOG_LINE@json.output@ }@@@" ,
"@@@STEP_LOG_LINE@json.output@ }, @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"patch_failure\": false, @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"patch_root\": \"skia\", @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"properties\": {@@@" ,
"@@@STEP_LOG_LINE@json.output@ \"got_revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\", @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"got_revision_cp\": \"refs/heads/master@{#164710}\"@@@" ,
"@@@STEP_LOG_LINE@json.output@ }, @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"root\": \"skia\", @@@" ,
2017-10-31 22:53:18 +00:00
"@@@STEP_LOG_LINE@json.output@ \"source_manifest\": {@@@" ,
2017-12-08 13:21:04 +00:00
"@@@STEP_LOG_LINE@json.output@ \"directories\": {@@@" ,
2017-10-31 22:53:18 +00:00
"@@@STEP_LOG_LINE@json.output@ \"skia\": {@@@" ,
2017-12-08 13:21:04 +00:00
"@@@STEP_LOG_LINE@json.output@ \"git_checkout\": {@@@" ,
"@@@STEP_LOG_LINE@json.output@ \"repo_url\": \"https://fake.org/skia.git\", @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"revision\": \"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@" ,
"@@@STEP_LOG_LINE@json.output@ }@@@" ,
2017-10-31 22:53:18 +00:00
"@@@STEP_LOG_LINE@json.output@ }@@@" ,
"@@@STEP_LOG_LINE@json.output@ }, @@@" ,
"@@@STEP_LOG_LINE@json.output@ \"version\": 0@@@" ,
"@@@STEP_LOG_LINE@json.output@ }, @@@" ,
2017-02-02 14:02:37 +00:00
"@@@STEP_LOG_LINE@json.output@ \"step_text\": \"Some step text\"@@@" ,
"@@@STEP_LOG_LINE@json.output@}@@@" ,
"@@@STEP_LOG_END@json.output@@@" ,
"@@@SET_BUILD_PROPERTY@got_revision@\"9046e2e693bb92a76e972b694580e5d17ad10748\"@@@" ,
"@@@SET_BUILD_PROPERTY@got_revision_cp@\"refs/heads/master@{#164710}\"@@@"
]
} ,
{
"cmd" : [
"python" ,
"-u" ,
"[CUSTOM_C:\\_B_WORK]\\skia\\bin\\fetch-gn"
] ,
"cwd" : "[CUSTOM_C:\\_B_WORK]\\skia" ,
"env" : {
2017-02-06 17:45:29 +00:00
"BUILDTYPE" : "Release_x64" ,
2017-10-11 04:23:58 +00:00
"CC" : "/usr/bin/clang" ,
2017-02-06 17:45:29 +00:00
"CHROME_HEADLESS" : "1" ,
2017-10-11 04:23:58 +00:00
"CXX" : "/usr/bin/clang++" ,
2017-05-31 23:13:27 +00:00
"PATH" : "<PATH>;RECIPE_PACKAGE_REPO[depot_tools]" ,
2017-10-11 04:23:58 +00:00
"SKIA_OUT" : "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-Clang-x86_64-Release-Vulkan"
2017-02-02 14:02:37 +00:00
} ,
2017-03-20 16:48:31 +00:00
"infra_step" : true ,
2017-02-02 14:02:37 +00:00
"name" : "fetch-gn"
} ,
{
"cmd" : [
"[CUSTOM_C:\\_B_WORK]\\skia\\bin\\gn.exe" ,
"gen" ,
2017-10-11 04:23:58 +00:00
"[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-Clang-x86_64-Release-Vulkan\\Release_x64" ,
Updated MSVC toolchain to 2017, and further refactored GN
'windk' is no longer a thing. There are two separate variables to point
at your compiler (win_vc), and SDK (win_sdk).
'msvc' is no longer a thing, either. By default, we look for 2017 and
then 2015 (in the default locations). If neither is located, use an
assert to let users know they should set win_vc. Then, detect if win_vc
points at a 2017 or 2015 installation, and configure it automatically.
Because the toolchain is now 2017, update the GN files to handle building
x86 in that configuration. In fact, we only support x86 builds (with 2017
or 2015) using the toolchain assets. Keep a 2015 toolchain around as a
new asset, so we can add bot coverage.
Docs-Preview: https://skia.org/?cl=81841
Bug: skia:
Change-Id: I8c68a6f949e54c0e798a219450bbb9406f8dc6ac
Reviewed-on: https://skia-review.googlesource.com/81841
Reviewed-by: Mike Klein <mtklein@chromium.org>
Commit-Queue: Brian Osman <brianosman@google.com>
2017-12-07 21:16:21 +00:00
"--args=cc=\"clang\" clang_win=\"[START_DIR]\\clang_win\" cxx=\"clang++\" is_debug=false skia_enable_vulkan_debug_layers=false skia_vulkan_sdk=\"[START_DIR]\\win_vulkan_sdk\" target_cpu=\"x86_64\" win_sdk=\"[START_DIR]\\t\\depot_tools\\win_toolchain\\vs_files\\a9e1098bba66d2acccc377d5ee81265910f29272/win_sdk\" win_vc=\"[START_DIR]\\t\\depot_tools\\win_toolchain\\vs_files\\a9e1098bba66d2acccc377d5ee81265910f29272/VC\""
2017-02-02 14:02:37 +00:00
] ,
"cwd" : "[CUSTOM_C:\\_B_WORK]\\skia" ,
"env" : {
2017-02-06 17:45:29 +00:00
"BUILDTYPE" : "Release_x64" ,
2017-10-11 04:23:58 +00:00
"CC" : "/usr/bin/clang" ,
2017-02-06 17:45:29 +00:00
"CHROME_HEADLESS" : "1" ,
2017-10-11 04:23:58 +00:00
"CXX" : "/usr/bin/clang++" ,
2017-05-31 23:13:27 +00:00
"PATH" : "<PATH>;RECIPE_PACKAGE_REPO[depot_tools]" ,
2017-10-11 04:23:58 +00:00
"SKIA_OUT" : "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-Clang-x86_64-Release-Vulkan"
2017-02-02 14:02:37 +00:00
} ,
"name" : "gn gen"
} ,
{
"cmd" : [
"ninja.exe" ,
2017-11-06 14:28:59 +00:00
"-k" ,
"0" ,
2017-02-02 14:02:37 +00:00
"-C" ,
2018-02-20 15:05:14 +00:00
"[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-Clang-x86_64-Release-Vulkan\\Release_x64"
2017-02-02 14:02:37 +00:00
] ,
"cwd" : "[CUSTOM_C:\\_B_WORK]\\skia" ,
"env" : {
2017-02-06 17:45:29 +00:00
"BUILDTYPE" : "Release_x64" ,
2017-10-11 04:23:58 +00:00
"CC" : "/usr/bin/clang" ,
2017-02-06 17:45:29 +00:00
"CHROME_HEADLESS" : "1" ,
2017-10-11 04:23:58 +00:00
"CXX" : "/usr/bin/clang++" ,
2017-05-31 23:13:27 +00:00
"PATH" : "<PATH>;RECIPE_PACKAGE_REPO[depot_tools]" ,
2017-10-11 04:23:58 +00:00
"SKIA_OUT" : "[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-Clang-x86_64-Release-Vulkan"
2017-02-02 14:02:37 +00:00
} ,
"name" : "ninja"
} ,
{
"cmd" : [
"python" ,
"-u" ,
2018-03-07 19:44:44 +00:00
"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', 'run_testlab', 'skqp-universal-debug.apk', 'whitelist_devices.json']\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" ,
2017-10-11 04:23:58 +00:00
"[CUSTOM_C:\\_B_WORK]\\skia\\out\\Build-Win-Clang-x86_64-Release-Vulkan\\Release_x64" ,
2017-02-02 14:02:37 +00:00
"[CUSTOM_[SWARM_OUT_DIR]]\\out\\Release_x64"
] ,
2017-03-20 16:48:31 +00:00
"infra_step" : true ,
2017-02-02 14:02:37 +00:00
"name" : "copy build products" ,
"~followup_annotations" : [
"@@@STEP_LOG_LINE@python.inline@import errno@@@" ,
"@@@STEP_LOG_LINE@python.inline@import glob@@@" ,
"@@@STEP_LOG_LINE@python.inline@import os@@@" ,
"@@@STEP_LOG_LINE@python.inline@import shutil@@@" ,
"@@@STEP_LOG_LINE@python.inline@import sys@@@" ,
"@@@STEP_LOG_LINE@python.inline@@@@" ,
"@@@STEP_LOG_LINE@python.inline@src = sys.argv[1]@@@" ,
"@@@STEP_LOG_LINE@python.inline@dst = sys.argv[2]@@@" ,
2018-03-07 19:44:44 +00:00
"@@@STEP_LOG_LINE@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', 'run_testlab', 'skqp-universal-debug.apk', 'whitelist_devices.json']@@@" ,
2017-02-02 14:02:37 +00:00
"@@@STEP_LOG_LINE@python.inline@@@@" ,
"@@@STEP_LOG_LINE@python.inline@try:@@@" ,
"@@@STEP_LOG_LINE@python.inline@ os.makedirs(dst)@@@" ,
"@@@STEP_LOG_LINE@python.inline@except OSError as e:@@@" ,
"@@@STEP_LOG_LINE@python.inline@ if e.errno != errno.EEXIST:@@@" ,
"@@@STEP_LOG_LINE@python.inline@ raise@@@" ,
"@@@STEP_LOG_LINE@python.inline@@@@" ,
"@@@STEP_LOG_LINE@python.inline@for pattern in build_products_whitelist:@@@" ,
"@@@STEP_LOG_LINE@python.inline@ path = os.path.join(src, pattern)@@@" ,
"@@@STEP_LOG_LINE@python.inline@ for f in glob.glob(path):@@@" ,
"@@@STEP_LOG_LINE@python.inline@ dst_path = os.path.join(dst, os.path.relpath(f, src))@@@" ,
"@@@STEP_LOG_LINE@python.inline@ if not os.path.isdir(os.path.dirname(dst_path)):@@@" ,
"@@@STEP_LOG_LINE@python.inline@ os.makedirs(os.path.dirname(dst_path))@@@" ,
"@@@STEP_LOG_LINE@python.inline@ print 'Copying build product %s to %s' % (f, dst_path)@@@" ,
"@@@STEP_LOG_LINE@python.inline@ shutil.move(f, dst_path)@@@" ,
"@@@STEP_LOG_END@python.inline@@@"
]
} ,
{
"cmd" : [
"python" ,
"-u" ,
"import psutil\nfor p in psutil.process_iter():\n try:\n if p.name in ('mspdbsrv.exe', 'vctip.exe', 'cl.exe', 'link.exe'):\n p.kill()\n except psutil._error.AccessDenied:\n pass\n"
] ,
2017-03-20 16:48:31 +00:00
"infra_step" : true ,
2017-02-02 14:02:37 +00:00
"name" : "cleanup" ,
"~followup_annotations" : [
"@@@STEP_LOG_LINE@python.inline@import psutil@@@" ,
"@@@STEP_LOG_LINE@python.inline@for p in psutil.process_iter():@@@" ,
"@@@STEP_LOG_LINE@python.inline@ try:@@@" ,
"@@@STEP_LOG_LINE@python.inline@ if p.name in ('mspdbsrv.exe', 'vctip.exe', 'cl.exe', 'link.exe'):@@@" ,
"@@@STEP_LOG_LINE@python.inline@ p.kill()@@@" ,
"@@@STEP_LOG_LINE@python.inline@ except psutil._error.AccessDenied:@@@" ,
"@@@STEP_LOG_LINE@python.inline@ pass@@@" ,
"@@@STEP_LOG_END@python.inline@@@"
]
} ,
{
"name" : "$result" ,
"recipe_result" : null ,
"status_code" : 0
}
]