2018-02-22 15:03:56 +00:00
[
2019-11-04 16:10:15 +00:00
{
"cmd" : [
"python" ,
"-u" ,
"\nimport subprocess\nimport sys\n\nwhich = 'where' if sys.platform == 'win32' else 'which'\ngit = subprocess.check_output([which, 'git'])\nprint 'git was found at %s' % git\nif 'cipd_bin_packages' not in git:\n print >> sys.stderr, 'Git must be obtained through CIPD.'\n sys.exit(1)\n"
] ,
"env" : {
"CHROME_HEADLESS" : "1" ,
"PATH" : "<PATH>;RECIPE_REPO[depot_tools]"
} ,
"name" : "Assert that Git is from CIPD" ,
"~followup_annotations" : [
"@@@STEP_LOG_LINE@python.inline@@@@" ,
"@@@STEP_LOG_LINE@python.inline@import subprocess@@@" ,
"@@@STEP_LOG_LINE@python.inline@import sys@@@" ,
"@@@STEP_LOG_LINE@python.inline@@@@" ,
"@@@STEP_LOG_LINE@python.inline@which = 'where' if sys.platform == 'win32' else 'which'@@@" ,
"@@@STEP_LOG_LINE@python.inline@git = subprocess.check_output([which, 'git'])@@@" ,
"@@@STEP_LOG_LINE@python.inline@print 'git was found at %s' % git@@@" ,
"@@@STEP_LOG_LINE@python.inline@if 'cipd_bin_packages' not in git:@@@" ,
"@@@STEP_LOG_LINE@python.inline@ print >> sys.stderr, 'Git must be obtained through CIPD.'@@@" ,
"@@@STEP_LOG_LINE@python.inline@ sys.exit(1)@@@" ,
"@@@STEP_LOG_END@python.inline@@@"
]
} ,
2018-02-22 15:03:56 +00:00
{
"cmd" : [
"python" ,
"-u" ,
2019-07-19 12:07:44 +00:00
"RECIPE_MODULE[depot_tools::git]\\resources\\git_setup.py" ,
2018-02-22 15:03:56 +00:00
"--path" ,
2019-07-19 12:07:44 +00:00
"[START_DIR]\\skia" ,
2018-02-22 15:03:56 +00:00
"--url" ,
"https://skia.googlesource.com/skia.git"
] ,
"name" : "git setup"
} ,
{
"cmd" : [
"git" ,
"fetch" ,
"origin" ,
"abc123" ,
"--progress"
] ,
2019-07-19 12:07:44 +00:00
"cwd" : "[START_DIR]\\skia" ,
2018-02-22 15:03:56 +00:00
"env" : {
2019-07-19 12:07:44 +00:00
"PATH" : "RECIPE_REPO[depot_tools];<PATH>"
2018-02-22 15:03:56 +00:00
} ,
"infra_step" : true ,
"name" : "git fetch"
} ,
{
"cmd" : [
"git" ,
"checkout" ,
"-f" ,
"FETCH_HEAD"
] ,
2019-07-19 12:07:44 +00:00
"cwd" : "[START_DIR]\\skia" ,
2018-02-22 15:03:56 +00:00
"infra_step" : true ,
"name" : "git checkout"
} ,
{
"cmd" : [
"git" ,
"rev-parse" ,
"HEAD"
] ,
2019-07-19 12:07:44 +00:00
"cwd" : "[START_DIR]\\skia" ,
2018-02-22 15:03:56 +00:00
"infra_step" : true ,
"name" : "read revision" ,
"~followup_annotations" : [
"@@@STEP_TEXT@<br/>checked out 'deadbeef'<br/>@@@"
]
} ,
{
"cmd" : [
"git" ,
"clean" ,
"-f" ,
"-d" ,
"-x"
] ,
2019-07-19 12:07:44 +00:00
"cwd" : "[START_DIR]\\skia" ,
2018-02-22 15:03:56 +00:00
"infra_step" : true ,
"name" : "git clean"
} ,
2018-05-04 17:46:15 +00:00
{
"cmd" : [
2019-09-09 22:36:05 +00:00
"vpython" ,
2018-05-04 17:46:15 +00:00
"-u" ,
2019-07-19 12:07:44 +00:00
"RECIPE_MODULE[recipe_engine::file]\\resources\\fileutil.py" ,
2018-05-04 17:46:15 +00:00
"--json-output" ,
"/path/to/tmp/json" ,
"ensure-directory" ,
"--mode" ,
"0777" ,
2019-07-19 12:07:44 +00:00
"[START_DIR]\\tmp"
2018-05-04 17:46:15 +00:00
] ,
"infra_step" : true ,
"name" : "makedirs tmp_dir"
} ,
2018-03-19 21:39:43 +00:00
{
"cmd" : [
2019-09-09 22:36:05 +00:00
"vpython" ,
2018-03-19 21:39:43 +00:00
"-u" ,
2019-07-19 12:07:44 +00:00
"RECIPE_MODULE[recipe_engine::file]\\resources\\fileutil.py" ,
2018-03-19 21:39:43 +00:00
"--json-output" ,
"/path/to/tmp/json" ,
"copy" ,
2019-07-19 12:07:44 +00:00
"[START_DIR]\\skia\\infra\\bots\\assets\\clang_win\\VERSION" ,
2018-03-19 21:39:43 +00:00
"/path/to/tmp/"
] ,
"infra_step" : true ,
2019-10-30 21:44:56 +00:00
"name" : "Get clang_win VERSION" ,
"~followup_annotations" : [
"@@@STEP_LOG_LINE@VERSION@42@@@" ,
"@@@STEP_LOG_END@VERSION@@@"
]
2018-03-19 21:39:43 +00:00
} ,
2018-02-22 15:03:56 +00:00
{
"cmd" : [
"python" ,
"-u" ,
2019-07-19 12:07:44 +00:00
"[START_DIR]\\skia\\bin\\fetch-gn"
2018-02-22 15:03:56 +00:00
] ,
2019-07-19 12:07:44 +00:00
"cwd" : "[START_DIR]\\skia" ,
2018-02-22 15:03:56 +00:00
"env" : {
"CHROME_HEADLESS" : "1" ,
2019-07-19 12:07:44 +00:00
"PATH" : "<PATH>;RECIPE_REPO[depot_tools]"
2018-02-22 15:03:56 +00:00
} ,
"infra_step" : true ,
"name" : "fetch-gn"
} ,
{
"cmd" : [
2019-07-19 12:07:44 +00:00
"[START_DIR]\\skia\\bin\\gn" ,
2018-02-22 15:03:56 +00:00
"gen" ,
2019-07-19 12:07:44 +00:00
"[START_DIR]\\skia\\out\\Build-Win10-Clang-x86_64-Release-NoDEPS\\Release_x64" ,
2020-03-09 18:23:30 +00:00
"--args=cc=\"clang\" clang_win=\"[START_DIR]\\clang_win\" cxx=\"clang++\" extra_cflags=[\"-DDUMMY_clang_win_version=42\"] is_debug=false is_official_build=true skia_enable_fontmgr_empty=true skia_enable_gpu=true skia_enable_pdf=false skia_use_expat=false skia_use_freetype=false skia_use_harfbuzz=false skia_use_libjpeg_turbo_decode=false skia_use_libjpeg_turbo_encode=false skia_use_libpng_decode=false skia_use_libpng_encode=false skia_use_libwebp_decode=false skia_use_libwebp_encode=false skia_use_vulkan=false skia_use_zlib=false target_cpu=\"x86_64\" werror=true win_sdk=\"[START_DIR]\\win_toolchain/win_sdk\" win_vc=\"[START_DIR]\\win_toolchain/VC\""
2018-02-22 15:03:56 +00:00
] ,
2019-07-19 12:07:44 +00:00
"cwd" : "[START_DIR]\\skia" ,
2018-02-22 15:03:56 +00:00
"env" : {
"CHROME_HEADLESS" : "1" ,
2019-07-19 12:07:44 +00:00
"PATH" : "<PATH>;RECIPE_REPO[depot_tools]"
2018-02-22 15:03:56 +00:00
} ,
"name" : "gn gen"
} ,
{
"cmd" : [
"ninja" ,
"-C" ,
2019-07-19 12:07:44 +00:00
"[START_DIR]\\skia\\out\\Build-Win10-Clang-x86_64-Release-NoDEPS\\Release_x64"
2018-02-22 15:03:56 +00:00
] ,
2019-07-19 12:07:44 +00:00
"cwd" : "[START_DIR]\\skia" ,
2018-02-22 15:03:56 +00:00
"env" : {
"CHROME_HEADLESS" : "1" ,
2019-07-19 12:07:44 +00:00
"PATH" : "<PATH>;RECIPE_REPO[depot_tools]"
2018-02-22 15:03:56 +00:00
} ,
"name" : "ninja"
} ,
{
"cmd" : [
"python" ,
"-u" ,
2020-04-29 17:49:19 +00:00
"import errno\nimport glob\nimport os\nimport shutil\nimport sys\n\nsrc = sys.argv[1]\ndst = sys.argv[2]\nbuild_products = ['dm', 'dm.exe', 'dm.app', 'fm', 'nanobench.app', 'get_images_from_skps', 'get_images_from_skps.exe', 'hello-opencl', 'hello-opencl.exe', 'nanobench', 'nanobench.exe', 'skpbench', 'skpbench.exe', '*.so', '*.dll', '*.dylib', 'skia_launcher', 'skottie_tool', '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:\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" ,
2019-07-19 12:07:44 +00:00
"[START_DIR]\\skia\\out\\Build-Win10-Clang-x86_64-Release-NoDEPS\\Release_x64" ,
"[START_DIR]\\[SWARM_OUT_DIR]"
2018-02-22 15:03:56 +00:00
] ,
"infra_step" : true ,
"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]@@@" ,
2020-04-29 17:49:19 +00:00
"@@@STEP_LOG_LINE@python.inline@build_products = ['dm', 'dm.exe', 'dm.app', 'fm', 'nanobench.app', 'get_images_from_skps', 'get_images_from_skps.exe', 'hello-opencl', 'hello-opencl.exe', 'nanobench', 'nanobench.exe', 'skpbench', 'skpbench.exe', '*.so', '*.dll', '*.dylib', 'skia_launcher', 'skottie_tool', 'lib/*.so', 'run_testlab', 'skqp-universal-debug.apk', 'whitelist_devices.json']@@@" ,
2018-02-22 15:03:56 +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@@@@" ,
2019-10-04 14:13:42 +00:00
"@@@STEP_LOG_LINE@python.inline@for pattern in build_products:@@@" ,
2018-02-22 15:03:56 +00:00
"@@@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@@@"
]
} ,
2019-07-19 12:07:44 +00:00
{
"cmd" : [
2020-01-08 14:21:49 +00:00
"vpython" ,
2019-07-19 12:07:44 +00:00
"-u" ,
2020-01-08 14:21:49 +00:00
"\n# [VPYTHON:BEGIN]\n# wheel: <\n# name: \"infra/python/wheels/psutil/${vpython_platform}\"\n# version: \"version:5.4.7\"\n# >\n# [VPYTHON:END]\n\nimport 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"
2019-07-19 12:07:44 +00:00
] ,
"infra_step" : true ,
"name" : "cleanup" ,
"~followup_annotations" : [
2020-01-08 14:21:49 +00:00
"@@@STEP_LOG_LINE@python.inline@@@@" ,
"@@@STEP_LOG_LINE@python.inline@# [VPYTHON:BEGIN]@@@" ,
"@@@STEP_LOG_LINE@python.inline@# wheel: <@@@" ,
"@@@STEP_LOG_LINE@python.inline@# name: \"infra/python/wheels/psutil/${vpython_platform}\"@@@" ,
"@@@STEP_LOG_LINE@python.inline@# version: \"version:5.4.7\"@@@" ,
"@@@STEP_LOG_LINE@python.inline@# >@@@" ,
"@@@STEP_LOG_LINE@python.inline@# [VPYTHON:END]@@@" ,
"@@@STEP_LOG_LINE@python.inline@@@@" ,
2019-07-19 12:07:44 +00:00
"@@@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@@@"
]
} ,
2018-02-22 15:03:56 +00:00
{
2018-10-30 22:22:37 +00:00
"name" : "$result"
2018-02-22 15:03:56 +00:00
}
]