libv8 8.4.255.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +19 -0
- data/.gitmodules +3 -0
- data/.rspec +3 -0
- data/.travis.yml +45 -0
- data/CHANGELOG.md +111 -0
- data/Gemfile +4 -0
- data/README.md +152 -0
- data/Rakefile +125 -0
- data/appveyor.yml.disabled +36 -0
- data/ext/libv8/arch.rb +20 -0
- data/ext/libv8/builder.rb +106 -0
- data/ext/libv8/extconf.rb +7 -0
- data/ext/libv8/location.rb +89 -0
- data/ext/libv8/paths.rb +28 -0
- data/lib/libv8.rb +9 -0
- data/lib/libv8/version.rb +3 -0
- data/libv8.gemspec +30 -0
- data/scaleway.png +0 -0
- data/spec/location_spec.rb +69 -0
- data/spec/spec_helper.rb +4 -0
- data/thefrontside.png +0 -0
- data/vendor/depot_tools/.cipd_impl.ps1 +129 -0
- data/vendor/depot_tools/.gitattributes +55 -0
- data/vendor/depot_tools/.gitignore +92 -0
- data/vendor/depot_tools/.style.yapf +4 -0
- data/vendor/depot_tools/.vpython +55 -0
- data/vendor/depot_tools/.vpython3 +23 -0
- data/vendor/depot_tools/CROS_OWNERS +7 -0
- data/vendor/depot_tools/GOMA_OWNERS +9 -0
- data/vendor/depot_tools/LICENSE +27 -0
- data/vendor/depot_tools/LUCI_OWNERS +5 -0
- data/vendor/depot_tools/OWNERS +39 -0
- data/vendor/depot_tools/PRESUBMIT.py +150 -0
- data/vendor/depot_tools/README.gclient.md +67 -0
- data/vendor/depot_tools/README.git-cl.md +99 -0
- data/vendor/depot_tools/README.md +78 -0
- data/vendor/depot_tools/WATCHLISTS +26 -0
- data/vendor/depot_tools/auth.py +163 -0
- data/vendor/depot_tools/autoninja +36 -0
- data/vendor/depot_tools/autoninja.bat +33 -0
- data/vendor/depot_tools/autoninja.py +148 -0
- data/vendor/depot_tools/bb +12 -0
- data/vendor/depot_tools/bb.bat +7 -0
- data/vendor/depot_tools/bootstrap/README.md +155 -0
- data/vendor/depot_tools/bootstrap/bootstrap.py +356 -0
- data/vendor/depot_tools/bootstrap/git-bash.template.sh +12 -0
- data/vendor/depot_tools/bootstrap/git.template.bat +5 -0
- data/vendor/depot_tools/bootstrap/manifest.txt +27 -0
- data/vendor/depot_tools/bootstrap/manifest_bleeding_edge.txt +27 -0
- data/vendor/depot_tools/bootstrap/profile.d.python.sh +20 -0
- data/vendor/depot_tools/bootstrap/python27.bat +46 -0
- data/vendor/depot_tools/bootstrap/python3.bat +46 -0
- data/vendor/depot_tools/bootstrap/win_tools.bat +79 -0
- data/vendor/depot_tools/bootstrap_python3 +35 -0
- data/vendor/depot_tools/breakpad.py +12 -0
- data/vendor/depot_tools/cbuildbot +1 -0
- data/vendor/depot_tools/chrome_set_ver +1 -0
- data/vendor/depot_tools/cipd +247 -0
- data/vendor/depot_tools/cipd.bat +67 -0
- data/vendor/depot_tools/cipd_bin_setup.bat +6 -0
- data/vendor/depot_tools/cipd_bin_setup.sh +22 -0
- data/vendor/depot_tools/cipd_client_version +1 -0
- data/vendor/depot_tools/cipd_client_version.digests +22 -0
- data/vendor/depot_tools/cipd_manifest.txt +63 -0
- data/vendor/depot_tools/cipd_manifest.versions +438 -0
- data/vendor/depot_tools/cit +8 -0
- data/vendor/depot_tools/cit.bat +12 -0
- data/vendor/depot_tools/cit.py +167 -0
- data/vendor/depot_tools/clang-format +8 -0
- data/vendor/depot_tools/clang-format.bat +12 -0
- data/vendor/depot_tools/clang_format.py +79 -0
- data/vendor/depot_tools/clang_format_merge_driver +8 -0
- data/vendor/depot_tools/clang_format_merge_driver.bat +12 -0
- data/vendor/depot_tools/clang_format_merge_driver.py +69 -0
- data/vendor/depot_tools/codereview.settings +6 -0
- data/vendor/depot_tools/compile_single_file +8 -0
- data/vendor/depot_tools/compile_single_file.bat +11 -0
- data/vendor/depot_tools/compile_single_file.py +79 -0
- data/vendor/depot_tools/cpplint.bat +11 -0
- data/vendor/depot_tools/cpplint.py +6097 -0
- data/vendor/depot_tools/cpplint_chromium.py +50 -0
- data/vendor/depot_tools/cros +87 -0
- data/vendor/depot_tools/cros_sdk +1 -0
- data/vendor/depot_tools/crosjobs +13 -0
- data/vendor/depot_tools/detect_host_arch.py +55 -0
- data/vendor/depot_tools/dirmd +12 -0
- data/vendor/depot_tools/dirmd.bat +7 -0
- data/vendor/depot_tools/download_from_google_storage +8 -0
- data/vendor/depot_tools/download_from_google_storage.bat +12 -0
- data/vendor/depot_tools/download_from_google_storage.py +634 -0
- data/vendor/depot_tools/ensure_bootstrap +53 -0
- data/vendor/depot_tools/fetch +21 -0
- data/vendor/depot_tools/fetch.bat +28 -0
- data/vendor/depot_tools/fetch.py +319 -0
- data/vendor/depot_tools/fetch_configs/android.py +34 -0
- data/vendor/depot_tools/fetch_configs/android_internal.py +34 -0
- data/vendor/depot_tools/fetch_configs/breakpad.py +44 -0
- data/vendor/depot_tools/fetch_configs/chromium.py +66 -0
- data/vendor/depot_tools/fetch_configs/config_util.py +52 -0
- data/vendor/depot_tools/fetch_configs/crashpad.py +41 -0
- data/vendor/depot_tools/fetch_configs/dart.py +45 -0
- data/vendor/depot_tools/fetch_configs/depot_tools.py +44 -0
- data/vendor/depot_tools/fetch_configs/devtools-frontend.py +44 -0
- data/vendor/depot_tools/fetch_configs/goma_client.py +41 -0
- data/vendor/depot_tools/fetch_configs/gyp.py +41 -0
- data/vendor/depot_tools/fetch_configs/infra.py +40 -0
- data/vendor/depot_tools/fetch_configs/infra_internal.py +45 -0
- data/vendor/depot_tools/fetch_configs/inspector_protocol.py +40 -0
- data/vendor/depot_tools/fetch_configs/ios.py +34 -0
- data/vendor/depot_tools/fetch_configs/ios_internal.py +39 -0
- data/vendor/depot_tools/fetch_configs/nacl.py +48 -0
- data/vendor/depot_tools/fetch_configs/naclports.py +47 -0
- data/vendor/depot_tools/fetch_configs/node-ci.py +41 -0
- data/vendor/depot_tools/fetch_configs/pdfium.py +40 -0
- data/vendor/depot_tools/fetch_configs/skia.py +41 -0
- data/vendor/depot_tools/fetch_configs/skia_buildbot.py +41 -0
- data/vendor/depot_tools/fetch_configs/syzygy.py +41 -0
- data/vendor/depot_tools/fetch_configs/v8.py +44 -0
- data/vendor/depot_tools/fetch_configs/webrtc.py +52 -0
- data/vendor/depot_tools/fetch_configs/webrtc_android.py +34 -0
- data/vendor/depot_tools/fetch_configs/webrtc_ios.py +34 -0
- data/vendor/depot_tools/fix_encoding.py +385 -0
- data/vendor/depot_tools/gclient +38 -0
- data/vendor/depot_tools/gclient-new-workdir.py +124 -0
- data/vendor/depot_tools/gclient.bat +32 -0
- data/vendor/depot_tools/gclient.py +3198 -0
- data/vendor/depot_tools/gclient_completion.sh +76 -0
- data/vendor/depot_tools/gclient_eval.py +891 -0
- data/vendor/depot_tools/gclient_paths.py +152 -0
- data/vendor/depot_tools/gclient_scm.py +1615 -0
- data/vendor/depot_tools/gclient_utils.py +1280 -0
- data/vendor/depot_tools/gerrit_client.py +151 -0
- data/vendor/depot_tools/gerrit_util.py +996 -0
- data/vendor/depot_tools/git-cache +6 -0
- data/vendor/depot_tools/git-cl +6 -0
- data/vendor/depot_tools/git-crrev-parse +53 -0
- data/vendor/depot_tools/git-drover +6 -0
- data/vendor/depot_tools/git-find-releases +6 -0
- data/vendor/depot_tools/git-footers +6 -0
- data/vendor/depot_tools/git-freeze +8 -0
- data/vendor/depot_tools/git-gs +9 -0
- data/vendor/depot_tools/git-hyper-blame +6 -0
- data/vendor/depot_tools/git-map +6 -0
- data/vendor/depot_tools/git-map-branches +6 -0
- data/vendor/depot_tools/git-mark-merge-base +6 -0
- data/vendor/depot_tools/git-nav-downstream +6 -0
- data/vendor/depot_tools/git-nav-upstream +6 -0
- data/vendor/depot_tools/git-new-branch +6 -0
- data/vendor/depot_tools/git-number +6 -0
- data/vendor/depot_tools/git-rebase-update +6 -0
- data/vendor/depot_tools/git-rename-branch +6 -0
- data/vendor/depot_tools/git-reparent-branch +6 -0
- data/vendor/depot_tools/git-retry +8 -0
- data/vendor/depot_tools/git-runhooks +23 -0
- data/vendor/depot_tools/git-squash-branch +6 -0
- data/vendor/depot_tools/git-templates/description +3 -0
- data/vendor/depot_tools/git-templates/hooks/applypatch-msg +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-applypatch +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-checkout +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-commit +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-merge +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-update +4 -0
- data/vendor/depot_tools/git-templates/hooks/pre-applypatch +4 -0
- data/vendor/depot_tools/git-templates/hooks/pre-auto-gc +4 -0
- data/vendor/depot_tools/git-templates/hooks/pre-commit +4 -0
- data/vendor/depot_tools/git-templates/hooks/pre-rebase +4 -0
- data/vendor/depot_tools/git-templates/hooks/prepare-commit-msg +4 -0
- data/vendor/depot_tools/git-templates/info/exclude +6 -0
- data/vendor/depot_tools/git-thaw +13 -0
- data/vendor/depot_tools/git-upstream-diff +9 -0
- data/vendor/depot_tools/git_cache.py +786 -0
- data/vendor/depot_tools/git_cl.py +5158 -0
- data/vendor/depot_tools/git_cl_completion.sh +48 -0
- data/vendor/depot_tools/git_common.py +1101 -0
- data/vendor/depot_tools/git_dates.py +62 -0
- data/vendor/depot_tools/git_drover.py +469 -0
- data/vendor/depot_tools/git_find_releases.py +67 -0
- data/vendor/depot_tools/git_footers.py +261 -0
- data/vendor/depot_tools/git_freezer.py +40 -0
- data/vendor/depot_tools/git_hyper_blame.py +391 -0
- data/vendor/depot_tools/git_map.py +166 -0
- data/vendor/depot_tools/git_map_branches.py +354 -0
- data/vendor/depot_tools/git_mark_merge_base.py +73 -0
- data/vendor/depot_tools/git_nav_downstream.py +69 -0
- data/vendor/depot_tools/git_new_branch.py +82 -0
- data/vendor/depot_tools/git_number.py +301 -0
- data/vendor/depot_tools/git_rebase_update.py +351 -0
- data/vendor/depot_tools/git_rename_branch.py +55 -0
- data/vendor/depot_tools/git_reparent_branch.py +101 -0
- data/vendor/depot_tools/git_retry.py +181 -0
- data/vendor/depot_tools/git_squash_branch.py +28 -0
- data/vendor/depot_tools/git_upstream_diff.py +64 -0
- data/vendor/depot_tools/gn +8 -0
- data/vendor/depot_tools/gn.bat +12 -0
- data/vendor/depot_tools/gn.py +78 -0
- data/vendor/depot_tools/goma_auth +12 -0
- data/vendor/depot_tools/goma_auth.bat +8 -0
- data/vendor/depot_tools/goma_ctl +12 -0
- data/vendor/depot_tools/goma_ctl.bat +8 -0
- data/vendor/depot_tools/gsutil.py +190 -0
- data/vendor/depot_tools/gsutil.py.bat +23 -0
- data/vendor/depot_tools/gsutil.vpython +120 -0
- data/vendor/depot_tools/infra/README.md +1 -0
- data/vendor/depot_tools/infra/config/OWNERS +7 -0
- data/vendor/depot_tools/infra/config/README.md +1 -0
- data/vendor/depot_tools/infra/config/recipes.cfg +26 -0
- data/vendor/depot_tools/led +12 -0
- data/vendor/depot_tools/led.bat +7 -0
- data/vendor/depot_tools/lockfile.py +116 -0
- data/vendor/depot_tools/luci-auth +13 -0
- data/vendor/depot_tools/luci-auth.bat +8 -0
- data/vendor/depot_tools/lucicfg +12 -0
- data/vendor/depot_tools/lucicfg.bat +7 -0
- data/vendor/depot_tools/mac_toolchain +12 -0
- data/vendor/depot_tools/man/html/depot_tools.html +934 -0
- data/vendor/depot_tools/man/html/depot_tools_tutorial.html +1593 -0
- data/vendor/depot_tools/man/html/git-cl.html +1033 -0
- data/vendor/depot_tools/man/html/git-drover.html +1048 -0
- data/vendor/depot_tools/man/html/git-footers.html +878 -0
- data/vendor/depot_tools/man/html/git-freeze.html +859 -0
- data/vendor/depot_tools/man/html/git-hyper-blame.html +878 -0
- data/vendor/depot_tools/man/html/git-map-branches.html +904 -0
- data/vendor/depot_tools/man/html/git-map.html +887 -0
- data/vendor/depot_tools/man/html/git-mark-merge-base.html +826 -0
- data/vendor/depot_tools/man/html/git-nav-downstream.html +844 -0
- data/vendor/depot_tools/man/html/git-nav-upstream.html +853 -0
- data/vendor/depot_tools/man/html/git-new-branch.html +932 -0
- data/vendor/depot_tools/man/html/git-rebase-update.html +961 -0
- data/vendor/depot_tools/man/html/git-rename-branch.html +794 -0
- data/vendor/depot_tools/man/html/git-reparent-branch.html +847 -0
- data/vendor/depot_tools/man/html/git-retry.html +858 -0
- data/vendor/depot_tools/man/html/git-squash-branch.html +881 -0
- data/vendor/depot_tools/man/html/git-thaw.html +794 -0
- data/vendor/depot_tools/man/html/git-upstream-diff.html +923 -0
- data/vendor/depot_tools/man/man1/git-cl.1 +198 -0
- data/vendor/depot_tools/man/man1/git-drover.1 +330 -0
- data/vendor/depot_tools/man/man1/git-footers.1 +144 -0
- data/vendor/depot_tools/man/man1/git-freeze.1 +113 -0
- data/vendor/depot_tools/man/man1/git-hyper-blame.1 +128 -0
- data/vendor/depot_tools/man/man1/git-map-branches.1 +210 -0
- data/vendor/depot_tools/man/man1/git-map.1 +179 -0
- data/vendor/depot_tools/man/man1/git-mark-merge-base.1 +69 -0
- data/vendor/depot_tools/man/man1/git-nav-downstream.1 +112 -0
- data/vendor/depot_tools/man/man1/git-nav-upstream.1 +122 -0
- data/vendor/depot_tools/man/man1/git-new-branch.1 +176 -0
- data/vendor/depot_tools/man/man1/git-rebase-update.1 +177 -0
- data/vendor/depot_tools/man/man1/git-rename-branch.1 +53 -0
- data/vendor/depot_tools/man/man1/git-reparent-branch.1 +93 -0
- data/vendor/depot_tools/man/man1/git-retry.1 +108 -0
- data/vendor/depot_tools/man/man1/git-squash-branch.1 +129 -0
- data/vendor/depot_tools/man/man1/git-thaw.1 +54 -0
- data/vendor/depot_tools/man/man1/git-upstream-diff.1 +153 -0
- data/vendor/depot_tools/man/man7/depot_tools.7 +139 -0
- data/vendor/depot_tools/man/man7/depot_tools_tutorial.7 +1061 -0
- data/vendor/depot_tools/man/push_to_gs.sh +4 -0
- data/vendor/depot_tools/man/src/.gitignore +5 -0
- data/vendor/depot_tools/man/src/_aliases.txt +5 -0
- data/vendor/depot_tools/man/src/_footer.txt +8 -0
- data/vendor/depot_tools/man/src/_git-cl_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-drover_desc.helper.txt +2 -0
- data/vendor/depot_tools/man/src/_git-footers_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-freeze_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-hyper-blame_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-map-branches_desc.helper.txt +4 -0
- data/vendor/depot_tools/man/src/_git-map_desc.helper.txt +3 -0
- data/vendor/depot_tools/man/src/_git-mark-merge-base_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-nav-downstream_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-nav-upstream_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-new-branch_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-rebase-update_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-rename-branch_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-reparent-branch_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-retry_desc.helper.txt +2 -0
- data/vendor/depot_tools/man/src/_git-squash-branch_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-thaw_desc.helper.txt +2 -0
- data/vendor/depot_tools/man/src/_git-upstream-diff_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_helper_prefix.txt +1 -0
- data/vendor/depot_tools/man/src/asciidoc-override.css +7 -0
- data/vendor/depot_tools/man/src/common_demo_functions.sh +84 -0
- data/vendor/depot_tools/man/src/demo_repo.sh +43 -0
- data/vendor/depot_tools/man/src/depot_tools.txt +28 -0
- data/vendor/depot_tools/man/src/depot_tools_tutorial.demo.walkthrough.sh +155 -0
- data/vendor/depot_tools/man/src/depot_tools_tutorial.txt +432 -0
- data/vendor/depot_tools/man/src/filter_demo_output.py +141 -0
- data/vendor/depot_tools/man/src/git-cl.txt +119 -0
- data/vendor/depot_tools/man/src/git-drover.demo.1.sh +22 -0
- data/vendor/depot_tools/man/src/git-drover.demo.2.sh +23 -0
- data/vendor/depot_tools/man/src/git-drover.demo.3.sh +27 -0
- data/vendor/depot_tools/man/src/git-drover.demo.4.sh +39 -0
- data/vendor/depot_tools/man/src/git-drover.demo.common.sh +19 -0
- data/vendor/depot_tools/man/src/git-drover.txt +102 -0
- data/vendor/depot_tools/man/src/git-footers.demo.1.sh +17 -0
- data/vendor/depot_tools/man/src/git-footers.txt +71 -0
- data/vendor/depot_tools/man/src/git-freeze.demo.1.sh +23 -0
- data/vendor/depot_tools/man/src/git-freeze.txt +54 -0
- data/vendor/depot_tools/man/src/git-hyper-blame.demo.1.sh +3 -0
- data/vendor/depot_tools/man/src/git-hyper-blame.demo.2.sh +4 -0
- data/vendor/depot_tools/man/src/git-hyper-blame.demo.common.sh +57 -0
- data/vendor/depot_tools/man/src/git-hyper-blame.txt +85 -0
- data/vendor/depot_tools/man/src/git-map-branches.demo.1.sh +8 -0
- data/vendor/depot_tools/man/src/git-map-branches.txt +64 -0
- data/vendor/depot_tools/man/src/git-map.demo.1.sh +3 -0
- data/vendor/depot_tools/man/src/git-map.txt +67 -0
- data/vendor/depot_tools/man/src/git-mark-merge-base.txt +46 -0
- data/vendor/depot_tools/man/src/git-nav-downstream.demo.1.sh +12 -0
- data/vendor/depot_tools/man/src/git-nav-downstream.txt +40 -0
- data/vendor/depot_tools/man/src/git-nav-upstream.demo.1.sh +12 -0
- data/vendor/depot_tools/man/src/git-nav-upstream.txt +39 -0
- data/vendor/depot_tools/man/src/git-new-branch.demo.1.sh +17 -0
- data/vendor/depot_tools/man/src/git-new-branch.txt +82 -0
- data/vendor/depot_tools/man/src/git-rebase-update.txt +141 -0
- data/vendor/depot_tools/man/src/git-rename-branch.txt +28 -0
- data/vendor/depot_tools/man/src/git-reparent-branch.txt +61 -0
- data/vendor/depot_tools/man/src/git-retry.txt +67 -0
- data/vendor/depot_tools/man/src/git-squash-branch.demo.1.sh +12 -0
- data/vendor/depot_tools/man/src/git-squash-branch.txt +59 -0
- data/vendor/depot_tools/man/src/git-thaw.txt +29 -0
- data/vendor/depot_tools/man/src/git-upstream-diff.txt +107 -0
- data/vendor/depot_tools/man/src/make_docs.sh +260 -0
- data/vendor/depot_tools/man/src/prep_demo_repo.sh +103 -0
- data/vendor/depot_tools/metrics.README.md +101 -0
- data/vendor/depot_tools/metrics.py +297 -0
- data/vendor/depot_tools/metrics_utils.py +293 -0
- data/vendor/depot_tools/my_activity.py +971 -0
- data/vendor/depot_tools/ninja +44 -0
- data/vendor/depot_tools/ninja-linux32 +0 -0
- data/vendor/depot_tools/ninja-linux64 +0 -0
- data/vendor/depot_tools/ninja-mac +0 -0
- data/vendor/depot_tools/ninja.exe +0 -0
- data/vendor/depot_tools/ninjalog.README.md +64 -0
- data/vendor/depot_tools/ninjalog_uploader.py +233 -0
- data/vendor/depot_tools/ninjalog_uploader_wrapper.py +125 -0
- data/vendor/depot_tools/owners.py +641 -0
- data/vendor/depot_tools/owners_finder.py +385 -0
- data/vendor/depot_tools/post_build_ninja_summary.py +350 -0
- data/vendor/depot_tools/presubmit_canned_checks.py +1655 -0
- data/vendor/depot_tools/presubmit_support.py +1923 -0
- data/vendor/depot_tools/profile.xml +8 -0
- data/vendor/depot_tools/prpc +13 -0
- data/vendor/depot_tools/prpc.bat +8 -0
- data/vendor/depot_tools/pylint +9 -0
- data/vendor/depot_tools/pylint-1.5 +78 -0
- data/vendor/depot_tools/pylint-1.6 +78 -0
- data/vendor/depot_tools/pylint-1.7 +78 -0
- data/vendor/depot_tools/pylint-1.8 +78 -0
- data/vendor/depot_tools/pylint-1.9 +78 -0
- data/vendor/depot_tools/pylint.bat +12 -0
- data/vendor/depot_tools/pylint_main.py +45 -0
- data/vendor/depot_tools/pylintrc +349 -0
- data/vendor/depot_tools/python-bin/python3 +7 -0
- data/vendor/depot_tools/python_runner.sh +60 -0
- data/vendor/depot_tools/rdb +12 -0
- data/vendor/depot_tools/rdb.bat +7 -0
- data/vendor/depot_tools/recipes/OWNERS +4 -0
- data/vendor/depot_tools/recipes/README.recipes.md +1079 -0
- data/vendor/depot_tools/recipes/recipe_modules/OWNERS +1 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/OWNERS +2 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/__init__.py +38 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/api.py +516 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic.json +117 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_luci.json +117 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_with_branch_heads.json +118 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/clobber.json +211 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/deprecated_got_revision_mapping.json +194 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_rebase_patch_ref.json +211 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_reset.json +211 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/input_commit_with_id_without_repo.json +210 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/multiple_patch_refs.json +214 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_apply_patch_on_gclient.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_HEAD.json +65 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_a_branch_head.json +65 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_a_specific_commit.json +65 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_master.json +65 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/refs.json +212 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/reset_root_solution_revision.json +210 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/resolve_chromium_fixed_version.json +117 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail.json +95 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch.json +209 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch_download.json +193 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_branch_heads.json +261 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_feature_branch.json +261 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8_feature_branch.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_webrtc.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8_head_by_default.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/unrecognized_commit_repo.json +8 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_tags.json +211 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.py +308 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/__init__.py +0 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/bot_update.py +1258 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/test_api.py +93 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/do_not_retry_patch_failures_in_cq.py +42 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/ensure_checkout.py +35 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/__init__.py +9 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/api.py +455 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic.json +403 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic_pkg.json +403 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-failed.json +82 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-many-instances.json +411 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/mac64.json +403 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_file.json +315 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_mode.json +313 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_verfile.json +313 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/win64.json +403 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.py +187 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk arch.json +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk bits.json +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_32.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_32.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_mips_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/mac_intel_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_32.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.py +59 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/test_api.py +93 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/__init__.py +9 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/api.py +75 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic_luci.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/win.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.py +55 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/__init__.py +13 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/api.py +428 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/config.py +462 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/basic.json +238 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/revision.json +240 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/tryserver.json +238 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.py +95 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/resources/diff_deps.py +16 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/test_api.py +36 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/basic.json +55 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/dont have revision yet.json +84 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/no change, exception.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/windows.json +55 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.py +88 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/patch_project.py +92 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/sync_failure.py +24 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/__init__.py +8 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/api.py +178 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.expected/basic.json +284 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.py +73 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/test_api.py +53 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/__init__.py +11 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/api.py +405 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic.json +217 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_branch.json +217 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_file_name.json +219 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_hash.json +216 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_ref.json +217 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_submodule_update_force.json +218 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_tags.json +218 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/can_fail_build.json +164 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cannot_fail_build.json +220 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cat-file_test.json +239 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_delta.json +290 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_failed.json +220 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output.json +222 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output_fails_build.json +111 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/curl_trace_file.json +218 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/git-cache-checkout.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/platform_win.json +217 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/rebase_failed.json +221 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/remote_not_origin.json +219 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/set_got_revision.json +218 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.py +170 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/resources/git_setup.py +52 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/test_api.py +18 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/__init__.py +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/api.py +50 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/config.py +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.expected/basic.json +105 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.py +47 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/OWNERS +2 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/__init__.py +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/api.py +257 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.expected/basic.json +596 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.py +93 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/resources/gerrit_client.py +251 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/test_api.py +95 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.expected/basic.json +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.py +49 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/__init__.py +4 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/api.py +222 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.expected/basic.json +247 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.py +92 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/resources/gsutil_smart_retry.py +69 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/__init__.py +36 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/api.py +140 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/ancient_version.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/automatic_version.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/explicit_version.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/linux.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/mac.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/win.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.py +42 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/__init__.py +27 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/api.py +251 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.expected/basic.json +27 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.py +19 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/properties.proto +14 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/test_api.py +19 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/tests/execute.py +247 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/tests/prepare.py +49 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/__init__.py +18 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/api.py +264 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/basic_tags.json +57 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch.json +190 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch_and_target_ref.json +190 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch_new.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.py +95 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/test_api.py +14 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_fetch_ref_timeout.py +29 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.expected/basic.json +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.py +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_target_ref.py +32 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/__init__.py +25 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/api.py +137 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/linux.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/mac.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/win.json +108 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.py +21 -0
- data/vendor/depot_tools/recipes/recipes.py +249 -0
- data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.expected/basic.json +175 -0
- data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.py +56 -0
- data/vendor/depot_tools/recipes/trigger_recipe_roller.txt +13 -0
- data/vendor/depot_tools/repo +1194 -0
- data/vendor/depot_tools/roll-dep +21 -0
- data/vendor/depot_tools/roll-dep.bat +21 -0
- data/vendor/depot_tools/roll_dep.py +282 -0
- data/vendor/depot_tools/scm.py +415 -0
- data/vendor/depot_tools/setup_color.py +130 -0
- data/vendor/depot_tools/split_cl.py +263 -0
- data/vendor/depot_tools/subcommand.py +261 -0
- data/vendor/depot_tools/subprocess2.py +258 -0
- data/vendor/depot_tools/third_party/__init__.py +5 -0
- data/vendor/depot_tools/third_party/colorama/LICENSE.txt +27 -0
- data/vendor/depot_tools/third_party/colorama/README.chromium +12 -0
- data/vendor/depot_tools/third_party/colorama/README.rst +346 -0
- data/vendor/depot_tools/third_party/colorama/__init__.py +6 -0
- data/vendor/depot_tools/third_party/colorama/ansi.py +102 -0
- data/vendor/depot_tools/third_party/colorama/ansitowin32.py +257 -0
- data/vendor/depot_tools/third_party/colorama/initialise.py +80 -0
- data/vendor/depot_tools/third_party/colorama/win32.py +152 -0
- data/vendor/depot_tools/third_party/colorama/winterm.py +169 -0
- data/vendor/depot_tools/third_party/coverage/AUTHORS.txt +43 -0
- data/vendor/depot_tools/third_party/coverage/PKG-INFO +41 -0
- data/vendor/depot_tools/third_party/coverage/README.chromium +13 -0
- data/vendor/depot_tools/third_party/coverage/__init__.py +120 -0
- data/vendor/depot_tools/third_party/coverage/__main__.py +4 -0
- data/vendor/depot_tools/third_party/coverage/annotate.py +101 -0
- data/vendor/depot_tools/third_party/coverage/backward.py +184 -0
- data/vendor/depot_tools/third_party/coverage/bytecode.py +75 -0
- data/vendor/depot_tools/third_party/coverage/cmdline.py +740 -0
- data/vendor/depot_tools/third_party/coverage/codeunit.py +145 -0
- data/vendor/depot_tools/third_party/coverage/collector.py +353 -0
- data/vendor/depot_tools/third_party/coverage/config.py +213 -0
- data/vendor/depot_tools/third_party/coverage/control.py +776 -0
- data/vendor/depot_tools/third_party/coverage/data.py +278 -0
- data/vendor/depot_tools/third_party/coverage/debug.py +54 -0
- data/vendor/depot_tools/third_party/coverage/execfile.py +171 -0
- data/vendor/depot_tools/third_party/coverage/files.py +309 -0
- data/vendor/depot_tools/third_party/coverage/fullcoverage/encodings.py +57 -0
- data/vendor/depot_tools/third_party/coverage/html.py +387 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/coverage_html.js +376 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/index.html +104 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery-1.4.3.min.js +166 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.hotkeys.js +99 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.isonscreen.js +53 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.min.js +166 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.tablesorter.min.js +2 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/keybd_closed.png +0 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/keybd_open.png +0 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/pyfile.html +90 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/style.css +300 -0
- data/vendor/depot_tools/third_party/coverage/misc.py +163 -0
- data/vendor/depot_tools/third_party/coverage/parser.py +666 -0
- data/vendor/depot_tools/third_party/coverage/phystokens.py +208 -0
- data/vendor/depot_tools/third_party/coverage/report.py +92 -0
- data/vendor/depot_tools/third_party/coverage/results.py +286 -0
- data/vendor/depot_tools/third_party/coverage/summary.py +86 -0
- data/vendor/depot_tools/third_party/coverage/templite.py +166 -0
- data/vendor/depot_tools/third_party/coverage/version.py +9 -0
- data/vendor/depot_tools/third_party/coverage/xmlreport.py +155 -0
- data/vendor/depot_tools/third_party/httplib2/LICENSE +1339 -0
- data/vendor/depot_tools/third_party/httplib2/README.chromium +15 -0
- data/vendor/depot_tools/third_party/httplib2/__init__.py +1780 -0
- data/vendor/depot_tools/third_party/httplib2/cacerts.txt +2196 -0
- data/vendor/depot_tools/third_party/httplib2/iri2uri.py +110 -0
- data/vendor/depot_tools/third_party/httplib2/socks.py +448 -0
- data/vendor/depot_tools/third_party/repo/COPYING +202 -0
- data/vendor/depot_tools/third_party/repo/README.chromium +4 -0
- data/vendor/depot_tools/third_party/repo/__init__.py +0 -0
- data/vendor/depot_tools/third_party/repo/progress.py +117 -0
- data/vendor/depot_tools/third_party/retry_decorator/LICENSE.google +30 -0
- data/vendor/depot_tools/third_party/retry_decorator/__init__.py +0 -0
- data/vendor/depot_tools/third_party/retry_decorator/decorators.py +45 -0
- data/vendor/depot_tools/third_party/schema/.editorconfig +15 -0
- data/vendor/depot_tools/third_party/schema/.gitignore +174 -0
- data/vendor/depot_tools/third_party/schema/.travis.yml +37 -0
- data/vendor/depot_tools/third_party/schema/LICENSE-MIT +19 -0
- data/vendor/depot_tools/third_party/schema/MANIFEST.in +1 -0
- data/vendor/depot_tools/third_party/schema/README.chromium +12 -0
- data/vendor/depot_tools/third_party/schema/README.rst +382 -0
- data/vendor/depot_tools/third_party/schema/__init__.py +1 -0
- data/vendor/depot_tools/third_party/schema/schema.py +338 -0
- data/vendor/depot_tools/third_party/schema/setup.cfg +5 -0
- data/vendor/depot_tools/third_party/schema/setup.py +30 -0
- data/vendor/depot_tools/third_party/schema/test_schema.py +556 -0
- data/vendor/depot_tools/third_party/schema/tox.ini +33 -0
- data/vendor/depot_tools/third_party/six/LICENSE.txt +18 -0
- data/vendor/depot_tools/third_party/six/README.chromium +10 -0
- data/vendor/depot_tools/third_party/six/__init__.py +762 -0
- data/vendor/depot_tools/update_depot_tools +138 -0
- data/vendor/depot_tools/update_depot_tools.bat +65 -0
- data/vendor/depot_tools/update_depot_tools_toggle.py +38 -0
- data/vendor/depot_tools/upload_metrics.py +26 -0
- data/vendor/depot_tools/upload_to_google_storage.py +306 -0
- data/vendor/depot_tools/vpython +42 -0
- data/vendor/depot_tools/vpython.bat +7 -0
- data/vendor/depot_tools/vpython3 +55 -0
- data/vendor/depot_tools/vpython3.bat +12 -0
- data/vendor/depot_tools/watchlists.py +141 -0
- data/vendor/depot_tools/weekly +54 -0
- data/vendor/depot_tools/win32imports.py +61 -0
- data/vendor/depot_tools/win_toolchain/OWNERS +2 -0
- data/vendor/depot_tools/win_toolchain/README.md +74 -0
- data/vendor/depot_tools/win_toolchain/get_toolchain_if_necessary.py +599 -0
- data/vendor/depot_tools/win_toolchain/package_from_installed.py +524 -0
- data/vendor/depot_tools/wtf +81 -0
- data/vendor/depot_tools/yapf +21 -0
- data/vendor/depot_tools/yapf.bat +12 -0
- data/vendor/depot_tools/zsh-goodies/README +6 -0
- data/vendor/depot_tools/zsh-goodies/_gclient +14 -0
- metadata +729 -0
@@ -0,0 +1,12 @@
|
|
1
|
+
#!/usr/bin/env bash
|
2
|
+
|
3
|
+
# Copyright 2020 The Chromium Authors. All rights reserved.
|
4
|
+
# Use of this source code is governed by a BSD-style license that can be
|
5
|
+
# found in the LICENSE file.
|
6
|
+
|
7
|
+
MYPATH=$(dirname "${BASH_SOURCE[0]}")
|
8
|
+
|
9
|
+
source "$MYPATH/cipd_bin_setup.sh"
|
10
|
+
cipd_bin_setup &> /dev/null
|
11
|
+
|
12
|
+
exec "$MYPATH/.cipd_bin/rdb" "$@"
|
@@ -0,0 +1,1079 @@
|
|
1
|
+
<!--- AUTOGENERATED BY `./recipes.py test train` -->
|
2
|
+
# Repo documentation for [depot\_tools](https://chromium.googlesource.com/chromium/tools/depot_tools.git)
|
3
|
+
## Table of Contents
|
4
|
+
|
5
|
+
**[Recipe Modules](#Recipe-Modules)**
|
6
|
+
* [bot_update](#recipe_modules-bot_update) — Recipe module to ensure a checkout is consistent on a bot.
|
7
|
+
* [cipd](#recipe_modules-cipd) — API for interacting with CIPD.
|
8
|
+
* [depot_tools](#recipe_modules-depot_tools) — The `depot_tools` module provides safe functions to access paths within the depot_tools repo.
|
9
|
+
* [gclient](#recipe_modules-gclient)
|
10
|
+
* [gerrit](#recipe_modules-gerrit)
|
11
|
+
* [git](#recipe_modules-git)
|
12
|
+
* [git_cl](#recipe_modules-git_cl)
|
13
|
+
* [gitiles](#recipe_modules-gitiles)
|
14
|
+
* [gsutil](#recipe_modules-gsutil)
|
15
|
+
* [osx_sdk](#recipe_modules-osx_sdk) — The `osx_sdk` module provides safe functions to access a semi-hermetic XCode installation.
|
16
|
+
* [presubmit](#recipe_modules-presubmit)
|
17
|
+
* [tryserver](#recipe_modules-tryserver)
|
18
|
+
* [windows_sdk](#recipe_modules-windows_sdk) — The `windows_sdk` module provides safe functions to access a hermetic Microsoft Visual Studio installation.
|
19
|
+
|
20
|
+
**[Recipes](#Recipes)**
|
21
|
+
* [bot_update:examples/full](#recipes-bot_update_examples_full)
|
22
|
+
* [bot_update:tests/do_not_retry_patch_failures_in_cq](#recipes-bot_update_tests_do_not_retry_patch_failures_in_cq)
|
23
|
+
* [bot_update:tests/ensure_checkout](#recipes-bot_update_tests_ensure_checkout)
|
24
|
+
* [cipd:examples/full](#recipes-cipd_examples_full)
|
25
|
+
* [cipd:examples/platform_suffix](#recipes-cipd_examples_platform_suffix)
|
26
|
+
* [depot_tools:examples/full](#recipes-depot_tools_examples_full)
|
27
|
+
* [fetch_end_to_end_test](#recipes-fetch_end_to_end_test)
|
28
|
+
* [gclient:examples/full](#recipes-gclient_examples_full)
|
29
|
+
* [gclient:tests/diff_deps](#recipes-gclient_tests_diff_deps)
|
30
|
+
* [gclient:tests/patch_project](#recipes-gclient_tests_patch_project)
|
31
|
+
* [gclient:tests/sync_failure](#recipes-gclient_tests_sync_failure)
|
32
|
+
* [gerrit:examples/full](#recipes-gerrit_examples_full)
|
33
|
+
* [git:examples/full](#recipes-git_examples_full)
|
34
|
+
* [git_cl:examples/full](#recipes-git_cl_examples_full)
|
35
|
+
* [gitiles:examples/full](#recipes-gitiles_examples_full)
|
36
|
+
* [gitiles:tests/parse_repo_url](#recipes-gitiles_tests_parse_repo_url)
|
37
|
+
* [gsutil:examples/full](#recipes-gsutil_examples_full)
|
38
|
+
* [osx_sdk:examples/full](#recipes-osx_sdk_examples_full)
|
39
|
+
* [presubmit:examples/full](#recipes-presubmit_examples_full)
|
40
|
+
* [presubmit:tests/execute](#recipes-presubmit_tests_execute)
|
41
|
+
* [presubmit:tests/prepare](#recipes-presubmit_tests_prepare)
|
42
|
+
* [tryserver:examples/full](#recipes-tryserver_examples_full)
|
43
|
+
* [tryserver:tests/gerrit_change_fetch_ref_timeout](#recipes-tryserver_tests_gerrit_change_fetch_ref_timeout)
|
44
|
+
* [tryserver:tests/gerrit_change_owner](#recipes-tryserver_tests_gerrit_change_owner)
|
45
|
+
* [tryserver:tests/gerrit_change_target_ref](#recipes-tryserver_tests_gerrit_change_target_ref)
|
46
|
+
* [windows_sdk:examples/full](#recipes-windows_sdk_examples_full)
|
47
|
+
## Recipe Modules
|
48
|
+
|
49
|
+
### *recipe_modules* / [bot\_update](/recipes/recipe_modules/bot_update)
|
50
|
+
|
51
|
+
[DEPS](/recipes/recipe_modules/bot_update/__init__.py#1): [depot\_tools](#recipe_modules-depot_tools), [gclient](#recipe_modules-gclient), [gerrit](#recipe_modules-gerrit), [gitiles](#recipe_modules-gitiles), [tryserver](#recipe_modules-tryserver), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/commit\_position][recipe_engine/recipe_modules/commit_position], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/cq][recipe_engine/recipe_modules/cq], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/runtime][recipe_engine/recipe_modules/runtime], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
52
|
+
|
53
|
+
Recipe module to ensure a checkout is consistent on a bot.
|
54
|
+
|
55
|
+
#### **class [BotUpdateApi](/recipes/recipe_modules/bot_update/api.py#12)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
56
|
+
|
57
|
+
— **def [\_\_call\_\_](/recipes/recipe_modules/bot_update/api.py#27)(self, name, cmd, \*\*kwargs):**
|
58
|
+
|
59
|
+
Wrapper for easy calling of bot_update.
|
60
|
+
|
61
|
+
— **def [deapply\_patch](/recipes/recipe_modules/bot_update/api.py#500)(self, bot_update_step):**
|
62
|
+
|
63
|
+
Deapplies a patch, taking care of DEPS and solution revisions properly.
|
64
|
+
|
65
|
+
|
66
|
+
— **def [ensure\_checkout](/recipes/recipe_modules/bot_update/api.py#76)(self, gclient_config=None, suffix=None, patch=True, update_presentation=True, patch_root=None, with_branch_heads=False, with_tags=False, no_fetch_tags=False, refs=None, patch_oauth2=None, oauth2_json=None, use_site_config_creds=None, clobber=False, root_solution_revision=None, rietveld=None, issue=None, patchset=None, gerrit_no_reset=False, gerrit_no_rebase_patch_ref=False, disable_syntax_validation=False, patch_refs=None, ignore_input_commit=False, set_output_commit=False, step_test_data=None, \*\*kwargs):**
|
67
|
+
|
68
|
+
Args:
|
69
|
+
gclient_config: The gclient configuration to use when running bot_update.
|
70
|
+
If omitted, the current gclient configuration is used.
|
71
|
+
no_fetch_tags: When true, the root git repo being checked out will not
|
72
|
+
fetch any tags referenced from the references being fetched. When a repo
|
73
|
+
has many references, it can become a performance bottleneck, so avoid
|
74
|
+
tags if the checkout will not need them present.
|
75
|
+
disable_syntax_validation: (legacy) Disables syntax validation for DEPS.
|
76
|
+
Needed as migration paths for recipes dealing with older revisions,
|
77
|
+
such as bisect.
|
78
|
+
ignore_input_commit: if True, ignore api.buildbucket.gitiles_commit.
|
79
|
+
Exists for historical reasons. Please do not use.
|
80
|
+
set_output_commit: if True, mark the checked out commit as the
|
81
|
+
primary output commit of this build, i.e. call
|
82
|
+
api.buildbucket.set_output_gitiles_commit.
|
83
|
+
In case of multiple repos, the repo is the one specified in
|
84
|
+
api.buildbucket.gitiles_commit or the first configured solution.
|
85
|
+
When sorting builds by commit position, this commit will be used.
|
86
|
+
Requires falsy ignore_input_commit.
|
87
|
+
step_test_data: a null function that returns test bot_update.py output.
|
88
|
+
Use test_api.output_json to generate test data.
|
89
|
+
|
90
|
+
— **def [get\_project\_revision\_properties](/recipes/recipe_modules/bot_update/api.py#477)(self, project_name, gclient_config=None):**
|
91
|
+
|
92
|
+
Returns all property names used for storing the checked-out revision of
|
93
|
+
a given project.
|
94
|
+
|
95
|
+
Args:
|
96
|
+
project_name (str): The name of a checked-out project as deps path, e.g.
|
97
|
+
src or src/v8.
|
98
|
+
gclient_config: The gclient configuration to use. If omitted, the current
|
99
|
+
gclient configuration is used.
|
100
|
+
|
101
|
+
Returns (list of str): All properties that'll hold the checked-out revision
|
102
|
+
of the given project. An empty list if no such properties exist.
|
103
|
+
|
104
|
+
— **def [initialize](/recipes/recipe_modules/bot_update/api.py#22)(self):**
|
105
|
+
|
106
|
+
  **@property**<br>— **def [last\_returned\_properties](/recipes/recipe_modules/bot_update/api.py#44)(self):**
|
107
|
+
|
108
|
+
— **def [resolve\_fixed\_revision](/recipes/recipe_modules/bot_update/api.py#427)(self, bot_update_json, name):**
|
109
|
+
|
110
|
+
Set a fixed revision for a single dependency using project revision
|
111
|
+
properties.
|
112
|
+
### *recipe_modules* / [cipd](/recipes/recipe_modules/cipd)
|
113
|
+
|
114
|
+
[DEPS](/recipes/recipe_modules/cipd/__init__.py#1): [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
115
|
+
|
116
|
+
API for interacting with CIPD.
|
117
|
+
|
118
|
+
Depends on 'cipd' binary available in PATH:
|
119
|
+
https://godoc.org/go.chromium.org/luci/cipd/client/cmd/cipd
|
120
|
+
|
121
|
+
WARNING: There is an alternative cipd recipe_module in recipes-py.git:
|
122
|
+
https://codesearch.chromium.org/chromium/infra/recipes-py/recipe_modules/cipd/
|
123
|
+
|
124
|
+
Consider using that one instead.
|
125
|
+
TODO(crbug.com/875523): Delete this module.
|
126
|
+
|
127
|
+
#### **class [CIPDApi](/recipes/recipe_modules/cipd/api.py#160)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
128
|
+
|
129
|
+
CIPDApi provides basic support for CIPD.
|
130
|
+
|
131
|
+
This assumes that `cipd` (or `cipd.exe` or `cipd.bat` on windows) has been
|
132
|
+
installed somewhere in $PATH. This will be true if you use depot_tools, or if
|
133
|
+
your recipe is running inside of chrome-infrastructure's systems (buildbot,
|
134
|
+
swarming).
|
135
|
+
|
136
|
+
— **def [build](/recipes/recipe_modules/cipd/api.py#233)(self, input_dir, output_package, package_name, install_mode=None):**
|
137
|
+
|
138
|
+
Builds, but does not upload, a cipd package from a directory.
|
139
|
+
|
140
|
+
Args:
|
141
|
+
input_dir (Path) - the directory to build the package from.
|
142
|
+
output_package (Path) - the file to write the package to.
|
143
|
+
package_name (str) - the name of the cipd package as it would appear when
|
144
|
+
uploaded to the cipd package server.
|
145
|
+
install_mode (None|'copy'|'symlink') - the mechanism that the cipd client
|
146
|
+
should use when installing this package. If None, defaults to the
|
147
|
+
platform default ('copy' on windows, 'symlink' on everything else).
|
148
|
+
|
149
|
+
— **def [create\_from\_pkg](/recipes/recipe_modules/cipd/api.py#329)(self, pkg_def, refs=None, tags=None):**
|
150
|
+
|
151
|
+
Builds and uploads a package based on a PackageDefinition object.
|
152
|
+
|
153
|
+
This builds and uploads the package in one step.
|
154
|
+
|
155
|
+
Args:
|
156
|
+
pkg_def (PackageDefinition) - The description of the package we want to
|
157
|
+
create.
|
158
|
+
refs (list(str)) - A list of ref names to set for the package instance.
|
159
|
+
tags (dict(str, str)) - A map of tag name -> value to set for the package
|
160
|
+
instance.
|
161
|
+
|
162
|
+
Returns the JSON 'result' section, e.g.: {
|
163
|
+
"package": "infra/tools/cipd/android-amd64",
|
164
|
+
"instance_id": "433bfdf86c0bb82d1eee2d1a0473d3709c25d2c4"
|
165
|
+
}
|
166
|
+
|
167
|
+
— **def [create\_from\_yaml](/recipes/recipe_modules/cipd/api.py#309)(self, pkg_def, refs=None, tags=None):**
|
168
|
+
|
169
|
+
Builds and uploads a package based on on-disk YAML package definition
|
170
|
+
file.
|
171
|
+
|
172
|
+
This builds and uploads the package in one step.
|
173
|
+
|
174
|
+
Args:
|
175
|
+
pkg_def (Path) - The path to the yaml file.
|
176
|
+
refs (list(str)) - A list of ref names to set for the package instance.
|
177
|
+
tags (dict(str, str)) - A map of tag name -> value to set for the package
|
178
|
+
instance.
|
179
|
+
|
180
|
+
Returns the JSON 'result' section, e.g.: {
|
181
|
+
"package": "infra/tools/cipd/android-amd64",
|
182
|
+
"instance_id": "433bfdf86c0bb82d1eee2d1a0473d3709c25d2c4"
|
183
|
+
}
|
184
|
+
|
185
|
+
  **@property**<br>— **def [default\_bot\_service\_account\_credentials](/recipes/recipe_modules/cipd/api.py#197)(self):**
|
186
|
+
|
187
|
+
— **def [describe](/recipes/recipe_modules/cipd/api.py#436)(self, package_name, version, test_data_refs=None, test_data_tags=None):**
|
188
|
+
|
189
|
+
— **def [ensure](/recipes/recipe_modules/cipd/api.py#351)(self, root, packages):**
|
190
|
+
|
191
|
+
Ensures that packages are installed in a given root dir.
|
192
|
+
|
193
|
+
packages must be a mapping from package name to its version, where
|
194
|
+
* name must be for right platform (see also ``platform_suffix``),
|
195
|
+
* version could be either instance_id, or ref, or unique tag.
|
196
|
+
|
197
|
+
If installing a package requires credentials, call
|
198
|
+
``set_service_account_credentials`` before calling this function.
|
199
|
+
|
200
|
+
  **@property**<br>— **def [executable](/recipes/recipe_modules/cipd/api.py#193)(self):**
|
201
|
+
|
202
|
+
— **def [initialize](/recipes/recipe_modules/cipd/api.py#187)(self):**
|
203
|
+
|
204
|
+
— **def [platform\_suffix](/recipes/recipe_modules/cipd/api.py#206)(self, name=None, arch=None, bits=None):**
|
205
|
+
|
206
|
+
Use to get full package name that is platform indepdent.
|
207
|
+
|
208
|
+
Example:
|
209
|
+
>>> 'my/package/%s' % api.cipd.platform_suffix()
|
210
|
+
'my/package/linux-amd64'
|
211
|
+
|
212
|
+
Optional platform bits and architecture may be supplied to generate CIPD
|
213
|
+
suffixes for other platforms. If any are omitted, the current platform
|
214
|
+
parameters will be used.
|
215
|
+
|
216
|
+
— **def [register](/recipes/recipe_modules/cipd/api.py#261)(self, package_name, package_path, refs=None, tags=None):**
|
217
|
+
|
218
|
+
— **def [search](/recipes/recipe_modules/cipd/api.py#418)(self, package_name, tag):**
|
219
|
+
|
220
|
+
— **def [set\_ref](/recipes/recipe_modules/cipd/api.py#398)(self, package_name, version, refs):**
|
221
|
+
|
222
|
+
— **def [set\_service\_account\_credentials](/recipes/recipe_modules/cipd/api.py#190)(self, path):**
|
223
|
+
|
224
|
+
— **def [set\_tag](/recipes/recipe_modules/cipd/api.py#378)(self, package_name, version, tags):**
|
225
|
+
### *recipe_modules* / [depot\_tools](/recipes/recipe_modules/depot_tools)
|
226
|
+
|
227
|
+
[DEPS](/recipes/recipe_modules/depot_tools/__init__.py#5): [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/runtime][recipe_engine/recipe_modules/runtime]
|
228
|
+
|
229
|
+
The `depot_tools` module provides safe functions to access paths within
|
230
|
+
the depot_tools repo.
|
231
|
+
|
232
|
+
#### **class [DepotToolsApi](/recipes/recipe_modules/depot_tools/api.py#12)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
233
|
+
|
234
|
+
  **@property**<br>— **def [autoninja\_path](/recipes/recipe_modules/depot_tools/api.py#45)(self):**
|
235
|
+
|
236
|
+
  **@property**<br>— **def [cros\_path](/recipes/recipe_modules/depot_tools/api.py#26)(self):**
|
237
|
+
|
238
|
+
  **@property**<br>— **def [download\_from\_google\_storage\_path](/recipes/recipe_modules/depot_tools/api.py#13)(self):**
|
239
|
+
|
240
|
+
  **@property**<br>— **def [gn\_py\_path](/recipes/recipe_modules/depot_tools/api.py#30)(self):**
|
241
|
+
|
242
|
+
  **@property**<br>— **def [gsutil\_py\_path](/recipes/recipe_modules/depot_tools/api.py#36)(self):**
|
243
|
+
|
244
|
+
  **@property**<br>— **def [ninja\_path](/recipes/recipe_modules/depot_tools/api.py#40)(self):**
|
245
|
+
|
246
|
+
  **@contextlib.contextmanager**<br>— **def [on\_path](/recipes/recipe_modules/depot_tools/api.py#54)(self):**
|
247
|
+
|
248
|
+
Use this context manager to put depot_tools on $PATH.
|
249
|
+
|
250
|
+
Example:
|
251
|
+
|
252
|
+
with api.depot_tools.on_path():
|
253
|
+
# run some steps
|
254
|
+
|
255
|
+
  **@property**<br>— **def [presubmit\_support\_py\_path](/recipes/recipe_modules/depot_tools/api.py#50)(self):**
|
256
|
+
|
257
|
+
  **@property**<br>— **def [root](/recipes/recipe_modules/depot_tools/api.py#21)(self):**
|
258
|
+
|
259
|
+
Returns (Path): The "depot_tools" root directory.
|
260
|
+
|
261
|
+
  **@property**<br>— **def [upload\_to\_google\_storage\_path](/recipes/recipe_modules/depot_tools/api.py#17)(self):**
|
262
|
+
### *recipe_modules* / [gclient](/recipes/recipe_modules/gclient)
|
263
|
+
|
264
|
+
[DEPS](/recipes/recipe_modules/gclient/__init__.py#1): [git](#recipe_modules-git), [gitiles](#recipe_modules-gitiles), [tryserver](#recipe_modules-tryserver), [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
265
|
+
|
266
|
+
#### **class [GclientApi](/recipes/recipe_modules/gclient/api.py#68)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
267
|
+
|
268
|
+
  **@property**<br>— **def [DepsDiffException](/recipes/recipe_modules/gclient/api.py#426)(self):**
|
269
|
+
|
270
|
+
— **def [\_\_call\_\_](/recipes/recipe_modules/gclient/api.py#78)(self, name, cmd, infra_step=True, \*\*kwargs):**
|
271
|
+
|
272
|
+
Wrapper for easy calling of gclient steps.
|
273
|
+
|
274
|
+
— **def [break\_locks](/recipes/recipe_modules/gclient/api.py#274)(self):**
|
275
|
+
|
276
|
+
Remove all index.lock files. If a previous run of git crashed, bot was
|
277
|
+
reset, etc... we might end up with leftover index.lock files.
|
278
|
+
|
279
|
+
— **def [checkout](/recipes/recipe_modules/gclient/api.py#234)(self, gclient_config=None, revert=RevertOnTryserver, inject_parent_got_revision=True, extra_sync_flags=None, \*\*kwargs):**
|
280
|
+
|
281
|
+
Return a step generator function for gclient checkouts.
|
282
|
+
|
283
|
+
  **@staticmethod**<br>— **def [config\_to\_pythonish](/recipes/recipe_modules/gclient/api.py#123)(cfg):**
|
284
|
+
|
285
|
+
— **def [diff\_deps](/recipes/recipe_modules/gclient/api.py#365)(self, cwd):**
|
286
|
+
|
287
|
+
— **def [get\_config\_defaults](/recipes/recipe_modules/gclient/api.py#117)(self):**
|
288
|
+
|
289
|
+
— **def [get\_gerrit\_patch\_root](/recipes/recipe_modules/gclient/api.py#296)(self, gclient_config=None):**
|
290
|
+
|
291
|
+
Returns local path to the repo where gerrit patch will be applied.
|
292
|
+
|
293
|
+
If there is no patch, returns None.
|
294
|
+
If patch is specified, but such repo is not found among configured solutions
|
295
|
+
or repo_path_map, returns name of the first solution. This is done solely
|
296
|
+
for backward compatibility with existing tests.
|
297
|
+
Please do not rely on this logic in new code.
|
298
|
+
Instead, properly map a repository to a local path using repo_path_map.
|
299
|
+
TODO(nodir): remove this. Update all recipe tests to specify a git_repo
|
300
|
+
matching the recipe.
|
301
|
+
|
302
|
+
— **def [get\_repo\_path](/recipes/recipe_modules/gclient/api.py#323)(self, repo_url, gclient_config=None):**
|
303
|
+
|
304
|
+
Returns local path to the repo checkout given its url.
|
305
|
+
|
306
|
+
Consults cfg.repo_path_map and fallbacks to urls in configured solutions.
|
307
|
+
|
308
|
+
Returns None if not found.
|
309
|
+
|
310
|
+
  **@staticmethod**<br>— **def [got\_revision\_reverse\_mapping](/recipes/recipe_modules/gclient/api.py#128)(cfg):**
|
311
|
+
|
312
|
+
Returns the merged got_revision_reverse_mapping.
|
313
|
+
|
314
|
+
Returns (dict): A mapping from property name -> project name. It merges the
|
315
|
+
values of the deprecated got_revision_mapping and the new
|
316
|
+
got_revision_reverse_mapping.
|
317
|
+
|
318
|
+
— **def [inject\_parent\_got\_revision](/recipes/recipe_modules/gclient/api.py#209)(self, gclient_config=None, override=False):**
|
319
|
+
|
320
|
+
Match gclient config to build revisions obtained from build_properties.
|
321
|
+
|
322
|
+
Args:
|
323
|
+
gclient_config (gclient config object) - The config to manipulate. A value
|
324
|
+
of None manipulates the module's built-in config (self.c).
|
325
|
+
override (bool) - If True, will forcibly set revision and custom_vars
|
326
|
+
even if the config already contains values for them.
|
327
|
+
|
328
|
+
— **def [resolve\_revision](/recipes/recipe_modules/gclient/api.py#145)(self, revision):**
|
329
|
+
|
330
|
+
— **def [runhooks](/recipes/recipe_modules/gclient/api.py#268)(self, args=None, name='runhooks', \*\*kwargs):**
|
331
|
+
|
332
|
+
— **def [set\_patch\_repo\_revision](/recipes/recipe_modules/gclient/api.py#353)(self, gclient_config=None):**
|
333
|
+
|
334
|
+
Updates config revision corresponding to patched project.
|
335
|
+
|
336
|
+
Useful for bot_update only, as this is the only consumer of gclient's config
|
337
|
+
revision map. This doesn't overwrite the revision if it was already set.
|
338
|
+
|
339
|
+
  **@spec_alias.deleter**<br>— **def [spec\_alias](/recipes/recipe_modules/gclient/api.py#113)(self):**
|
340
|
+
|
341
|
+
— **def [sync](/recipes/recipe_modules/gclient/api.py#150)(self, cfg, extra_sync_flags=None, \*\*kwargs):**
|
342
|
+
|
343
|
+
  **@use_mirror.setter**<br>— **def [use\_mirror](/recipes/recipe_modules/gclient/api.py#100)(self, val):**
|
344
|
+
### *recipe_modules* / [gerrit](/recipes/recipe_modules/gerrit)
|
345
|
+
|
346
|
+
[DEPS](/recipes/recipe_modules/gerrit/__init__.py#1): [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
347
|
+
|
348
|
+
#### **class [GerritApi](/recipes/recipe_modules/gerrit/api.py#7)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
349
|
+
|
350
|
+
Module for interact with gerrit endpoints
|
351
|
+
|
352
|
+
— **def [\_\_call\_\_](/recipes/recipe_modules/gerrit/api.py#14)(self, name, cmd, infra_step=True, \*\*kwargs):**
|
353
|
+
|
354
|
+
Wrapper for easy calling of gerrit_utils steps.
|
355
|
+
|
356
|
+
— **def [abandon\_change](/recipes/recipe_modules/gerrit/api.py#160)(self, host, change, message=None, name=None, step_test_data=None):**
|
357
|
+
|
358
|
+
— **def [create\_gerrit\_branch](/recipes/recipe_modules/gerrit/api.py#32)(self, host, project, branch, commit, \*\*kwargs):**
|
359
|
+
|
360
|
+
Create a new branch from given project and commit
|
361
|
+
|
362
|
+
Returns:
|
363
|
+
the ref of the branch created
|
364
|
+
|
365
|
+
— **def [get\_change\_description](/recipes/recipe_modules/gerrit/api.py#73)(self, host, change, patchset):**
|
366
|
+
|
367
|
+
Get the description for a given CL and patchset.
|
368
|
+
|
369
|
+
Args:
|
370
|
+
host: URL of Gerrit host to query.
|
371
|
+
change: The change number.
|
372
|
+
patchset: The patchset number.
|
373
|
+
|
374
|
+
Returns:
|
375
|
+
The description corresponding to given CL and patchset.
|
376
|
+
|
377
|
+
— **def [get\_changes](/recipes/recipe_modules/gerrit/api.py#118)(self, host, query_params, start=None, limit=None, o_params=None, step_test_data=None, \*\*kwargs):**
|
378
|
+
|
379
|
+
Query changes for the given host.
|
380
|
+
|
381
|
+
Args:
|
382
|
+
host: URL of Gerrit host to query.
|
383
|
+
query_params: Query parameters as list of (key, value) tuples to form a
|
384
|
+
query as documented here:
|
385
|
+
https://gerrit-review.googlesource.com/Documentation/user-search.html#search-operators
|
386
|
+
start: How many changes to skip (starting with the most recent).
|
387
|
+
limit: Maximum number of results to return.
|
388
|
+
o_params: A list of additional output specifiers, as documented here:
|
389
|
+
https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-changes
|
390
|
+
step_test_data: Optional mock test data for the underlying gerrit client.
|
391
|
+
Returns:
|
392
|
+
A list of change dicts as documented here:
|
393
|
+
https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-changes
|
394
|
+
|
395
|
+
— **def [get\_gerrit\_branch](/recipes/recipe_modules/gerrit/api.py#54)(self, host, project, branch, \*\*kwargs):**
|
396
|
+
|
397
|
+
Get a branch from given project and commit
|
398
|
+
|
399
|
+
Returns:
|
400
|
+
the revision of the branch
|
401
|
+
|
402
|
+
— **def [get\_revision\_info](/recipes/recipe_modules/gerrit/api.py#88)(self, host, change, patchset):**
|
403
|
+
|
404
|
+
Returns the info for a given patchset of a given change.
|
405
|
+
|
406
|
+
Args:
|
407
|
+
host: Gerrit host to query.
|
408
|
+
change: The change number.
|
409
|
+
patchset: The patchset number.
|
410
|
+
|
411
|
+
Returns:
|
412
|
+
A dict for the target revision as documented here:
|
413
|
+
https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-changes
|
414
|
+
### *recipe_modules* / [git](/recipes/recipe_modules/git)
|
415
|
+
|
416
|
+
[DEPS](/recipes/recipe_modules/git/__init__.py#1): [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/runtime][recipe_engine/recipe_modules/runtime], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
417
|
+
|
418
|
+
#### **class [GitApi](/recipes/recipe_modules/git/api.py#10)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
419
|
+
|
420
|
+
— **def [\_\_call\_\_](/recipes/recipe_modules/git/api.py#13)(self, \*args, \*\*kwargs):**
|
421
|
+
|
422
|
+
Return a git command step.
|
423
|
+
|
424
|
+
— **def [bundle\_create](/recipes/recipe_modules/git/api.py#374)(self, bundle_path, rev_list_args=None, \*\*kwargs):**
|
425
|
+
|
426
|
+
Run 'git bundle create' on a Git repository.
|
427
|
+
|
428
|
+
Args:
|
429
|
+
bundle_path (Path): The path of the output bundle.
|
430
|
+
refs (list): The list of refs to include in the bundle. If None, all
|
431
|
+
refs in the Git checkout will be bundled.
|
432
|
+
kwargs: Forwarded to '__call__'.
|
433
|
+
|
434
|
+
— **def [cat\_file\_at\_commit](/recipes/recipe_modules/git/api.py#40)(self, file_path, commit_hash, remote_name=None, \*\*kwargs):**
|
435
|
+
|
436
|
+
Outputs the contents of a file at a given revision.
|
437
|
+
|
438
|
+
— **def [checkout](/recipes/recipe_modules/git/api.py#112)(self, url, ref=None, dir_path=None, recursive=False, submodules=True, submodule_update_force=False, keep_paths=None, step_suffix=None, curl_trace_file=None, can_fail_build=True, set_got_revision=False, remote_name=None, display_fetch_size=None, file_name=None, submodule_update_recursive=True, use_git_cache=False, progress=True, tags=False):**
|
439
|
+
|
440
|
+
Performs a full git checkout and returns sha1 of checked out revision.
|
441
|
+
|
442
|
+
Args:
|
443
|
+
url (str): url of remote repo to use as upstream
|
444
|
+
ref (str): ref to fetch and check out
|
445
|
+
dir_path (Path): optional directory to clone into
|
446
|
+
recursive (bool): whether to recursively fetch submodules or not
|
447
|
+
submodules (bool): whether to sync and update submodules or not
|
448
|
+
submodule_update_force (bool): whether to update submodules with --force
|
449
|
+
keep_paths (iterable of strings): paths to ignore during git-clean;
|
450
|
+
paths are gitignore-style patterns relative to checkout_path.
|
451
|
+
step_suffix (str): suffix to add to a each step name
|
452
|
+
curl_trace_file (Path): if not None, dump GIT_CURL_VERBOSE=1 trace to that
|
453
|
+
file. Useful for debugging git issue reproducible only on bots. It has
|
454
|
+
a side effect of all stderr output of 'git fetch' going to that file.
|
455
|
+
can_fail_build (bool): if False, ignore errors during fetch or checkout.
|
456
|
+
set_got_revision (bool): if True, resolves HEAD and sets got_revision
|
457
|
+
property.
|
458
|
+
remote_name (str): name of the git remote to use
|
459
|
+
display_fetch_size (bool): if True, run `git count-objects` before and
|
460
|
+
after fetch and display delta. Adds two more steps. Defaults to False.
|
461
|
+
file_name (str): optional path to a single file to checkout.
|
462
|
+
submodule_update_recursive (bool): if True, updates submodules
|
463
|
+
recursively.
|
464
|
+
use_git_cache (bool): if True, git cache will be used for this checkout.
|
465
|
+
WARNING, this is EXPERIMENTAL!!! This wasn't tested with:
|
466
|
+
* submodules
|
467
|
+
* since origin url is modified
|
468
|
+
to a local path, may cause problem with scripts that do
|
469
|
+
"git fetch origin" or "git push origin".
|
470
|
+
* arbitrary refs such refs/whatever/not-fetched-by-default-to-cache
|
471
|
+
progress (bool): whether to show progress for fetch or not
|
472
|
+
tags (bool): Also fetch tags.
|
473
|
+
|
474
|
+
Returns: If the checkout was successful, this returns the commit hash of
|
475
|
+
the checked-out-repo. Otherwise this returns None.
|
476
|
+
|
477
|
+
— **def [config\_get](/recipes/recipe_modules/git/api.py#347)(self, prop_name, \*\*kwargs):**
|
478
|
+
|
479
|
+
Returns: (str) The Git config output, or None if no output was generated.
|
480
|
+
|
481
|
+
Args:
|
482
|
+
prop_name: (str) The name of the config property to query.
|
483
|
+
kwargs: Forwarded to '__call__'.
|
484
|
+
|
485
|
+
— **def [count\_objects](/recipes/recipe_modules/git/api.py#48)(self, previous_result=None, can_fail_build=False, \*\*kwargs):**
|
486
|
+
|
487
|
+
Returns `git count-objects` result as a dict.
|
488
|
+
|
489
|
+
Args:
|
490
|
+
previous_result (dict): the result of previous count_objects call.
|
491
|
+
If passed, delta is reported in the log and step text.
|
492
|
+
can_fail_build (bool): if True, may fail the build and/or raise an
|
493
|
+
exception. Defaults to False.
|
494
|
+
|
495
|
+
Returns:
|
496
|
+
A dict of count-object values, or None if count-object run failed.
|
497
|
+
|
498
|
+
— **def [fetch\_tags](/recipes/recipe_modules/git/api.py#34)(self, remote_name=None, \*\*kwargs):**
|
499
|
+
|
500
|
+
Fetches all tags from the remote.
|
501
|
+
|
502
|
+
— **def [get\_remote\_url](/recipes/recipe_modules/git/api.py#364)(self, remote_name=None, \*\*kwargs):**
|
503
|
+
|
504
|
+
Returns: (str) The URL of the remote Git repository, or None.
|
505
|
+
|
506
|
+
Args:
|
507
|
+
remote_name: (str) The name of the remote to query, defaults to 'origin'.
|
508
|
+
kwargs: Forwarded to '__call__'.
|
509
|
+
|
510
|
+
— **def [get\_timestamp](/recipes/recipe_modules/git/api.py#319)(self, commit='HEAD', test_data=None, \*\*kwargs):**
|
511
|
+
|
512
|
+
Find and return the timestamp of the given commit.
|
513
|
+
|
514
|
+
— **def [new\_branch](/recipes/recipe_modules/git/api.py#387)(self, branch, name=None, upstream=None, \*\*kwargs):**
|
515
|
+
|
516
|
+
Runs git new-branch on a Git repository, to be used before git cl upload.
|
517
|
+
|
518
|
+
Args:
|
519
|
+
branch (str): new branch name, which must not yet exist.
|
520
|
+
name (str): step name.
|
521
|
+
upstream (str): to origin/master.
|
522
|
+
kwargs: Forwarded to '__call__'.
|
523
|
+
|
524
|
+
— **def [rebase](/recipes/recipe_modules/git/api.py#328)(self, name_prefix, branch, dir_path, remote_name=None, \*\*kwargs):**
|
525
|
+
|
526
|
+
Run rebase HEAD onto branch
|
527
|
+
Args:
|
528
|
+
name_prefix (str): a prefix used for the step names
|
529
|
+
branch (str): a branch name or a hash to rebase onto
|
530
|
+
dir_path (Path): directory to clone into
|
531
|
+
remote_name (str): the remote name to rebase from if not origin
|
532
|
+
### *recipe_modules* / [git\_cl](/recipes/recipe_modules/git_cl)
|
533
|
+
|
534
|
+
[DEPS](/recipes/recipe_modules/git_cl/__init__.py#1): [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io]
|
535
|
+
|
536
|
+
#### **class [GitClApi](/recipes/recipe_modules/git_cl/api.py#9)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
537
|
+
|
538
|
+
— **def [get\_description](/recipes/recipe_modules/git_cl/api.py#23)(self, patch_url=None, \*\*kwargs):**
|
539
|
+
|
540
|
+
DEPRECATED. Consider using gerrit.get_change_description instead.
|
541
|
+
|
542
|
+
— **def [issue](/recipes/recipe_modules/git_cl/api.py#48)(self, \*\*kwargs):**
|
543
|
+
|
544
|
+
— **def [set\_description](/recipes/recipe_modules/git_cl/api.py#31)(self, description, patch_url=None, \*\*kwargs):**
|
545
|
+
|
546
|
+
— **def [upload](/recipes/recipe_modules/git_cl/api.py#41)(self, message, upload_args=None, \*\*kwargs):**
|
547
|
+
### *recipe_modules* / [gitiles](/recipes/recipe_modules/gitiles)
|
548
|
+
|
549
|
+
[DEPS](/recipes/recipe_modules/gitiles/__init__.py#5): [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/step][recipe_engine/recipe_modules/step], [recipe\_engine/url][recipe_engine/recipe_modules/url]
|
550
|
+
|
551
|
+
#### **class [Gitiles](/recipes/recipe_modules/gitiles/api.py#11)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
552
|
+
|
553
|
+
Module for polling a git repository using the Gitiles web interface.
|
554
|
+
|
555
|
+
— **def [canonicalize\_repo\_url](/recipes/recipe_modules/gitiles/api.py#216)(self, repo_url):**
|
556
|
+
|
557
|
+
Returns a canonical form of repo_url. If not recognized, returns as is.
|
558
|
+
|
559
|
+
|
560
|
+
— **def [commit\_log](/recipes/recipe_modules/gitiles/api.py#114)(self, url, commit, step_name=None, attempts=None):**
|
561
|
+
|
562
|
+
Returns: (dict) the Gitiles commit log structure for a given commit.
|
563
|
+
|
564
|
+
Args:
|
565
|
+
url (str): The base repository URL.
|
566
|
+
commit (str): The commit hash.
|
567
|
+
step_name (str): If not None, override the step name.
|
568
|
+
attempts (int): Number of times to try the request before failing.
|
569
|
+
|
570
|
+
— **def [download\_archive](/recipes/recipe_modules/gitiles/api.py#156)(self, repository_url, destination, revision='refs/heads/master'):**
|
571
|
+
|
572
|
+
Downloads an archive of the repo and extracts it to `destination`.
|
573
|
+
|
574
|
+
If the gitiles server attempts to provide a tarball with paths which escape
|
575
|
+
`destination`, this function will extract all valid files and then
|
576
|
+
raise StepFailure with an attribute `StepFailure.gitiles_skipped_files`
|
577
|
+
containing the names of the files that were skipped.
|
578
|
+
|
579
|
+
Args:
|
580
|
+
repository_url (str): Full URL to the repository
|
581
|
+
destination (Path): Local path to extract the archive to. Must not exist
|
582
|
+
prior to this call.
|
583
|
+
revision (str): The ref or revision in the repo to download. Defaults to
|
584
|
+
'refs/heads/master'.
|
585
|
+
|
586
|
+
— **def [download\_file](/recipes/recipe_modules/gitiles/api.py#130)(self, repository_url, file_path, branch='master', step_name=None, attempts=None, \*\*kwargs):**
|
587
|
+
|
588
|
+
Downloads raw file content from a Gitiles repository.
|
589
|
+
|
590
|
+
Args:
|
591
|
+
repository_url (str): Full URL to the repository.
|
592
|
+
branch (str): Branch of the repository.
|
593
|
+
file_path (str): Relative path to the file from the repository root.
|
594
|
+
step_name (str): Custom name for this step (optional).
|
595
|
+
attempts (int): Number of times to try the request before failing.
|
596
|
+
|
597
|
+
Returns:
|
598
|
+
Raw file content.
|
599
|
+
|
600
|
+
— **def [log](/recipes/recipe_modules/gitiles/api.py#68)(self, url, ref, limit=0, cursor=None, step_name=None, attempts=None, \*\*kwargs):**
|
601
|
+
|
602
|
+
Returns the most recent commits under the given ref with properties.
|
603
|
+
|
604
|
+
Args:
|
605
|
+
url (str): URL of the remote repository.
|
606
|
+
ref (str): Name of the desired ref (see Gitiles.refs).
|
607
|
+
limit (int): Number of commits to limit the fetching to.
|
608
|
+
Gitiles does not return all commits in one call; instead paging is
|
609
|
+
used. 0 implies to return whatever first gerrit responds with.
|
610
|
+
Otherwise, paging will be used to fetch at least this many
|
611
|
+
commits, but all fetched commits will be returned.
|
612
|
+
cursor (str or None): The paging cursor used to fetch the next page.
|
613
|
+
step_name (str): Custom name for this step (optional).
|
614
|
+
|
615
|
+
Returns:
|
616
|
+
A tuple of (commits, cursor).
|
617
|
+
Commits are a list of commits (as Gitiles dict structure) in reverse
|
618
|
+
chronological order. The number of commits may be higher than limit
|
619
|
+
argument.
|
620
|
+
Cursor can be used for subsequent calls to log for paging. If None,
|
621
|
+
signals that there are no more commits to fetch.
|
622
|
+
|
623
|
+
— **def [parse\_repo\_url](/recipes/recipe_modules/gitiles/api.py#205)(self, repo_url):**
|
624
|
+
|
625
|
+
Returns (host, project) pair.
|
626
|
+
|
627
|
+
Returns (None, None) if repo_url is not recognized.
|
628
|
+
|
629
|
+
— **def [refs](/recipes/recipe_modules/gitiles/api.py#56)(self, url, step_name='refs', attempts=None):**
|
630
|
+
|
631
|
+
Returns a list of refs in the remote repository.
|
632
|
+
|
633
|
+
— **def [unparse\_repo\_url](/recipes/recipe_modules/gitiles/api.py#212)(self, host, project):**
|
634
|
+
|
635
|
+
Generates a Gitiles repo URL. See also parse_repo_url.
|
636
|
+
### *recipe_modules* / [gsutil](/recipes/recipe_modules/gsutil)
|
637
|
+
|
638
|
+
[DEPS](/recipes/recipe_modules/gsutil/__init__.py#1): [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/python][recipe_engine/recipe_modules/python]
|
639
|
+
|
640
|
+
#### **class [GSUtilApi](/recipes/recipe_modules/gsutil/api.py#9)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
641
|
+
|
642
|
+
— **def [\_\_call\_\_](/recipes/recipe_modules/gsutil/api.py#14)(self, cmd, name=None, use_retry_wrapper=True, version=None, parallel_upload=False, multithreaded=False, infra_step=True, \*\*kwargs):**
|
643
|
+
|
644
|
+
A step to run arbitrary gsutil commands.
|
645
|
+
|
646
|
+
On LUCI this should automatically use the ambient task account credentials.
|
647
|
+
On Buildbot, this assumes that gsutil authentication environment variables
|
648
|
+
(AWS_CREDENTIAL_FILE and BOTO_CONFIG) are already set, though if you want to
|
649
|
+
set them to something else you can always do so using the env={} kwarg.
|
650
|
+
|
651
|
+
Note also that gsutil does its own wildcard processing, so wildcards are
|
652
|
+
valid in file-like portions of the cmd. See 'gsutil help wildcards'.
|
653
|
+
|
654
|
+
Arguments:
|
655
|
+
|
656
|
+
* cmd (List[str|Path]) - Arguments to pass to gsutil. Include gsutil-level
|
657
|
+
options first (see 'gsutil help options').
|
658
|
+
* name (str) - Name of the step to use. Defaults to the first non-flag
|
659
|
+
token in the cmd.
|
660
|
+
|
661
|
+
— **def [cat](/recipes/recipe_modules/gsutil/api.py#109)(self, url, args=None, \*\*kwargs):**
|
662
|
+
|
663
|
+
— **def [copy](/recipes/recipe_modules/gsutil/api.py#123)(self, source_bucket, source, dest_bucket, dest, args=None, link_name='gsutil.copy', metadata=None, unauthenticated_url=False, \*\*kwargs):**
|
664
|
+
|
665
|
+
— **def [download](/recipes/recipe_modules/gsutil/api.py#95)(self, bucket, source, dest, args=None, \*\*kwargs):**
|
666
|
+
|
667
|
+
— **def [download\_url](/recipes/recipe_modules/gsutil/api.py#102)(self, url, dest, args=None, \*\*kwargs):**
|
668
|
+
|
669
|
+
  **@property**<br>— **def [gsutil\_py\_path](/recipes/recipe_modules/gsutil/api.py#10)(self):**
|
670
|
+
|
671
|
+
— **def [list](/recipes/recipe_modules/gsutil/api.py#142)(self, url, args=None, \*\*kwargs):**
|
672
|
+
|
673
|
+
— **def [remove\_url](/recipes/recipe_modules/gsutil/api.py#156)(self, url, args=None, \*\*kwargs):**
|
674
|
+
|
675
|
+
— **def [signurl](/recipes/recipe_modules/gsutil/api.py#149)(self, private_key_file, bucket, dest, args=None, \*\*kwargs):**
|
676
|
+
|
677
|
+
— **def [stat](/recipes/recipe_modules/gsutil/api.py#116)(self, url, args=None, \*\*kwargs):**
|
678
|
+
|
679
|
+
— **def [upload](/recipes/recipe_modules/gsutil/api.py#78)(self, source, bucket, dest, args=None, link_name='gsutil.upload', metadata=None, unauthenticated_url=False, \*\*kwargs):**
|
680
|
+
### *recipe_modules* / [osx\_sdk](/recipes/recipe_modules/osx_sdk)
|
681
|
+
|
682
|
+
[DEPS](/recipes/recipe_modules/osx_sdk/__init__.py#5): [recipe\_engine/cipd][recipe_engine/recipe_modules/cipd], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/step][recipe_engine/recipe_modules/step], [recipe\_engine/version][recipe_engine/recipe_modules/version]
|
683
|
+
|
684
|
+
The `osx_sdk` module provides safe functions to access a semi-hermetic
|
685
|
+
XCode installation.
|
686
|
+
|
687
|
+
Available only to Google-run bots.
|
688
|
+
|
689
|
+
#### **class [OSXSDKApi](/recipes/recipe_modules/osx_sdk/api.py#35)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
690
|
+
|
691
|
+
API for using OS X SDK distributed via CIPD.
|
692
|
+
|
693
|
+
  **@contextmanager**<br>— **def [\_\_call\_\_](/recipes/recipe_modules/osx_sdk/api.py#61)(self, kind):**
|
694
|
+
|
695
|
+
Sets up the XCode SDK environment.
|
696
|
+
|
697
|
+
Is a no-op on non-mac platforms.
|
698
|
+
|
699
|
+
This will deploy the helper tool and the XCode.app bundle at
|
700
|
+
`[START_DIR]/cache/osx_sdk`.
|
701
|
+
|
702
|
+
To avoid machines rebuilding these on every run, set up a named cache in
|
703
|
+
your cr-buildbucket.cfg file like:
|
704
|
+
|
705
|
+
caches: {
|
706
|
+
# Cache for mac_toolchain tool and XCode.app
|
707
|
+
name: "osx_sdk"
|
708
|
+
path: "osx_sdk"
|
709
|
+
}
|
710
|
+
|
711
|
+
If you have builders which e.g. use a non-current SDK, you can give them
|
712
|
+
a uniqely named cache:
|
713
|
+
|
714
|
+
caches: {
|
715
|
+
# Cache for N-1 version mac_toolchain tool and XCode.app
|
716
|
+
name: "osx_sdk_old"
|
717
|
+
path: "osx_sdk"
|
718
|
+
}
|
719
|
+
|
720
|
+
Similarly, if you have mac and iOS builders you may want to distinguish the
|
721
|
+
cache name by adding '_ios' to it. However, if you're sharing the same bots
|
722
|
+
for both mac and iOS, consider having a single cache and just always
|
723
|
+
fetching the iOS version. This will lead to lower overall disk utilization
|
724
|
+
and should help to reduce cache thrashing.
|
725
|
+
|
726
|
+
Usage:
|
727
|
+
with api.osx_sdk('mac'):
|
728
|
+
# sdk with mac build bits
|
729
|
+
|
730
|
+
with api.osx_sdk('ios'):
|
731
|
+
# sdk with mac+iOS build bits
|
732
|
+
|
733
|
+
Args:
|
734
|
+
kind ('mac'|'ios'): How the SDK should be configured. iOS includes the
|
735
|
+
base XCode distribution, as well as the iOS simulators (which can be
|
736
|
+
quite large).
|
737
|
+
|
738
|
+
Raises:
|
739
|
+
StepFailure or InfraFailure.
|
740
|
+
|
741
|
+
— **def [initialize](/recipes/recipe_modules/osx_sdk/api.py#46)(self):**
|
742
|
+
### *recipe_modules* / [presubmit](/recipes/recipe_modules/presubmit)
|
743
|
+
|
744
|
+
[DEPS](/recipes/recipe_modules/presubmit/__init__.py#11): [bot\_update](#recipe_modules-bot_update), [depot\_tools](#recipe_modules-depot_tools), [gclient](#recipe_modules-gclient), [git](#recipe_modules-git), [tryserver](#recipe_modules-tryserver), [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/cq][recipe_engine/recipe_modules/cq], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
745
|
+
|
746
|
+
#### **class [PresubmitApi](/recipes/recipe_modules/presubmit/api.py#16)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
747
|
+
|
748
|
+
— **def [\_\_call\_\_](/recipes/recipe_modules/presubmit/api.py#28)(self, \*args, \*\*kwargs):**
|
749
|
+
|
750
|
+
Return a presubmit step.
|
751
|
+
|
752
|
+
— **def [execute](/recipes/recipe_modules/presubmit/api.py#77)(self, bot_update_step, skip_owners=False):**
|
753
|
+
|
754
|
+
Runs presubmit and sets summary markdown if applicable.
|
755
|
+
|
756
|
+
Args:
|
757
|
+
bot_update_step: the StepResult from a previously executed bot_update step.
|
758
|
+
skip_owners: a boolean indicating whether Owners checks should be skipped.
|
759
|
+
Returns:
|
760
|
+
a RawResult object, suitable for being returned from RunSteps.
|
761
|
+
|
762
|
+
— **def [prepare](/recipes/recipe_modules/presubmit/api.py#41)(self):**
|
763
|
+
|
764
|
+
Set up a presubmit run.
|
765
|
+
|
766
|
+
This includes:
|
767
|
+
|
768
|
+
- setting up the checkout w/ bot_update
|
769
|
+
- locally committing the applied patch
|
770
|
+
- running hooks, if requested
|
771
|
+
|
772
|
+
This expects the gclient configuration to already have been set.
|
773
|
+
|
774
|
+
Returns:
|
775
|
+
the StepResult from the bot_update step.
|
776
|
+
|
777
|
+
  **@property**<br>— **def [presubmit\_support\_path](/recipes/recipe_modules/presubmit/api.py#24)(self):**
|
778
|
+
### *recipe_modules* / [tryserver](/recipes/recipe_modules/tryserver)
|
779
|
+
|
780
|
+
[DEPS](/recipes/recipe_modules/tryserver/__init__.py#5): [gerrit](#recipe_modules-gerrit), [git](#recipe_modules-git), [git\_cl](#recipe_modules-git_cl), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
781
|
+
|
782
|
+
#### **class [TryserverApi](/recipes/recipe_modules/tryserver/api.py#11)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
783
|
+
|
784
|
+
  **@property**<br>— **def [gerrit\_change](/recipes/recipe_modules/tryserver/api.py#33)(self):**
|
785
|
+
|
786
|
+
Returns current gerrit change, if there is exactly one.
|
787
|
+
|
788
|
+
Returns a self.m.buildbucket.common_pb2.GerritChange or None.
|
789
|
+
|
790
|
+
  **@property**<br>— **def [gerrit\_change\_fetch\_ref](/recipes/recipe_modules/tryserver/api.py#110)(self):**
|
791
|
+
|
792
|
+
Returns gerrit patch ref, e.g. "refs/heads/45/12345/6, or None.
|
793
|
+
|
794
|
+
Populated iff gerrit_change is populated.
|
795
|
+
|
796
|
+
  **@property**<br>— **def [gerrit\_change\_owner](/recipes/recipe_modules/tryserver/api.py#49)(self):**
|
797
|
+
|
798
|
+
Returns owner of the current Gerrit CL.
|
799
|
+
|
800
|
+
Populated iff gerrit_change is populated.
|
801
|
+
Is a dictionary with keys like "name".
|
802
|
+
|
803
|
+
  **@property**<br>— **def [gerrit\_change\_repo\_url](/recipes/recipe_modules/tryserver/api.py#41)(self):**
|
804
|
+
|
805
|
+
Returns canonical URL of the gitiles repo of the current Gerrit CL.
|
806
|
+
|
807
|
+
Populated iff gerrit_change is populated.
|
808
|
+
|
809
|
+
  **@property**<br>— **def [gerrit\_change\_target\_ref](/recipes/recipe_modules/tryserver/api.py#119)(self):**
|
810
|
+
|
811
|
+
Returns gerrit change destination ref, e.g. "refs/heads/master".
|
812
|
+
|
813
|
+
Populated iff gerrit_change is populated.
|
814
|
+
|
815
|
+
— **def [get\_files\_affected\_by\_patch](/recipes/recipe_modules/tryserver/api.py#149)(self, patch_root, \*\*kwargs):**
|
816
|
+
|
817
|
+
Returns list of paths to files affected by the patch.
|
818
|
+
|
819
|
+
Argument:
|
820
|
+
patch_root: path relative to api.path['root'], usually obtained from
|
821
|
+
api.gclient.get_gerrit_patch_root().
|
822
|
+
|
823
|
+
Returned paths will be relative to to patch_root.
|
824
|
+
|
825
|
+
— **def [get\_footer](/recipes/recipe_modules/tryserver/api.py#259)(self, tag, patch_text=None):**
|
826
|
+
|
827
|
+
Gets a specific tag from a CL description
|
828
|
+
|
829
|
+
— **def [get\_footers](/recipes/recipe_modules/tryserver/api.py#239)(self, patch_text=None):**
|
830
|
+
|
831
|
+
Retrieves footers from the patch description.
|
832
|
+
|
833
|
+
footers are machine readable tags embedded in commit messages. See
|
834
|
+
git-footers documentation for more information.
|
835
|
+
|
836
|
+
— **def [initialize](/recipes/recipe_modules/tryserver/api.py#22)(self):**
|
837
|
+
|
838
|
+
  **@property**<br>— **def [is\_gerrit\_issue](/recipes/recipe_modules/tryserver/api.py#133)(self):**
|
839
|
+
|
840
|
+
Returns true iff the properties exist to match a Gerrit issue.
|
841
|
+
|
842
|
+
  **@property**<br>— **def [is\_patch\_in\_git](/recipes/recipe_modules/tryserver/api.py#143)(self):**
|
843
|
+
|
844
|
+
  **@property**<br>— **def [is\_tryserver](/recipes/recipe_modules/tryserver/api.py#128)(self):**
|
845
|
+
|
846
|
+
Returns true iff we have a change to check out.
|
847
|
+
|
848
|
+
— **def [normalize\_footer\_name](/recipes/recipe_modules/tryserver/api.py#263)(self, footer):**
|
849
|
+
|
850
|
+
— **def [set\_compile\_failure\_tryjob\_result](/recipes/recipe_modules/tryserver/api.py#202)(self):**
|
851
|
+
|
852
|
+
Mark the tryjob result as a compile failure.
|
853
|
+
|
854
|
+
— **def [set\_invalid\_test\_results\_tryjob\_result](/recipes/recipe_modules/tryserver/api.py#214)(self):**
|
855
|
+
|
856
|
+
Mark the tryjob result as having invalid test results.
|
857
|
+
|
858
|
+
This means we run some tests, but the results were not valid
|
859
|
+
(e.g. no list of specific test cases that failed, or too many
|
860
|
+
tests failing, etc).
|
861
|
+
|
862
|
+
— **def [set\_patch\_failure\_tryjob\_result](/recipes/recipe_modules/tryserver/api.py#198)(self):**
|
863
|
+
|
864
|
+
Mark the tryjob result as failure to apply the patch.
|
865
|
+
|
866
|
+
— **def [set\_subproject\_tag](/recipes/recipe_modules/tryserver/api.py#176)(self, subproject_tag):**
|
867
|
+
|
868
|
+
Adds a subproject tag to the build.
|
869
|
+
|
870
|
+
This can be used to distinguish between builds that execute different steps
|
871
|
+
depending on what was patched, e.g. blink vs. pure chromium patches.
|
872
|
+
|
873
|
+
— **def [set\_test\_expired\_tryjob\_result](/recipes/recipe_modules/tryserver/api.py#231)(self):**
|
874
|
+
|
875
|
+
Mark the tryjob result as a test expiration.
|
876
|
+
|
877
|
+
This means a test task expired and was never scheduled, most likely due to
|
878
|
+
lack of capacity.
|
879
|
+
|
880
|
+
— **def [set\_test\_failure\_tryjob\_result](/recipes/recipe_modules/tryserver/api.py#206)(self):**
|
881
|
+
|
882
|
+
Mark the tryjob result as a test failure.
|
883
|
+
|
884
|
+
This means we started running actual tests (not prerequisite steps
|
885
|
+
like checkout or compile), and some of these tests have failed.
|
886
|
+
|
887
|
+
— **def [set\_test\_timeout\_tryjob\_result](/recipes/recipe_modules/tryserver/api.py#223)(self):**
|
888
|
+
|
889
|
+
Mark the tryjob result as a test timeout.
|
890
|
+
|
891
|
+
This means tests were scheduled but didn't finish executing within the
|
892
|
+
timeout.
|
893
|
+
### *recipe_modules* / [windows\_sdk](/recipes/recipe_modules/windows_sdk)
|
894
|
+
|
895
|
+
[DEPS](/recipes/recipe_modules/windows_sdk/__init__.py#5): [recipe\_engine/cipd][recipe_engine/recipe_modules/cipd], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
896
|
+
|
897
|
+
The `windows_sdk` module provides safe functions to access a hermetic
|
898
|
+
Microsoft Visual Studio installation.
|
899
|
+
|
900
|
+
Available only to Google-run bots.
|
901
|
+
|
902
|
+
#### **class [WindowsSDKApi](/recipes/recipe_modules/windows_sdk/api.py#16)([RecipeApi][recipe_engine/wkt/RecipeApi]):**
|
903
|
+
|
904
|
+
API for using Windows SDK distributed via CIPD.
|
905
|
+
|
906
|
+
  **@contextmanager**<br>— **def [\_\_call\_\_](/recipes/recipe_modules/windows_sdk/api.py#26)(self, path=None, version=None, enabled=True, target_arch='x64'):**
|
907
|
+
|
908
|
+
Setups the SDK environment when enabled.
|
909
|
+
|
910
|
+
Args:
|
911
|
+
path (path): Path to a directory where to install the SDK
|
912
|
+
(default is '[CACHE]/windows_sdk')
|
913
|
+
version (str): CIPD version of the SDK
|
914
|
+
(default is set via $infra/windows_sdk.version property)
|
915
|
+
enabled (bool): Whether the SDK should be used or not.
|
916
|
+
target_arch (str): 'x86' or 'x64'.
|
917
|
+
|
918
|
+
Yields:
|
919
|
+
If enabled, yields SDKPaths object with paths to well-known roots within
|
920
|
+
the deployed bundle:
|
921
|
+
* win_sdk - a Path to the root of the extracted Windows SDK.
|
922
|
+
* dia_sdk - a Path to the root of the extracted Debug Interface Access
|
923
|
+
SDK.
|
924
|
+
|
925
|
+
Raises:
|
926
|
+
StepFailure or InfraFailure.
|
927
|
+
## Recipes
|
928
|
+
|
929
|
+
### *recipes* / [bot\_update:examples/full](/recipes/recipe_modules/bot_update/examples/full.py)
|
930
|
+
|
931
|
+
[DEPS](/recipes/recipe_modules/bot_update/examples/full.py#5): [bot\_update](#recipe_modules-bot_update), [gclient](#recipe_modules-gclient), [gerrit](#recipe_modules-gerrit), [tryserver](#recipe_modules-tryserver), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/runtime][recipe_engine/recipe_modules/runtime]
|
932
|
+
|
933
|
+
— **def [RunSteps](/recipes/recipe_modules/bot_update/examples/full.py#22)(api):**
|
934
|
+
### *recipes* / [bot\_update:tests/do\_not\_retry\_patch\_failures\_in\_cq](/recipes/recipe_modules/bot_update/tests/do_not_retry_patch_failures_in_cq.py)
|
935
|
+
|
936
|
+
[DEPS](/recipes/recipe_modules/bot_update/tests/do_not_retry_patch_failures_in_cq.py#5): [bot\_update](#recipe_modules-bot_update), [gclient](#recipe_modules-gclient), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/cq][recipe_engine/recipe_modules/cq], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
937
|
+
|
938
|
+
— **def [RunSteps](/recipes/recipe_modules/bot_update/tests/do_not_retry_patch_failures_in_cq.py#17)(api):**
|
939
|
+
### *recipes* / [bot\_update:tests/ensure\_checkout](/recipes/recipe_modules/bot_update/tests/ensure_checkout.py)
|
940
|
+
|
941
|
+
[DEPS](/recipes/recipe_modules/bot_update/tests/ensure_checkout.py#7): [bot\_update](#recipe_modules-bot_update), [gclient](#recipe_modules-gclient), [recipe\_engine/json][recipe_engine/recipe_modules/json]
|
942
|
+
|
943
|
+
— **def [RunSteps](/recipes/recipe_modules/bot_update/tests/ensure_checkout.py#14)(api):**
|
944
|
+
### *recipes* / [cipd:examples/full](/recipes/recipe_modules/cipd/examples/full.py)
|
945
|
+
|
946
|
+
[DEPS](/recipes/recipe_modules/cipd/examples/full.py#8): [cipd](#recipe_modules-cipd), [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
947
|
+
|
948
|
+
— **def [RunSteps](/recipes/recipe_modules/cipd/examples/full.py#27)(api, use_pkg, pkg_files, pkg_dirs, ver_files, install_mode):**
|
949
|
+
### *recipes* / [cipd:examples/platform\_suffix](/recipes/recipe_modules/cipd/examples/platform_suffix.py)
|
950
|
+
|
951
|
+
[DEPS](/recipes/recipe_modules/cipd/examples/platform_suffix.py#8): [cipd](#recipe_modules-cipd), [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
952
|
+
|
953
|
+
— **def [RunSteps](/recipes/recipe_modules/cipd/examples/platform_suffix.py#22)(api, arch_override, bits_override, expect_error):**
|
954
|
+
### *recipes* / [depot\_tools:examples/full](/recipes/recipe_modules/depot_tools/examples/full.py)
|
955
|
+
|
956
|
+
[DEPS](/recipes/recipe_modules/depot_tools/examples/full.py#5): [depot\_tools](#recipe_modules-depot_tools), [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/runtime][recipe_engine/recipe_modules/runtime], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
957
|
+
|
958
|
+
— **def [RunSteps](/recipes/recipe_modules/depot_tools/examples/full.py#14)(api):**
|
959
|
+
### *recipes* / [fetch\_end\_to\_end\_test](/recipes/recipes/fetch_end_to_end_test.py)
|
960
|
+
|
961
|
+
[DEPS](/recipes/recipes/fetch_end_to_end_test.py#5): [bot\_update](#recipe_modules-bot_update), [gclient](#recipe_modules-gclient), [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/file][recipe_engine/recipe_modules/file], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
962
|
+
|
963
|
+
— **def [RunSteps](/recipes/recipes/fetch_end_to_end_test.py#16)(api):**
|
964
|
+
### *recipes* / [gclient:examples/full](/recipes/recipe_modules/gclient/examples/full.py)
|
965
|
+
|
966
|
+
[DEPS](/recipes/recipe_modules/gclient/examples/full.py#5): [gclient](#recipe_modules-gclient), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
967
|
+
|
968
|
+
— **def [RunSteps](/recipes/recipe_modules/gclient/examples/full.py#55)(api):**
|
969
|
+
### *recipes* / [gclient:tests/diff\_deps](/recipes/recipe_modules/gclient/tests/diff_deps.py)
|
970
|
+
|
971
|
+
[DEPS](/recipes/recipe_modules/gclient/tests/diff_deps.py#7): [gclient](#recipe_modules-gclient), [recipe\_engine/assertions][recipe_engine/recipe_modules/assertions], [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io]
|
972
|
+
|
973
|
+
— **def [RunSteps](/recipes/recipe_modules/gclient/tests/diff_deps.py#18)(api):**
|
974
|
+
### *recipes* / [gclient:tests/patch\_project](/recipes/recipe_modules/gclient/tests/patch_project.py)
|
975
|
+
|
976
|
+
[DEPS](/recipes/recipe_modules/gclient/tests/patch_project.py#9): [gclient](#recipe_modules-gclient), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/properties][recipe_engine/recipe_modules/properties]
|
977
|
+
|
978
|
+
— **def [RunSteps](/recipes/recipe_modules/gclient/tests/patch_project.py#18)(api):**
|
979
|
+
### *recipes* / [gclient:tests/sync\_failure](/recipes/recipe_modules/gclient/tests/sync_failure.py)
|
980
|
+
|
981
|
+
[DEPS](/recipes/recipe_modules/gclient/tests/sync_failure.py#7): [gclient](#recipe_modules-gclient), [recipe\_engine/path][recipe_engine/recipe_modules/path]
|
982
|
+
|
983
|
+
— **def [RunSteps](/recipes/recipe_modules/gclient/tests/sync_failure.py#13)(api):**
|
984
|
+
### *recipes* / [gerrit:examples/full](/recipes/recipe_modules/gerrit/examples/full.py)
|
985
|
+
|
986
|
+
[DEPS](/recipes/recipe_modules/gerrit/examples/full.py#5): [gerrit](#recipe_modules-gerrit), [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
987
|
+
|
988
|
+
— **def [RunSteps](/recipes/recipe_modules/gerrit/examples/full.py#11)(api):**
|
989
|
+
### *recipes* / [git:examples/full](/recipes/recipe_modules/git/examples/full.py)
|
990
|
+
|
991
|
+
[DEPS](/recipes/recipe_modules/git/examples/full.py#5): [git](#recipe_modules-git), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
992
|
+
|
993
|
+
— **def [RunSteps](/recipes/recipe_modules/git/examples/full.py#18)(api):**
|
994
|
+
### *recipes* / [git\_cl:examples/full](/recipes/recipe_modules/git_cl/examples/full.py)
|
995
|
+
|
996
|
+
[DEPS](/recipes/recipe_modules/git_cl/examples/full.py#9): [git\_cl](#recipe_modules-git_cl), [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
997
|
+
|
998
|
+
— **def [RunSteps](/recipes/recipe_modules/git_cl/examples/full.py#17)(api):**
|
999
|
+
### *recipes* / [gitiles:examples/full](/recipes/recipe_modules/gitiles/examples/full.py)
|
1000
|
+
|
1001
|
+
[DEPS](/recipes/recipe_modules/gitiles/examples/full.py#5): [gitiles](#recipe_modules-gitiles), [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
1002
|
+
|
1003
|
+
— **def [RunSteps](/recipes/recipe_modules/gitiles/examples/full.py#14)(api):**
|
1004
|
+
### *recipes* / [gitiles:tests/parse\_repo\_url](/recipes/recipe_modules/gitiles/tests/parse_repo_url.py)
|
1005
|
+
|
1006
|
+
[DEPS](/recipes/recipe_modules/gitiles/tests/parse_repo_url.py#5): [gitiles](#recipe_modules-gitiles), [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
1007
|
+
|
1008
|
+
— **def [RunSteps](/recipes/recipe_modules/gitiles/tests/parse_repo_url.py#12)(api):**
|
1009
|
+
### *recipes* / [gsutil:examples/full](/recipes/recipe_modules/gsutil/examples/full.py)
|
1010
|
+
|
1011
|
+
[DEPS](/recipes/recipe_modules/gsutil/examples/full.py#5): [gsutil](#recipe_modules-gsutil), [recipe\_engine/path][recipe_engine/recipe_modules/path]
|
1012
|
+
|
1013
|
+
— **def [RunSteps](/recipes/recipe_modules/gsutil/examples/full.py#11)(api):**
|
1014
|
+
|
1015
|
+
Move things around in a loop!
|
1016
|
+
### *recipes* / [osx\_sdk:examples/full](/recipes/recipe_modules/osx_sdk/examples/full.py)
|
1017
|
+
|
1018
|
+
[DEPS](/recipes/recipe_modules/osx_sdk/examples/full.py#5): [osx\_sdk](#recipe_modules-osx_sdk), [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
1019
|
+
|
1020
|
+
— **def [RunSteps](/recipes/recipe_modules/osx_sdk/examples/full.py#13)(api):**
|
1021
|
+
### *recipes* / [presubmit:examples/full](/recipes/recipe_modules/presubmit/examples/full.py)
|
1022
|
+
|
1023
|
+
[DEPS](/recipes/recipe_modules/presubmit/examples/full.py#5): [presubmit](#recipe_modules-presubmit), [recipe\_engine/json][recipe_engine/recipe_modules/json]
|
1024
|
+
|
1025
|
+
— **def [RunSteps](/recipes/recipe_modules/presubmit/examples/full.py#11)(api):**
|
1026
|
+
### *recipes* / [presubmit:tests/execute](/recipes/recipe_modules/presubmit/tests/execute.py)
|
1027
|
+
|
1028
|
+
[DEPS](/recipes/recipe_modules/presubmit/tests/execute.py#10): [gclient](#recipe_modules-gclient), [presubmit](#recipe_modules-presubmit), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/cq][recipe_engine/recipe_modules/cq], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/runtime][recipe_engine/recipe_modules/runtime]
|
1029
|
+
|
1030
|
+
— **def [RunSteps](/recipes/recipe_modules/presubmit/tests/execute.py#23)(api):**
|
1031
|
+
### *recipes* / [presubmit:tests/prepare](/recipes/recipe_modules/presubmit/tests/prepare.py)
|
1032
|
+
|
1033
|
+
[DEPS](/recipes/recipe_modules/presubmit/tests/prepare.py#9): [gclient](#recipe_modules-gclient), [presubmit](#recipe_modules-presubmit), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/context][recipe_engine/recipe_modules/context], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/runtime][recipe_engine/recipe_modules/runtime]
|
1034
|
+
|
1035
|
+
— **def [RunSteps](/recipes/recipe_modules/presubmit/tests/prepare.py#26)(api, patch_project, patch_repository_url):**
|
1036
|
+
### *recipes* / [tryserver:examples/full](/recipes/recipe_modules/tryserver/examples/full.py)
|
1037
|
+
|
1038
|
+
[DEPS](/recipes/recipe_modules/tryserver/examples/full.py#5): [gerrit](#recipe_modules-gerrit), [tryserver](#recipe_modules-tryserver), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/json][recipe_engine/recipe_modules/json], [recipe\_engine/path][recipe_engine/recipe_modules/path], [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/python][recipe_engine/recipe_modules/python], [recipe\_engine/raw\_io][recipe_engine/recipe_modules/raw_io], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
1039
|
+
|
1040
|
+
— **def [RunSteps](/recipes/recipe_modules/tryserver/examples/full.py#19)(api):**
|
1041
|
+
### *recipes* / [tryserver:tests/gerrit\_change\_fetch\_ref\_timeout](/recipes/recipe_modules/tryserver/tests/gerrit_change_fetch_ref_timeout.py)
|
1042
|
+
|
1043
|
+
[DEPS](/recipes/recipe_modules/tryserver/tests/gerrit_change_fetch_ref_timeout.py#7): [gerrit](#recipe_modules-gerrit), [tryserver](#recipe_modules-tryserver), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/properties][recipe_engine/recipe_modules/properties]
|
1044
|
+
|
1045
|
+
— **def [RunSteps](/recipes/recipe_modules/tryserver/tests/gerrit_change_fetch_ref_timeout.py#15)(api):**
|
1046
|
+
### *recipes* / [tryserver:tests/gerrit\_change\_owner](/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.py)
|
1047
|
+
|
1048
|
+
[DEPS](/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.py#7): [gerrit](#recipe_modules-gerrit), [tryserver](#recipe_modules-tryserver), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket]
|
1049
|
+
|
1050
|
+
— **def [RunSteps](/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.py#14)(api):**
|
1051
|
+
### *recipes* / [tryserver:tests/gerrit\_change\_target\_ref](/recipes/recipe_modules/tryserver/tests/gerrit_change_target_ref.py)
|
1052
|
+
|
1053
|
+
[DEPS](/recipes/recipe_modules/tryserver/tests/gerrit_change_target_ref.py#7): [gerrit](#recipe_modules-gerrit), [tryserver](#recipe_modules-tryserver), [recipe\_engine/buildbucket][recipe_engine/recipe_modules/buildbucket], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
1054
|
+
|
1055
|
+
— **def [RunSteps](/recipes/recipe_modules/tryserver/tests/gerrit_change_target_ref.py#16)(api):**
|
1056
|
+
### *recipes* / [windows\_sdk:examples/full](/recipes/recipe_modules/windows_sdk/examples/full.py)
|
1057
|
+
|
1058
|
+
[DEPS](/recipes/recipe_modules/windows_sdk/examples/full.py#5): [windows\_sdk](#recipe_modules-windows_sdk), [recipe\_engine/platform][recipe_engine/recipe_modules/platform], [recipe\_engine/properties][recipe_engine/recipe_modules/properties], [recipe\_engine/step][recipe_engine/recipe_modules/step]
|
1059
|
+
|
1060
|
+
— **def [RunSteps](/recipes/recipe_modules/windows_sdk/examples/full.py#13)(api):**
|
1061
|
+
|
1062
|
+
[recipe_engine/recipe_modules/assertions]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-assertions
|
1063
|
+
[recipe_engine/recipe_modules/buildbucket]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-buildbucket
|
1064
|
+
[recipe_engine/recipe_modules/cipd]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-cipd
|
1065
|
+
[recipe_engine/recipe_modules/commit_position]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-commit_position
|
1066
|
+
[recipe_engine/recipe_modules/context]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-context
|
1067
|
+
[recipe_engine/recipe_modules/cq]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-cq
|
1068
|
+
[recipe_engine/recipe_modules/file]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-file
|
1069
|
+
[recipe_engine/recipe_modules/json]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-json
|
1070
|
+
[recipe_engine/recipe_modules/path]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-path
|
1071
|
+
[recipe_engine/recipe_modules/platform]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-platform
|
1072
|
+
[recipe_engine/recipe_modules/properties]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-properties
|
1073
|
+
[recipe_engine/recipe_modules/python]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-python
|
1074
|
+
[recipe_engine/recipe_modules/raw_io]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-raw_io
|
1075
|
+
[recipe_engine/recipe_modules/runtime]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-runtime
|
1076
|
+
[recipe_engine/recipe_modules/step]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-step
|
1077
|
+
[recipe_engine/recipe_modules/url]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-url
|
1078
|
+
[recipe_engine/recipe_modules/version]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/README.recipes.md#recipe_modules-version
|
1079
|
+
[recipe_engine/wkt/RecipeApi]: https://chromium.googlesource.com/infra/luci/recipes-py.git/+/59e7d3f289e8f160db10bbcd311b299805080c4b/recipe_engine/recipe_api.py#801
|