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" ,
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
] ,
"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" ,
2017-12-12 22:08:24 +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', 'vulkan-1.dll']\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]@@@" ,
2017-12-12 22:08:24 +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', 'vulkan-1.dll']@@@" ,
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" ,
2017-12-12 22:08:24 +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', 'vulkan-1.dll']\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-02-02 14:02:37 +00:00
"[START_DIR]\\win_vulkan_sdk" ,
"[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 (2)" ,
"~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]@@@" ,
2017-12-12 22:08:24 +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', 'vulkan-1.dll']@@@" ,
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
}
]