libv8 6.7.288.46.1 → 7.3.492.27.0beta1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +3 -0
- data/CHANGELOG.md +4 -0
- data/README.md +2 -0
- data/ext/libv8/builder.rb +6 -2
- data/lib/libv8/version.rb +1 -1
- data/vendor/depot_tools/.gitattributes +1 -0
- data/vendor/depot_tools/.gitignore +7 -0
- data/vendor/depot_tools/CROS_OWNERS +5 -0
- data/vendor/depot_tools/OWNERS +12 -1
- data/vendor/depot_tools/PRESUBMIT.py +16 -9
- data/vendor/depot_tools/README.md +9 -2
- data/vendor/depot_tools/autoninja +14 -6
- data/vendor/depot_tools/autoninja.bat +11 -1
- data/vendor/depot_tools/autoninja.py +40 -18
- data/vendor/depot_tools/bb +12 -0
- data/vendor/depot_tools/bb.bat +7 -0
- data/vendor/depot_tools/bootstrap/win/manifest.txt +1 -1
- data/vendor/depot_tools/bootstrap/win/manifest_bleeding_edge.txt +1 -1
- data/vendor/depot_tools/bootstrap/win/win_tools.py +2 -1
- data/vendor/depot_tools/buildbucket.py +57 -4
- data/vendor/depot_tools/cipd +157 -44
- data/vendor/depot_tools/cipd.bat +51 -14
- data/vendor/depot_tools/cipd.ps1 +104 -42
- data/vendor/depot_tools/cipd_client_version +1 -1
- data/vendor/depot_tools/cipd_client_version.digests +21 -0
- data/vendor/depot_tools/cipd_manifest.txt +19 -6
- data/vendor/depot_tools/cipd_manifest.versions +318 -0
- data/vendor/depot_tools/clang_format.py +4 -4
- data/vendor/depot_tools/cpplint.py +44 -199
- data/vendor/depot_tools/dart_format.py +2 -2
- data/vendor/depot_tools/detect_host_arch.py +8 -3
- data/vendor/depot_tools/download_from_google_storage.py +47 -39
- data/vendor/depot_tools/fetch.py +30 -18
- data/vendor/depot_tools/fetch_configs/android_internal.py +34 -0
- data/vendor/depot_tools/fetch_configs/chromium.py +18 -1
- data/vendor/depot_tools/fetch_configs/config_util.py +4 -2
- data/vendor/depot_tools/fetch_configs/inspector_protocol.py +40 -0
- data/vendor/depot_tools/fetch_configs/node-ci.py +41 -0
- data/vendor/depot_tools/fix_encoding.py +3 -3
- data/vendor/depot_tools/gclient +1 -1
- data/vendor/depot_tools/gclient.py +415 -198
- data/vendor/depot_tools/gclient_eval.py +220 -171
- data/vendor/depot_tools/gclient_paths.py +142 -0
- data/vendor/depot_tools/gclient_scm.py +200 -51
- data/vendor/depot_tools/gclient_utils.py +88 -191
- data/vendor/depot_tools/gerrit_client.py +13 -0
- data/vendor/depot_tools/gerrit_util.py +158 -23
- data/vendor/depot_tools/git-nav-upstream +1 -1
- data/vendor/depot_tools/git_cache.py +77 -24
- data/vendor/depot_tools/git_cl.py +705 -1099
- data/vendor/depot_tools/git_common.py +9 -6
- data/vendor/depot_tools/git_map_branches.py +19 -2
- data/vendor/depot_tools/git_nav_downstream.py +3 -4
- data/vendor/depot_tools/git_rebase_update.py +14 -0
- data/vendor/depot_tools/git_reparent_branch.py +8 -2
- data/vendor/depot_tools/gn.py +38 -3
- data/vendor/depot_tools/gsutil.py +8 -3
- data/vendor/depot_tools/gsutil.py.bat +15 -0
- data/vendor/depot_tools/gsutil.vpython +16 -0
- data/vendor/depot_tools/infra/config/OWNERS +0 -1
- data/vendor/depot_tools/infra/config/recipes.cfg +3 -2
- data/vendor/depot_tools/lucicfg +12 -0
- data/vendor/depot_tools/lucicfg.bat +7 -0
- data/vendor/depot_tools/man/html/git-map-branches.html +34 -2
- data/vendor/depot_tools/man/html/git-new-branch.html +40 -32
- data/vendor/depot_tools/man/man1/git-map-branches.1 +24 -5
- data/vendor/depot_tools/man/man1/git-new-branch.1 +35 -27
- data/vendor/depot_tools/man/src/git-map-branches.demo.1.sh +1 -0
- data/vendor/depot_tools/man/src/git-map-branches.txt +10 -0
- data/vendor/depot_tools/man/src/git-new-branch.demo.1.sh +9 -4
- data/vendor/depot_tools/man/src/git-new-branch.txt +1 -1
- data/vendor/depot_tools/metrics.README.md +98 -0
- data/vendor/depot_tools/metrics.py +296 -0
- data/vendor/depot_tools/metrics_utils.py +303 -0
- data/vendor/depot_tools/my_activity.py +91 -29
- data/vendor/depot_tools/ninja +1 -1
- data/vendor/depot_tools/ninjalog.README.md +64 -0
- data/vendor/depot_tools/ninjalog_uploader.py +232 -0
- data/vendor/depot_tools/ninjalog_uploader_wrapper.py +116 -0
- data/vendor/depot_tools/owners.py +30 -13
- data/vendor/depot_tools/owners_finder.py +5 -2
- data/vendor/depot_tools/presubmit_canned_checks.py +188 -29
- data/vendor/depot_tools/presubmit_support.py +18 -41
- data/vendor/depot_tools/pylintrc +23 -19
- data/vendor/depot_tools/recipes/OWNERS +2 -0
- data/vendor/depot_tools/recipes/README.recipes.md +344 -151
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/OWNERS +2 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/__init__.py +2 -16
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/api.py +141 -99
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic.json +5 -8
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_luci.json +5 -8
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_with_branch_heads.json +6 -98
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/clobber.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/deprecated_got_revision_mapping.json +45 -5
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_rebase_patch_ref.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_reset.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{tryjob.json → input_commit_with_id_without_repo.json} +6 -11
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{tryjob_empty_revision.json → multiple_patch_refs.json} +8 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_apply_patch_on_gclient.json +19 -29
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{trychange.json → refs.json} +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/reset_root_solution_revision.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail.json +51 -6
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch.json +50 -6
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch_download.json +51 -6
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle.json +17 -25
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_branch_heads.json +17 -25
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_feature_branch.json +18 -26
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8_feature_branch.json +18 -26
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_webrtc.json +26 -28
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8.json +45 -5
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8_head_by_default.json +17 -25
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/unrecognized_commit_repo.json +13 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name.json +13 -152
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_tags.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.py +185 -202
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/bot_update.py +52 -157
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/test_api.py +5 -14
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/ensure_checkout.py +34 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/api.py +14 -2
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic_pkg.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-failed.json +7 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-many-instances.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/mac64.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_file.json +9 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_mode.json +9 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_verfile.json +9 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/win64.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk arch.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk bits.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_32.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_32.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_mips_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/mac_intel_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_32.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/api.py +13 -8
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic.json +18 -12
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic_luci.json +18 -12
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/win.json +18 -12
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.py +3 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/__init__.py +1 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/api.py +58 -46
- data/vendor/depot_tools/recipes/recipe_modules/gclient/config.py +65 -22
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/basic.json +20 -21
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/buildbot.json +20 -21
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/revision.json +20 -21
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/tryserver.json +20 -21
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.py +5 -2
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/patch_project.py +62 -14
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/api.py +24 -38
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.expected/basic.json +56 -50
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.py +15 -9
- data/vendor/depot_tools/recipes/recipe_modules/git/__init__.py +4 -1
- data/vendor/depot_tools/recipes/recipe_modules/git/api.py +34 -22
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_branch.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_file_name.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_hash.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_luci.json +222 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_ref.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_submodule_update_force.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_tags.json +224 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/can_fail_build.json +10 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cannot_fail_build.json +5 -7
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cat-file_test.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_delta.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_failed.json +5 -7
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output_fails_build.json +10 -5
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/curl_trace_file.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/git-cache-checkout.json +8 -9
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/platform_win.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/rebase_failed.json +12 -8
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/remote_not_origin.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/set_got_revision.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.py +27 -11
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/api.py +1 -1
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.expected/basic.json +12 -13
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/__init__.py +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/api.py +120 -5
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.expected/basic.json +45 -3
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.py +25 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/resources/gerrit_client.py +56 -4
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.expected/basic.json +6 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.py +49 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/api.py +24 -13
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.expected/basic.json +13 -14
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/basic.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_linux.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_mac.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_win.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_linux.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_mac.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_win.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_linux.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_mac.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_win.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/path_config.py +1 -2
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/__init__.py +35 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/api.py +116 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/linux.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/mac.json +82 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/win.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.py +23 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/__init__.py +1 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/api.py +2 -7
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.expected/basic.json +7 -6
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/__init__.py +1 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/api.py +117 -8
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/basic_tags.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/set_failure_hash_with_no_steps.json +7 -4
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch.json +98 -7
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch_and_target_ref.json +147 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch.json +8 -5
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch_luci.json +8 -5
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch.json +9 -6
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch_new.json +9 -6
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.py +27 -2
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/test_api.py +14 -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 +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/mac.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/win.json +107 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.py +26 -0
- data/vendor/depot_tools/recipes/recipes.py +37 -27
- data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.expected/basic.json +7 -10
- data/vendor/depot_tools/repo +34 -8
- data/vendor/depot_tools/roll_dep.py +52 -49
- data/vendor/depot_tools/scm.py +38 -23
- data/vendor/depot_tools/setup_color.py +4 -2
- data/vendor/depot_tools/split_cl.py +32 -4
- data/vendor/depot_tools/subprocess2.py +22 -4
- data/vendor/depot_tools/third_party/httplib2/README.chromium +2 -2
- data/vendor/depot_tools/third_party/httplib2/__init__.py +242 -158
- data/vendor/depot_tools/third_party/httplib2/cacerts.txt +57 -44
- data/vendor/depot_tools/third_party/httplib2/socks.py +15 -5
- data/vendor/depot_tools/third_party/logilab/README.chromium +2 -4
- data/vendor/depot_tools/third_party/logilab/astroid/README.chromium +2 -1
- data/vendor/depot_tools/third_party/logilab/astroid/__init__.py +10 -5
- data/vendor/depot_tools/third_party/logilab/astroid/__pkginfo__.py +5 -5
- data/vendor/depot_tools/third_party/logilab/astroid/arguments.py +233 -0
- data/vendor/depot_tools/third_party/logilab/astroid/as_string.py +82 -33
- data/vendor/depot_tools/third_party/logilab/astroid/bases.py +137 -153
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{builtin_inference.py → brain_builtin_inference.py} +117 -26
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_dateutil.py +15 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{py2gi.py → brain_gi.py} +48 -8
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{py2mechanize.py → brain_mechanize.py} +0 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{pynose.py → brain_nose.py} +4 -1
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_numpy.py +62 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_pytest.py +76 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_qt.py +44 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{pysix_moves.py → brain_six.py} +28 -1
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_ssl.py +65 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_stdlib.py +473 -0
- data/vendor/depot_tools/third_party/logilab/astroid/builder.py +104 -81
- data/vendor/depot_tools/third_party/logilab/astroid/context.py +81 -0
- data/vendor/depot_tools/third_party/logilab/astroid/decorators.py +75 -0
- data/vendor/depot_tools/third_party/logilab/astroid/exceptions.py +20 -0
- data/vendor/depot_tools/third_party/logilab/astroid/inference.py +137 -183
- data/vendor/depot_tools/third_party/logilab/astroid/manager.py +45 -169
- data/vendor/depot_tools/third_party/logilab/astroid/mixins.py +37 -14
- data/vendor/depot_tools/third_party/logilab/astroid/modutils.py +112 -41
- data/vendor/depot_tools/third_party/logilab/astroid/node_classes.py +243 -156
- data/vendor/depot_tools/third_party/logilab/astroid/nodes.py +35 -22
- data/vendor/depot_tools/third_party/logilab/astroid/objects.py +186 -0
- data/vendor/depot_tools/third_party/logilab/astroid/protocols.py +157 -102
- data/vendor/depot_tools/third_party/logilab/astroid/raw_building.py +32 -8
- data/vendor/depot_tools/third_party/logilab/astroid/rebuilder.py +372 -309
- data/vendor/depot_tools/third_party/logilab/astroid/scoped_nodes.py +652 -420
- data/vendor/depot_tools/third_party/logilab/astroid/test_utils.py +4 -21
- data/vendor/depot_tools/third_party/logilab/astroid/transforms.py +96 -0
- data/vendor/depot_tools/third_party/logilab/astroid/util.py +89 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/LICENSE +19 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/README.chromium +11 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/__init__.py +20 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/cext.c +1421 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/compat.py +9 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/simple.py +246 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/slots.py +414 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/utils.py +13 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/LICENSE +24 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/README.chromium +11 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/__init__.py +19 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/_wrappers.c +2729 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/arguments.py +96 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/decorators.py +512 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/importer.py +228 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/wrappers.py +901 -0
- data/vendor/depot_tools/third_party/pylint/README.chromium +2 -25
- data/vendor/depot_tools/third_party/pylint/__pkginfo__.py +13 -3
- data/vendor/depot_tools/third_party/pylint/checkers/__init__.py +1 -2
- data/vendor/depot_tools/third_party/pylint/checkers/async.py +82 -0
- data/vendor/depot_tools/third_party/pylint/checkers/base.py +893 -119
- data/vendor/depot_tools/third_party/pylint/checkers/classes.py +342 -204
- data/vendor/depot_tools/third_party/pylint/checkers/design_analysis.py +51 -34
- data/vendor/depot_tools/third_party/pylint/checkers/exceptions.py +84 -47
- data/vendor/depot_tools/third_party/pylint/checkers/format.py +55 -30
- data/vendor/depot_tools/third_party/pylint/checkers/imports.py +314 -73
- data/vendor/depot_tools/third_party/pylint/checkers/logging.py +10 -8
- data/vendor/depot_tools/third_party/pylint/checkers/misc.py +2 -1
- data/vendor/depot_tools/third_party/pylint/checkers/newstyle.py +45 -48
- data/vendor/depot_tools/third_party/pylint/checkers/python3.py +31 -21
- data/vendor/depot_tools/third_party/pylint/checkers/raw_metrics.py +3 -3
- data/vendor/depot_tools/third_party/pylint/checkers/similar.py +4 -5
- data/vendor/depot_tools/third_party/pylint/checkers/spelling.py +24 -10
- data/vendor/depot_tools/third_party/pylint/checkers/stdlib.py +120 -56
- data/vendor/depot_tools/third_party/pylint/checkers/strings.py +38 -35
- data/vendor/depot_tools/third_party/pylint/checkers/typecheck.py +485 -138
- data/vendor/depot_tools/third_party/pylint/checkers/utils.py +319 -142
- data/vendor/depot_tools/third_party/pylint/checkers/variables.py +329 -207
- data/vendor/depot_tools/third_party/pylint/config.py +739 -76
- data/vendor/depot_tools/third_party/pylint/epylint.py +9 -5
- data/vendor/depot_tools/third_party/pylint/extensions/__init__.py +0 -0
- data/vendor/depot_tools/third_party/pylint/extensions/check_docs.py +311 -0
- data/vendor/depot_tools/third_party/pylint/extensions/check_elif.py +62 -0
- data/vendor/depot_tools/third_party/{logilab/common → pylint}/graph.py +30 -133
- data/vendor/depot_tools/third_party/pylint/gui.py +2 -2
- data/vendor/depot_tools/third_party/pylint/interfaces.py +21 -3
- data/vendor/depot_tools/third_party/pylint/lint.py +123 -140
- data/vendor/depot_tools/third_party/pylint/pyreverse/diadefslib.py +10 -13
- data/vendor/depot_tools/third_party/pylint/pyreverse/diagrams.py +15 -4
- data/vendor/depot_tools/third_party/pylint/pyreverse/inspector.py +372 -0
- data/vendor/depot_tools/third_party/pylint/pyreverse/main.py +30 -7
- data/vendor/depot_tools/third_party/pylint/pyreverse/utils.py +80 -2
- data/vendor/depot_tools/third_party/{logilab/common → pylint/pyreverse}/vcgutils.py +19 -37
- data/vendor/depot_tools/third_party/pylint/pyreverse/writer.py +3 -4
- data/vendor/depot_tools/third_party/pylint/reporters/__init__.py +34 -18
- data/vendor/depot_tools/third_party/pylint/reporters/guireporter.py +1 -1
- data/vendor/depot_tools/third_party/pylint/reporters/html.py +10 -3
- data/vendor/depot_tools/third_party/pylint/reporters/json.py +10 -4
- data/vendor/depot_tools/third_party/pylint/reporters/text.py +94 -3
- data/vendor/depot_tools/third_party/pylint/reporters/ureports/__init__.py +106 -0
- data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/html_writer.py +17 -57
- data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/nodes.py +52 -74
- data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/text_writer.py +14 -60
- data/vendor/depot_tools/third_party/pylint/testutils.py +22 -20
- data/vendor/depot_tools/third_party/pylint/utils.py +268 -44
- data/vendor/depot_tools/third_party/repo/progress.py +42 -0
- data/vendor/depot_tools/update_depot_tools +1 -1
- data/vendor/depot_tools/upload_metrics.py +25 -0
- data/vendor/depot_tools/win_toolchain/get_toolchain_if_necessary.py +45 -15
- data/vendor/depot_tools/win_toolchain/package_from_installed.py +71 -24
- data/vendor/depot_tools/yapf +1 -1
- data/vendor/depot_tools/yapf.bat +1 -1
- metadata +92 -77
- data/vendor/depot_tools/git-crsync +0 -3
- data/vendor/depot_tools/infra/config/cq.cfg +0 -32
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/apply_gerrit_ref.json +0 -29
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/apply_gerrit_ref_custom.json +0 -29
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/buildbot.json +0 -105
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/shallow.json +0 -195
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle_deprecated.json +0 -248
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8.json +0 -248
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name_no_patch.json +0 -105
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/apply_gerrit.py +0 -33
- data/vendor/depot_tools/third_party/logilab/astroid/brain/py2pytest.py +0 -31
- data/vendor/depot_tools/third_party/logilab/astroid/brain/py2qt4.py +0 -22
- data/vendor/depot_tools/third_party/logilab/astroid/brain/py2stdlib.py +0 -334
- data/vendor/depot_tools/third_party/logilab/astroid/inspector.py +0 -273
- data/vendor/depot_tools/third_party/logilab/astroid/utils.py +0 -239
- data/vendor/depot_tools/third_party/logilab/common/LICENSE.txt +0 -339
- data/vendor/depot_tools/third_party/logilab/common/README.chromium +0 -11
- data/vendor/depot_tools/third_party/logilab/common/__init__.py +0 -175
- data/vendor/depot_tools/third_party/logilab/common/__pkginfo__.py +0 -57
- data/vendor/depot_tools/third_party/logilab/common/cache.py +0 -114
- data/vendor/depot_tools/third_party/logilab/common/changelog.py +0 -238
- data/vendor/depot_tools/third_party/logilab/common/clcommands.py +0 -334
- data/vendor/depot_tools/third_party/logilab/common/cli.py +0 -211
- data/vendor/depot_tools/third_party/logilab/common/compat.py +0 -78
- data/vendor/depot_tools/third_party/logilab/common/configuration.py +0 -1105
- data/vendor/depot_tools/third_party/logilab/common/contexts.py +0 -5
- data/vendor/depot_tools/third_party/logilab/common/corbautils.py +0 -117
- data/vendor/depot_tools/third_party/logilab/common/daemon.py +0 -101
- data/vendor/depot_tools/third_party/logilab/common/date.py +0 -335
- data/vendor/depot_tools/third_party/logilab/common/dbf.py +0 -231
- data/vendor/depot_tools/third_party/logilab/common/debugger.py +0 -214
- data/vendor/depot_tools/third_party/logilab/common/decorators.py +0 -281
- data/vendor/depot_tools/third_party/logilab/common/deprecation.py +0 -189
- data/vendor/depot_tools/third_party/logilab/common/fileutils.py +0 -404
- data/vendor/depot_tools/third_party/logilab/common/interface.py +0 -71
- data/vendor/depot_tools/third_party/logilab/common/logging_ext.py +0 -195
- data/vendor/depot_tools/third_party/logilab/common/modutils.py +0 -702
- data/vendor/depot_tools/third_party/logilab/common/optik_ext.py +0 -392
- data/vendor/depot_tools/third_party/logilab/common/optparser.py +0 -92
- data/vendor/depot_tools/third_party/logilab/common/proc.py +0 -277
- data/vendor/depot_tools/third_party/logilab/common/pyro_ext.py +0 -180
- data/vendor/depot_tools/third_party/logilab/common/pytest.py +0 -1199
- data/vendor/depot_tools/third_party/logilab/common/registry.py +0 -1119
- data/vendor/depot_tools/third_party/logilab/common/shellutils.py +0 -462
- data/vendor/depot_tools/third_party/logilab/common/sphinx_ext.py +0 -87
- data/vendor/depot_tools/third_party/logilab/common/sphinxutils.py +0 -122
- data/vendor/depot_tools/third_party/logilab/common/table.py +0 -929
- data/vendor/depot_tools/third_party/logilab/common/tasksqueue.py +0 -101
- data/vendor/depot_tools/third_party/logilab/common/testlib.py +0 -1392
- data/vendor/depot_tools/third_party/logilab/common/textutils.py +0 -537
- data/vendor/depot_tools/third_party/logilab/common/tree.py +0 -369
- data/vendor/depot_tools/third_party/logilab/common/umessage.py +0 -194
- data/vendor/depot_tools/third_party/logilab/common/ureports/__init__.py +0 -172
- data/vendor/depot_tools/third_party/logilab/common/ureports/docbook_writer.py +0 -140
- data/vendor/depot_tools/third_party/logilab/common/urllib2ext.py +0 -89
- data/vendor/depot_tools/third_party/logilab/common/visitor.py +0 -109
- data/vendor/depot_tools/third_party/logilab/common/xmlrpcutils.py +0 -131
- data/vendor/depot_tools/third_party/logilab/common/xmlutils.py +0 -61
@@ -2,6 +2,8 @@ DEPS = [
|
|
2
2
|
'depot_tools',
|
3
3
|
'gclient',
|
4
4
|
'gerrit',
|
5
|
+
'gitiles',
|
6
|
+
'recipe_engine/buildbucket',
|
5
7
|
'recipe_engine/context',
|
6
8
|
'recipe_engine/json',
|
7
9
|
'recipe_engine/path',
|
@@ -20,24 +22,8 @@ from recipe_engine.config import ConfigGroup, Single
|
|
20
22
|
|
21
23
|
PROPERTIES = {
|
22
24
|
# Gerrit patches will have all properties about them prefixed with patch_.
|
23
|
-
'patch_issue': Property(default=None), # TODO(tandrii): add kind=int.
|
24
|
-
'patch_set': Property(default=None), # TODO(tandrii): add kind=int.
|
25
|
-
'patch_gerrit_url': Property(default=None),
|
26
|
-
'patch_repository_url': Property(default=None),
|
27
|
-
'patch_ref': Property(default=None),
|
28
|
-
|
29
|
-
# TODO(tAndrii): remove legacy Gerrit fields.
|
30
|
-
# Legacy Gerrit fields.
|
31
|
-
'event.patchSet.ref': Property(default=None, param_name='gerrit_ref'),
|
32
|
-
|
33
|
-
# Rietveld-only (?) fields.
|
34
|
-
'repository': Property(default=None),
|
35
|
-
|
36
|
-
# Common fields for both systems.
|
37
25
|
'deps_revision_overrides': Property(default={}),
|
38
26
|
'fail_patch': Property(default=None, kind=str),
|
39
|
-
'parent_got_revision': Property(default=None),
|
40
|
-
'revision': Property(default=None),
|
41
27
|
|
42
28
|
'$depot_tools/bot_update': Property(
|
43
29
|
help='Properties specific to bot_update module.',
|
@@ -6,28 +6,24 @@
|
|
6
6
|
|
7
7
|
from recipe_engine import recipe_api
|
8
8
|
|
9
|
+
from PB.go.chromium.org.luci.buildbucket.proto import common as common_pb2
|
10
|
+
|
9
11
|
|
10
12
|
class BotUpdateApi(recipe_api.RecipeApi):
|
11
13
|
|
12
|
-
def __init__(self, properties,
|
13
|
-
|
14
|
-
patch_gerrit_url, revision, parent_got_revision,
|
15
|
-
deps_revision_overrides, fail_patch, *args, **kwargs):
|
16
|
-
self._apply_patch_on_gclient = properties.get(
|
17
|
-
'apply_patch_on_gclient', True)
|
18
|
-
self._issue = patch_issue
|
19
|
-
self._patchset = patch_set
|
20
|
-
self._repository = repository or patch_repository_url
|
21
|
-
self._gerrit_ref = gerrit_ref or patch_ref
|
22
|
-
self._gerrit = patch_gerrit_url
|
23
|
-
self._revision = revision
|
24
|
-
self._parent_got_revision = parent_got_revision
|
14
|
+
def __init__(self, properties, deps_revision_overrides, fail_patch, *args,
|
15
|
+
**kwargs):
|
25
16
|
self._deps_revision_overrides = deps_revision_overrides
|
26
17
|
self._fail_patch = fail_patch
|
27
18
|
|
28
19
|
self._last_returned_properties = {}
|
29
20
|
super(BotUpdateApi, self).__init__(*args, **kwargs)
|
30
21
|
|
22
|
+
def initialize(self):
|
23
|
+
assert len(self.m.buildbucket.build.input.gerrit_changes) <= 1, (
|
24
|
+
'bot_update does not support more than one '
|
25
|
+
'buildbucket.build.input.gerrit_changes')
|
26
|
+
|
31
27
|
def __call__(self, name, cmd, **kwargs):
|
32
28
|
"""Wrapper for easy calling of bot_update."""
|
33
29
|
assert isinstance(cmd, (list, tuple))
|
@@ -41,33 +37,37 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
41
37
|
def last_returned_properties(self):
|
42
38
|
return self._last_returned_properties
|
43
39
|
|
44
|
-
|
45
|
-
|
46
|
-
def apply_gerrit_ref(self, root, gerrit_no_reset=False,
|
47
|
-
gerrit_no_rebase_patch_ref=False,
|
48
|
-
gerrit_repo=None, gerrit_ref=None,
|
49
|
-
step_name='apply_gerrit', **kwargs):
|
50
|
-
apply_gerrit_path = self.resource('apply_gerrit.py')
|
51
|
-
kwargs.setdefault('infra_step', True)
|
52
|
-
cmd = [
|
53
|
-
'--gerrit_repo', gerrit_repo or self._repository,
|
54
|
-
'--gerrit_ref', gerrit_ref or self._gerrit_ref or '',
|
55
|
-
'--root', str(root),
|
56
|
-
]
|
57
|
-
if gerrit_no_reset:
|
58
|
-
cmd.append('--gerrit_no_reset')
|
59
|
-
if gerrit_no_rebase_patch_ref:
|
60
|
-
cmd.append('--gerrit_no_rebase_patch_ref')
|
40
|
+
def _get_commit_repo_path(self, commit, gclient_config):
|
41
|
+
"""Returns local path to the repo that the commit is associated with.
|
61
42
|
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
43
|
+
The commit must be a self.m.buildbucket.common_pb2.GitilesCommit.
|
44
|
+
If commit does not specify any repo, returns name of the first solution.
|
45
|
+
|
46
|
+
Raises an InfraFailure if the commit specifies a repo unexpected by gclient.
|
47
|
+
"""
|
48
|
+
assert gclient_config.solutions, 'gclient_config.solutions is empty'
|
49
|
+
|
50
|
+
# if repo is not specified, choose the first solution.
|
51
|
+
if not (commit.host and commit.project):
|
52
|
+
return gclient_config.solutions[0].name
|
53
|
+
assert commit.host and commit.project
|
54
|
+
|
55
|
+
repo_url = self.m.gitiles.unparse_repo_url(commit.host, commit.project)
|
56
|
+
repo_path = self.m.gclient.get_repo_path(
|
57
|
+
repo_url, gclient_config=gclient_config)
|
58
|
+
if not repo_path:
|
59
|
+
raise self.m.step.InfraFailure(
|
60
|
+
'invalid (host, project) pair in '
|
61
|
+
'buildbucket.build.input.gitiles_commit: '
|
62
|
+
'(%r, %r) does not match any of configured gclient solutions '
|
63
|
+
'and not present in gclient_config.repo_path_map' % (
|
64
|
+
commit.host, commit.project))
|
65
|
+
|
66
|
+
return repo_path
|
67
67
|
|
68
68
|
def ensure_checkout(self, gclient_config=None, suffix=None,
|
69
69
|
patch=True, update_presentation=True,
|
70
|
-
patch_root=None,
|
70
|
+
patch_root=None,
|
71
71
|
with_branch_heads=False, with_tags=False, refs=None,
|
72
72
|
patch_oauth2=None, oauth2_json=None,
|
73
73
|
use_site_config_creds=None, clobber=False,
|
@@ -75,6 +75,8 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
75
75
|
patchset=None, gerrit_no_reset=False,
|
76
76
|
gerrit_no_rebase_patch_ref=False,
|
77
77
|
disable_syntax_validation=False, manifest_name=None,
|
78
|
+
patch_refs=None, ignore_input_commit=False,
|
79
|
+
set_output_commit=False,
|
78
80
|
**kwargs):
|
79
81
|
"""
|
80
82
|
Args:
|
@@ -85,6 +87,15 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
85
87
|
such as bisect.
|
86
88
|
manifest_name: The name of the manifest to upload to LogDog. This must
|
87
89
|
be unique for the whole build.
|
90
|
+
ignore_input_commit: if True, ignore api.buildbucket.gitiles_commit.
|
91
|
+
Exists for historical reasons. Please do not use.
|
92
|
+
set_output_commit: if True, mark the checked out commit as the
|
93
|
+
primary output commit of this build, i.e. call
|
94
|
+
api.buildbucket.set_output_gitiles_commit.
|
95
|
+
In case of multiple repos, the repo is the one specified in
|
96
|
+
api.buildbucket.gitiles_commit or the first configured solution.
|
97
|
+
When sorting builds by commit position, this commit will be used.
|
98
|
+
Requires falsy ignore_input_commit.
|
88
99
|
"""
|
89
100
|
assert use_site_config_creds is None, "use_site_config_creds is deprecated"
|
90
101
|
assert rietveld is None, "rietveld is deprecated"
|
@@ -92,6 +103,7 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
92
103
|
assert patchset is None, "patchset is deprecated"
|
93
104
|
assert patch_oauth2 is None, "patch_oauth2 is deprecated"
|
94
105
|
assert oauth2_json is None, "oauth2_json is deprecated"
|
106
|
+
assert not (ignore_input_commit and set_output_commit)
|
95
107
|
|
96
108
|
refs = refs or []
|
97
109
|
# We can re-use the gclient spec from the gclient module, since all the
|
@@ -100,34 +112,15 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
100
112
|
assert cfg is not None, (
|
101
113
|
'missing gclient_config or forgot api.gclient.set_config(...) before?')
|
102
114
|
|
103
|
-
|
104
115
|
# Construct our bot_update command. This basically be inclusive of
|
105
116
|
# everything required for bot_update to know:
|
106
|
-
|
107
|
-
|
108
|
-
root = self.m.gclient.calculate_patch_root(
|
109
|
-
self.m.properties.get('patch_project'), cfg, self._repository)
|
110
|
-
|
111
|
-
if patch:
|
112
|
-
patchset = patchset or self._patchset
|
113
|
-
gerrit_repo = self._repository
|
114
|
-
gerrit_ref = self._gerrit_ref
|
115
|
-
else:
|
116
|
-
# The trybot recipe sometimes wants to de-apply the patch. In which case
|
117
|
-
# we pretend the issue/patchset never existed.
|
118
|
-
gerrit_repo = gerrit_ref = None
|
119
|
-
|
120
|
-
# The gerrit_ref and gerrit_repo must be together or not at all. If one is
|
121
|
-
# missing, clear both of them.
|
122
|
-
if not gerrit_ref or not gerrit_repo:
|
123
|
-
gerrit_repo = gerrit_ref = None
|
124
|
-
assert (gerrit_ref != None) == (gerrit_repo != None)
|
117
|
+
patch_root = patch_root or self.m.gclient.get_gerrit_patch_root(
|
118
|
+
gclient_config=cfg)
|
125
119
|
|
126
120
|
# Allow patch_project's revision if necessary.
|
127
121
|
# This is important for projects which are checked out as DEPS of the
|
128
122
|
# gclient solution.
|
129
|
-
self.m.gclient.
|
130
|
-
self.m.properties.get('patch_project'), cfg)
|
123
|
+
self.m.gclient.set_patch_repo_revision(cfg)
|
131
124
|
|
132
125
|
reverse_rev_map = self.m.gclient.got_revision_reverse_mapping(cfg)
|
133
126
|
|
@@ -135,38 +128,61 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
135
128
|
# What do we want to check out (spec/root/rev/reverse_rev_map).
|
136
129
|
['--spec-path', self.m.raw_io.input(
|
137
130
|
self.m.gclient.config_to_pythonish(cfg))],
|
138
|
-
['--patch_root',
|
131
|
+
['--patch_root', patch_root],
|
139
132
|
['--revision_mapping_file', self.m.json.input(reverse_rev_map)],
|
140
133
|
['--git-cache-dir', cfg.cache_dir],
|
141
134
|
['--cleanup-dir', self.m.path['cleanup'].join('bot_update')],
|
142
135
|
|
143
|
-
# How to find the patch, if any
|
144
|
-
['--gerrit_repo', gerrit_repo],
|
145
|
-
['--gerrit_ref', gerrit_ref],
|
146
|
-
|
147
136
|
# Hookups to JSON output back into recipes.
|
148
137
|
['--output_json', self.m.json.output()],
|
149
138
|
]
|
150
139
|
|
140
|
+
# How to find the patch, if any
|
141
|
+
if patch:
|
142
|
+
repo_url = self.m.tryserver.gerrit_change_repo_url
|
143
|
+
fetch_ref = self.m.tryserver.gerrit_change_fetch_ref
|
144
|
+
if repo_url and fetch_ref:
|
145
|
+
flags.append(['--patch_ref', '%s@%s' % (repo_url, fetch_ref)])
|
146
|
+
if patch_refs:
|
147
|
+
flags.extend(
|
148
|
+
['--patch_ref', patch_ref]
|
149
|
+
for patch_ref in patch_refs)
|
150
|
+
|
151
151
|
# Compute requested revisions.
|
152
152
|
revisions = {}
|
153
153
|
for solution in cfg.solutions:
|
154
154
|
if solution.revision:
|
155
155
|
revisions[solution.name] = solution.revision
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
156
|
+
|
157
|
+
# HACK: ensure_checkout API must be redesigned so that we don't pass such
|
158
|
+
# parameters. Existing semantics is too opiniated.
|
159
|
+
main_repo_path = None
|
160
|
+
input_commit = self.m.buildbucket.gitiles_commit
|
161
|
+
input_commit_rev = input_commit.id or input_commit.ref
|
162
|
+
if not ignore_input_commit:
|
163
|
+
main_repo_path = self._get_commit_repo_path(input_commit, cfg)
|
164
|
+
# Note: this is not entirely correct. build.input.gitiles_commit
|
165
|
+
# definition says "The Gitiles commit to run against.".
|
166
|
+
# However, here we ignore it if the config specified a revision.
|
167
|
+
# This is necessary because existing builders rely on this behavior,
|
168
|
+
# e.g. they want to force refs/heads/master at the config level.
|
169
|
+
if input_commit_rev:
|
170
|
+
revisions[main_repo_path] = (
|
171
|
+
revisions.get(main_repo_path) or input_commit_rev)
|
172
|
+
|
173
|
+
# Guarantee that first solution has a revision.
|
174
|
+
# TODO(machenbach): We should explicitly pass HEAD for ALL solutions
|
175
|
+
# that don't specify anything else.
|
176
|
+
first_sol = cfg.solutions[0].name
|
177
|
+
revisions[first_sol] = revisions.get(first_sol) or 'HEAD'
|
178
|
+
|
179
|
+
if cfg.revisions:
|
164
180
|
# Only update with non-empty values. Some recipe might otherwise
|
165
181
|
# overwrite the HEAD default with an empty string.
|
166
182
|
revisions.update(
|
167
|
-
(k, v) for k, v in
|
183
|
+
(k, v) for k, v in cfg.revisions.iteritems() if v)
|
168
184
|
if cfg.solutions and root_solution_revision:
|
169
|
-
revisions[
|
185
|
+
revisions[first_sol] = root_solution_revision
|
170
186
|
# Allow for overrides required to bisect into rolls.
|
171
187
|
revisions.update(self._deps_revision_overrides)
|
172
188
|
|
@@ -184,7 +200,12 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
184
200
|
fixed_revision = self._destination_branch(cfg, name)
|
185
201
|
# If we're syncing to a ref, we want to make sure it exists before
|
186
202
|
# trying to check it out.
|
187
|
-
if fixed_revision.startswith('refs/')
|
203
|
+
if (fixed_revision.startswith('refs/') and
|
204
|
+
# TODO(crbug.com/874501): fetching additional refs is currently
|
205
|
+
# only supported for the root solution. We should investigate
|
206
|
+
# supporting it for other dependencies.
|
207
|
+
cfg.solutions and
|
208
|
+
cfg.solutions[0].name == name):
|
188
209
|
# Handle the "ref:revision" syntax, e.g.
|
189
210
|
# refs/branch-heads/4.2:deadbeef
|
190
211
|
refs.append(fixed_revision.split(':')[0])
|
@@ -208,8 +229,6 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
208
229
|
|
209
230
|
if clobber:
|
210
231
|
cmd.append('--clobber')
|
211
|
-
if no_shallow is False:
|
212
|
-
cmd.append('--maybe_shallow')
|
213
232
|
if with_branch_heads or cfg.with_branch_heads:
|
214
233
|
cmd.append('--with_branch_heads')
|
215
234
|
if with_tags or cfg.with_tags:
|
@@ -220,13 +239,11 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
220
239
|
cmd.append('--gerrit_no_rebase_patch_ref')
|
221
240
|
if disable_syntax_validation or cfg.disable_syntax_validation:
|
222
241
|
cmd.append('--disable-syntax-validation')
|
223
|
-
if not self._apply_patch_on_gclient:
|
224
|
-
cmd.append('--no-apply-patch-on-gclient')
|
225
242
|
|
226
243
|
# Inject Json output for testing.
|
227
244
|
first_sln = cfg.solutions[0].name
|
228
245
|
step_test_data = lambda: self.test_api.output_json(
|
229
|
-
|
246
|
+
patch_root, first_sln, reverse_rev_map, self._fail_patch,
|
230
247
|
fixed_revisions=fixed_revisions)
|
231
248
|
|
232
249
|
name = 'bot_update'
|
@@ -250,27 +267,54 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
250
267
|
finally:
|
251
268
|
if step_result and step_result.json.output:
|
252
269
|
result = step_result.json.output
|
253
|
-
self._last_returned_properties =
|
254
|
-
'properties', {})
|
270
|
+
self._last_returned_properties = result.get('properties', {})
|
255
271
|
|
256
272
|
if update_presentation:
|
257
273
|
# Set properties such as got_revision.
|
258
274
|
for prop_name, prop_value in (
|
259
275
|
self.last_returned_properties.iteritems()):
|
260
276
|
step_result.presentation.properties[prop_name] = prop_value
|
277
|
+
|
261
278
|
# Add helpful step description in the step UI.
|
262
279
|
if 'step_text' in result:
|
263
280
|
step_text = result['step_text']
|
264
281
|
step_result.presentation.step_text = step_text
|
265
282
|
|
266
283
|
# Export the step results as a Source Manifest to LogDog.
|
284
|
+
source_manifest = result.get('source_manifest', {})
|
267
285
|
if manifest_name:
|
268
286
|
if not patch:
|
269
287
|
# The param "patched" is purely cosmetic to mean "if false, this
|
270
288
|
# bot_update run exists purely to unpatch an existing patch".
|
271
289
|
manifest_name += '_unpatched'
|
272
290
|
self.m.source_manifest.set_json_manifest(
|
273
|
-
manifest_name,
|
291
|
+
manifest_name, source_manifest)
|
292
|
+
|
293
|
+
# Set output commit of the build.
|
294
|
+
git_checkout = (
|
295
|
+
source_manifest
|
296
|
+
.get('directories', {})
|
297
|
+
.get(main_repo_path, {})
|
298
|
+
.get('git_checkout', {}))
|
299
|
+
if set_output_commit and git_checkout:
|
300
|
+
output_commit = common_pb2.GitilesCommit(
|
301
|
+
ref=revisions.get(main_repo_path) or '',
|
302
|
+
id=git_checkout['revision'],
|
303
|
+
)
|
304
|
+
if not output_commit.ref.startswith('refs/'):
|
305
|
+
# Require that what was checked out is what was requested on
|
306
|
+
# input commit.
|
307
|
+
# If this assertion fails, this setup is unusual/unsupported.
|
308
|
+
# The caller should not pass set_output_commit=True and should call
|
309
|
+
# api.buildbucket.set_output_gitiles_commit themselves.
|
310
|
+
assert (
|
311
|
+
input_commit.ref and
|
312
|
+
# Revision was not overridden.
|
313
|
+
revisions[main_repo_path] == input_commit_rev)
|
314
|
+
output_commit.ref = input_commit.ref
|
315
|
+
output_commit.host, output_commit.project = (
|
316
|
+
self.m.gitiles.parse_repo_url(git_checkout['repo_url']))
|
317
|
+
self.m.buildbucket.set_output_gitiles_commit(output_commit)
|
274
318
|
|
275
319
|
# Set the "checkout" path for the main solution.
|
276
320
|
# This is used by the Chromium module to figure out where to look for
|
@@ -299,7 +343,9 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
299
343
|
|
300
344
|
# bot_update actually just sets root to be the folder name of the
|
301
345
|
# first solution.
|
302
|
-
if result
|
346
|
+
if (result.get('did_run')
|
347
|
+
and 'checkout' not in self.m.path
|
348
|
+
and 'root' in result):
|
303
349
|
co_root = result['root']
|
304
350
|
cwd = self.m.context.cwd or self.m.path['start_dir']
|
305
351
|
self.m.path['checkout'] = cwd.join(*co_root.split(self.m.path.sep))
|
@@ -310,7 +356,7 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
310
356
|
"""Returns the destination branch of a CL for the matching project
|
311
357
|
if available or HEAD otherwise.
|
312
358
|
|
313
|
-
|
359
|
+
If there's no Gerrit CL associated with the run, returns 'HEAD'.
|
314
360
|
Otherwise this queries Gerrit for the correct destination branch, which
|
315
361
|
might differ from master.
|
316
362
|
|
@@ -323,26 +369,22 @@ class BotUpdateApi(recipe_api.RecipeApi):
|
|
323
369
|
A destination branch as understood by bot_update.py if available
|
324
370
|
and if different from master, returns 'HEAD' otherwise.
|
325
371
|
"""
|
326
|
-
#
|
327
|
-
|
328
|
-
|
372
|
+
# Ignore project paths other than the one belonging to the current CL.
|
373
|
+
patch_path = self.m.gclient.get_gerrit_patch_root(gclient_config=cfg)
|
374
|
+
if not patch_path or path != patch_path:
|
329
375
|
return 'HEAD'
|
330
376
|
|
331
|
-
|
332
|
-
if
|
333
|
-
self.m.properties.get('patch_project'),
|
334
|
-
(cfg.solutions[0].name, None))[0]:
|
377
|
+
target_ref = self.m.tryserver.gerrit_change_target_ref
|
378
|
+
if target_ref == 'refs/heads/master':
|
335
379
|
return 'HEAD'
|
336
380
|
|
337
|
-
#
|
338
|
-
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
)
|
381
|
+
# TODO: Remove. Return ref, not branch.
|
382
|
+
ret = target_ref
|
383
|
+
prefix = 'refs/heads/'
|
384
|
+
if ret.startswith(prefix):
|
385
|
+
ret = ret[len(prefix):]
|
343
386
|
|
344
|
-
|
345
|
-
return destination_branch if destination_branch != 'master' else 'HEAD'
|
387
|
+
return ret
|
346
388
|
|
347
389
|
def _resolve_fixed_revisions(self, bot_update_json):
|
348
390
|
"""Set all fixed revisions from the first sync to their respective
|
@@ -6,8 +6,6 @@
|
|
6
6
|
"RECIPE_MODULE[depot_tools::bot_update]/resources/bot_update.py",
|
7
7
|
"--spec-path",
|
8
8
|
"cache_dir = '[GIT_CACHE]'\nsolutions = [{'deps_file': '.DEPS.git', 'managed': True, 'name': 'src', 'url': 'https://chromium.googlesource.com/chromium/src.git'}]",
|
9
|
-
"--patch_root",
|
10
|
-
"src",
|
11
9
|
"--revision_mapping_file",
|
12
10
|
"{\"got_angle_revision\": \"src/third_party/angle\", \"got_cr_revision\": \"src\", \"got_revision\": \"src\", \"got_v8_revision\": \"src/v8\"}",
|
13
11
|
"--git-cache-dir",
|
@@ -17,12 +15,12 @@
|
|
17
15
|
"--output_json",
|
18
16
|
"/path/to/tmp/json",
|
19
17
|
"--revision",
|
20
|
-
"src@
|
18
|
+
"src@2d72510e447ab60a9728aeea2362d8be2cbd7789",
|
21
19
|
"--disable-syntax-validation"
|
22
20
|
],
|
23
21
|
"env_prefixes": {
|
24
22
|
"PATH": [
|
25
|
-
"
|
23
|
+
"RECIPE_REPO[depot_tools]"
|
26
24
|
]
|
27
25
|
},
|
28
26
|
"infra_step": true,
|
@@ -32,7 +30,7 @@
|
|
32
30
|
"@@@STEP_LOG_LINE@json.output@{@@@",
|
33
31
|
"@@@STEP_LOG_LINE@json.output@ \"did_run\": true, @@@",
|
34
32
|
"@@@STEP_LOG_LINE@json.output@ \"fixed_revisions\": {@@@",
|
35
|
-
"@@@STEP_LOG_LINE@json.output@ \"src\": \"
|
33
|
+
"@@@STEP_LOG_LINE@json.output@ \"src\": \"2d72510e447ab60a9728aeea2362d8be2cbd7789\"@@@",
|
36
34
|
"@@@STEP_LOG_LINE@json.output@ }, @@@",
|
37
35
|
"@@@STEP_LOG_LINE@json.output@ \"manifest\": {@@@",
|
38
36
|
"@@@STEP_LOG_LINE@json.output@ \"src\": {@@@",
|
@@ -98,8 +96,7 @@
|
|
98
96
|
]
|
99
97
|
},
|
100
98
|
{
|
101
|
-
"
|
102
|
-
"
|
103
|
-
"status_code": 0
|
99
|
+
"jsonResult": null,
|
100
|
+
"name": "$result"
|
104
101
|
}
|
105
102
|
]
|