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
@@ -1,13 +1,13 @@
|
|
1
1
|
'\" t
|
2
2
|
.\" Title: git-map-branches
|
3
3
|
.\" Author: [FIXME: author] [see http://docbook.sf.net/el/author]
|
4
|
-
.\" Generator: DocBook XSL Stylesheets v1.
|
5
|
-
.\" Date: 12/
|
4
|
+
.\" Generator: DocBook XSL Stylesheets v1.79.1 <http://docbook.sf.net/>
|
5
|
+
.\" Date: 12/04/2018
|
6
6
|
.\" Manual: Chromium depot_tools Manual
|
7
|
-
.\" Source: depot_tools
|
7
|
+
.\" Source: depot_tools 3edf049e
|
8
8
|
.\" Language: English
|
9
9
|
.\"
|
10
|
-
.TH "GIT\-MAP\-BRANCHES" "1" "12/
|
10
|
+
.TH "GIT\-MAP\-BRANCHES" "1" "12/04/2018" "depot_tools 3edf049e" "Chromium depot_tools Manual"
|
11
11
|
.\" -----------------------------------------------------------------
|
12
12
|
.\" * Define some portability stuff
|
13
13
|
.\" -----------------------------------------------------------------
|
@@ -139,6 +139,17 @@ Branches which have this as their parent are usually misconfigured, and should b
|
|
139
139
|
If multiple branches are on the same commit, they will all be cyan\&.
|
140
140
|
.sp .5v
|
141
141
|
.RE
|
142
|
+
.SH "OPTIONS"
|
143
|
+
.PP
|
144
|
+
\-\-no\-color
|
145
|
+
.RS 4
|
146
|
+
Turn off colors\&.
|
147
|
+
.RE
|
148
|
+
.PP
|
149
|
+
\-v
|
150
|
+
.RS 4
|
151
|
+
Be more verbose\&. Pass once to show tracking info, twice for hash and review URL, thrice for review status\&.
|
152
|
+
.RE
|
142
153
|
.SH "EXAMPLE"
|
143
154
|
.sp
|
144
155
|
Given the hypothetical demo repo in \fBgit-map\fR(1)\*(Aqs EXAMPLE section, and assuming that the frozen_changes branch was currently checked out, running \fIgit map\-branches\fR would result in an output like:
|
@@ -156,7 +167,15 @@ origin/master
|
|
156
167
|
cool_feature
|
157
168
|
subfeature
|
158
169
|
fixit
|
159
|
-
\fB frozen_branch
|
170
|
+
\fB frozen_branch *
|
171
|
+
$ git map\-branches \-v\fR
|
172
|
+
{NO_UPSTREAM}
|
173
|
+
no_upstream
|
174
|
+
origin/master
|
175
|
+
cool_feature [ ahead 4 ]
|
176
|
+
subfeature [ ahead 2 | behind 1 ]
|
177
|
+
fixit [ ahead 6 ]
|
178
|
+
\fB frozen_branch * [ ahead 3 ]\fR
|
160
179
|
.fi
|
161
180
|
.if n \{\
|
162
181
|
.RE
|
@@ -1,13 +1,13 @@
|
|
1
1
|
'\" t
|
2
2
|
.\" Title: git-new-branch
|
3
3
|
.\" Author: [FIXME: author] [see http://docbook.sf.net/el/author]
|
4
|
-
.\" Generator: DocBook XSL Stylesheets v1.
|
5
|
-
.\" Date: 12/
|
4
|
+
.\" Generator: DocBook XSL Stylesheets v1.79.1 <http://docbook.sf.net/>
|
5
|
+
.\" Date: 12/05/2018
|
6
6
|
.\" Manual: Chromium depot_tools Manual
|
7
|
-
.\" Source: depot_tools
|
7
|
+
.\" Source: depot_tools 0379dbb3
|
8
8
|
.\" Language: English
|
9
9
|
.\"
|
10
|
-
.TH "GIT\-NEW\-BRANCH" "1" "12/
|
10
|
+
.TH "GIT\-NEW\-BRANCH" "1" "12/05/2018" "depot_tools 0379dbb3" "Chromium depot_tools Manual"
|
11
11
|
.\" -----------------------------------------------------------------
|
12
12
|
.\" * Define some portability stuff
|
13
13
|
.\" -----------------------------------------------------------------
|
@@ -50,7 +50,7 @@ Conceptually, each branch in your repo represents one \fIChange List (CL)\fR\&.
|
|
50
50
|
Set the tracking (upstream) branch to the currently\-checked\-out branch\&.
|
51
51
|
.RE
|
52
52
|
.PP
|
53
|
-
\-\-
|
53
|
+
\-\-upstream <REF>
|
54
54
|
.RS 4
|
55
55
|
Set the tracking (upstream) branch to <REF>\&. <REF> may be a local branch, remote branch, or a tag\&.
|
56
56
|
.RE
|
@@ -77,43 +77,51 @@ This configures the default \fIupstream\fR for all new branches\&. If it is unse
|
|
77
77
|
.RS 4
|
78
78
|
.\}
|
79
79
|
.nf
|
80
|
-
\fB$ git map\-branches\fR
|
80
|
+
\fB$ git map\-branches \-v\fR
|
81
81
|
origin/master
|
82
|
-
cool_feature
|
83
|
-
subfeature
|
84
|
-
fixit
|
85
|
-
\fB frozen_branch *
|
82
|
+
cool_feature [ ahead 4 ]
|
83
|
+
subfeature [ ahead 2 | behind 1 ]
|
84
|
+
fixit [ ahead 2 ]
|
85
|
+
\fB frozen_branch * [ ahead 3 ]
|
86
86
|
$ git new\-branch independent_cl\fR
|
87
|
-
\fB$ git map\-branches\fR
|
87
|
+
\fB$ git map\-branches \-v\fR
|
88
88
|
\fBorigin/master
|
89
|
-
\fR cool_feature
|
90
|
-
subfeature
|
91
|
-
fixit
|
92
|
-
frozen_branch
|
89
|
+
\fR cool_feature [ ahead 4 ]
|
90
|
+
subfeature [ ahead 2 | behind 1 ]
|
91
|
+
fixit [ ahead 2 ]
|
92
|
+
frozen_branch [ ahead 3 ]
|
93
93
|
\fB independent_cl *
|
94
|
+
$ vi foo && git add \-A && git commit \-m foo\fR
|
95
|
+
\fB$ git map\-branches \-v\fR
|
96
|
+
origin/master
|
97
|
+
cool_feature [ ahead 4 ]
|
98
|
+
subfeature [ ahead 2 | behind 1 ]
|
99
|
+
fixit [ ahead 2 ]
|
100
|
+
frozen_branch [ ahead 3 ]
|
101
|
+
\fB independent_cl * [ ahead 1 ]
|
94
102
|
$ git new\-branch \-\-upstream subfeature nested_cl\fR
|
95
|
-
\fB$ git map\-branches\fR
|
103
|
+
\fB$ git map\-branches \-v\fR
|
96
104
|
origin/master
|
97
|
-
cool_feature
|
98
|
-
\fB subfeature \fR\fB\fB(1)\fR\fR\fB
|
105
|
+
cool_feature [ ahead 4 ]
|
106
|
+
\fB subfeature [ ahead 2 | behind 1 ] \fR\fB\fB(1)\fR\fR\fB
|
99
107
|
nested_cl *
|
100
|
-
\fR fixit
|
101
|
-
frozen_branch
|
102
|
-
independent_cl
|
108
|
+
\fR fixit [ ahead 2 ]
|
109
|
+
frozen_branch [ ahead 3 ]
|
110
|
+
independent_cl [ ahead 1 ]
|
103
111
|
\fB$ git checkout cool_feature\fR
|
104
112
|
Switched to branch \*(Aqcool_feature\*(Aq
|
105
113
|
Your branch is ahead of \*(Aqorigin/master\*(Aq by 4 commits\&.
|
106
114
|
(use "git push" to publish your local commits)
|
107
115
|
\fB$ git new\-branch \-\-upstream_current cl_depends_on_cool_feature\fR
|
108
|
-
\fB$ git map\-branches\fR
|
116
|
+
\fB$ git map\-branches \-v\fR
|
109
117
|
origin/master
|
110
|
-
\fB cool_feature
|
118
|
+
\fB cool_feature [ ahead 4 ]
|
111
119
|
cl_depends_on_cool_feature *
|
112
|
-
\fR subfeature
|
120
|
+
\fR subfeature [ ahead 2 | behind 1 ]
|
113
121
|
nested_cl
|
114
|
-
fixit
|
115
|
-
frozen_branch
|
116
|
-
independent_cl
|
122
|
+
fixit [ ahead 2 ]
|
123
|
+
frozen_branch [ ahead 3 ]
|
124
|
+
independent_cl [ ahead 1 ]
|
117
125
|
.fi
|
118
126
|
.if n \{\
|
119
127
|
.RE
|
@@ -29,6 +29,16 @@ Git map-branches displays all local branches such that:
|
|
29
29
|
|
30
30
|
NOTE: If multiple branches are on the same commit, they will all be cyan.
|
31
31
|
|
32
|
+
OPTIONS
|
33
|
+
-------
|
34
|
+
|
35
|
+
--no-color::
|
36
|
+
Turn off colors.
|
37
|
+
|
38
|
+
-v::
|
39
|
+
Be more verbose. Pass once to show tracking info, twice for hash and review
|
40
|
+
URL, thrice for review status.
|
41
|
+
|
32
42
|
EXAMPLE
|
33
43
|
-------
|
34
44
|
|
@@ -1,12 +1,17 @@
|
|
1
1
|
#!/usr/bin/env bash
|
2
2
|
. demo_repo.sh
|
3
3
|
|
4
|
-
run git map-branches
|
4
|
+
run git map-branches -v
|
5
5
|
run git new-branch independent_cl
|
6
|
-
run git map-branches
|
6
|
+
run git map-branches -v
|
7
|
+
praw vi foo \&\& git add -A \&\& git commit -m 'foo'
|
8
|
+
silent echo 'foo' >foo
|
9
|
+
silent git add -A
|
10
|
+
silent git commit -m 'foo'
|
11
|
+
run git map-branches -v
|
7
12
|
run git new-branch --upstream subfeature nested_cl
|
8
13
|
callout 3
|
9
|
-
run git map-branches
|
14
|
+
run git map-branches -v
|
10
15
|
run git checkout cool_feature 2>&1
|
11
16
|
run git new-branch --upstream_current cl_depends_on_cool_feature
|
12
|
-
run git map-branches
|
17
|
+
run git map-branches -v
|
@@ -34,7 +34,7 @@ OPTIONS
|
|
34
34
|
--upstream_current::
|
35
35
|
Set the tracking (upstream) branch to the currently-checked-out branch.
|
36
36
|
|
37
|
-
--
|
37
|
+
--upstream <REF>::
|
38
38
|
Set the tracking (upstream) branch to <REF>. <REF> may be a local branch,
|
39
39
|
remote branch, or a tag.
|
40
40
|
|
@@ -0,0 +1,98 @@
|
|
1
|
+
# Why am I seeing this message?
|
2
|
+
|
3
|
+
We're starting to collect metrics about how developers use gclient and other
|
4
|
+
tools in depot\_tools to better understand the performance and failure modes of
|
5
|
+
the tools, as well of the pain points and workflows of depot\_tools users.
|
6
|
+
|
7
|
+
We will collect metrics only if you're a Googler on the corp network: If you can
|
8
|
+
access https://cit-cli-metrics.appspot.com/should-upload, then we will collect
|
9
|
+
metrics from you.
|
10
|
+
|
11
|
+
The first ten executions of depot\_tools commands will print large warnings
|
12
|
+
counting down to zero. When the counter hits zero, metrics collection will
|
13
|
+
automatically begin, and depot\_tools will display large warning messages
|
14
|
+
informing you of it. These messages will continue until you explicitly opt in or
|
15
|
+
opt out.
|
16
|
+
|
17
|
+
You can run `gclient metrics --opt-in` or `gclient metrics --opt-out` to do so.
|
18
|
+
And you can opt-in or out at any time.
|
19
|
+
|
20
|
+
Please consider opting in. It will allow us to know what features are the most
|
21
|
+
important, what features can we deprecate, and what features should we develop
|
22
|
+
to better cover your use case.
|
23
|
+
|
24
|
+
## What metrics are you collecting?
|
25
|
+
|
26
|
+
First, some words about what data we are **NOT** collecting:
|
27
|
+
|
28
|
+
- We won't record any information that identifies you personally.
|
29
|
+
- We won't record the command line flag values.
|
30
|
+
- We won't record information about the current directory or environment flags.
|
31
|
+
- We won't record arbitrary strings. We only collect a string if it is in the
|
32
|
+
list available at
|
33
|
+
https://chromium.googlesource.com/infra/infra/+/master/go/src/infra/appengine/depot_tools_metrics/metrics/metrics_schema.json#45
|
34
|
+
|
35
|
+
The metrics we're collecting are:
|
36
|
+
|
37
|
+
- A timestamp, with a week resolution.
|
38
|
+
- The age of your depot\_tools checkout, with a week resolution.
|
39
|
+
- Your version of Python (in the format major.minor.micro).
|
40
|
+
- Your version of Git (in the format major.minor.micro).
|
41
|
+
- The OS of your machine (i.e. win, linux or mac).
|
42
|
+
- The arch of your machine (e.g. x64, arm, etc).
|
43
|
+
- The command that you ran (e.g. `gclient sync`).
|
44
|
+
- The flag names (but not their values) that you passed to the command
|
45
|
+
(e.g. `--force`, `--revision`).
|
46
|
+
- The execution time.
|
47
|
+
- The exit code.
|
48
|
+
- The project you're working on. We only record data about projects you can
|
49
|
+
fetch using depot\_tools' fetch command (e.g. Chromium, WebRTC, V8, etc)
|
50
|
+
- The age of your project checkout, with a week resolution.
|
51
|
+
- What features are you using in your DEPS and .gclient files. For example:
|
52
|
+
- Are you setting `use_relative_paths=True`?
|
53
|
+
- Are you using `recursedeps`?
|
54
|
+
- Information about the http requests that depot_tools makes:
|
55
|
+
- What host are we making the request to?
|
56
|
+
Only collected for well known hosts like chromium-review.googlesource.com.
|
57
|
+
- What path did we access on the server?
|
58
|
+
We map the path to an enum to make sure we're not collecting personally
|
59
|
+
identifiable information.
|
60
|
+
i.e. we report 'changes/' instead of 'changes/12345'
|
61
|
+
- What arguments were used on the request?
|
62
|
+
We collect only known argument names, but not their values.
|
63
|
+
- What known headers were present or absent?
|
64
|
+
- How long did the execution take?
|
65
|
+
- What was the response code?
|
66
|
+
- What HTTP method was used? (i.e. GET, PUT, POST, etc.)
|
67
|
+
- Information about the commands that depot_tools runs:
|
68
|
+
- What command was executed? (i.e. git or cipd)
|
69
|
+
- How long did the command execute for?
|
70
|
+
- What argument names (but not values) were passed to the program.
|
71
|
+
(e.g. --checkout but not the branch name).
|
72
|
+
- What was the exit code?
|
73
|
+
|
74
|
+
The list of all known strings we collect can be found at
|
75
|
+
https://chromium.googlesource.com/infra/infra/+/master/go/src/infra/appengine/depot_tools_metrics/metrics/metrics_schema.json#45
|
76
|
+
|
77
|
+
## Why am I seeing this message *again*?
|
78
|
+
|
79
|
+
We might want to collect additional metrics, and if so we will ask you for
|
80
|
+
permission again.
|
81
|
+
|
82
|
+
Opting in or out explicitly will stop the messages from being displayed.
|
83
|
+
|
84
|
+
# How can I check if metrics are being collected?
|
85
|
+
|
86
|
+
You can run `gclient metrics` and it will report if you have opted in, out, or
|
87
|
+
not chosen for metrics collection.
|
88
|
+
|
89
|
+
If you have not yet explicitly opted in or out you will see a message after
|
90
|
+
each time we collect metrics.
|
91
|
+
|
92
|
+
# How can I stop seeing this message?
|
93
|
+
|
94
|
+
You will stop seeing it once you have explicitly opted in or out of depot\_tools
|
95
|
+
metrics collection.
|
96
|
+
|
97
|
+
You can run `gclient metrics --opt-in` or `gclient metrics --opt-out` to do so.
|
98
|
+
And you can opt-in or out at any time.
|
@@ -0,0 +1,296 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# Copyright (c) 2018 The Chromium Authors. All rights reserved.
|
3
|
+
# Use of this source code is governed by a BSD-style license that can be
|
4
|
+
# found in the LICENSE file.
|
5
|
+
|
6
|
+
from __future__ import print_function
|
7
|
+
|
8
|
+
import contextlib
|
9
|
+
import functools
|
10
|
+
import json
|
11
|
+
import os
|
12
|
+
import subprocess
|
13
|
+
import sys
|
14
|
+
import tempfile
|
15
|
+
import threading
|
16
|
+
import time
|
17
|
+
import traceback
|
18
|
+
|
19
|
+
try:
|
20
|
+
import urllib2 as urllib
|
21
|
+
except ImportError: # For Py3 compatibility
|
22
|
+
import urllib.request as urllib
|
23
|
+
|
24
|
+
import detect_host_arch
|
25
|
+
import gclient_utils
|
26
|
+
import metrics_utils
|
27
|
+
|
28
|
+
|
29
|
+
DEPOT_TOOLS = os.path.dirname(os.path.abspath(__file__))
|
30
|
+
CONFIG_FILE = os.path.join(DEPOT_TOOLS, 'metrics.cfg')
|
31
|
+
UPLOAD_SCRIPT = os.path.join(DEPOT_TOOLS, 'upload_metrics.py')
|
32
|
+
|
33
|
+
DISABLE_METRICS_COLLECTION = os.environ.get('DEPOT_TOOLS_METRICS') == '0'
|
34
|
+
DEFAULT_COUNTDOWN = 10
|
35
|
+
|
36
|
+
INVALID_CONFIG_WARNING = (
|
37
|
+
'WARNING: Your metrics.cfg file was invalid or nonexistent. A new one will '
|
38
|
+
'be created.'
|
39
|
+
)
|
40
|
+
PERMISSION_DENIED_WARNING = (
|
41
|
+
'Could not write the metrics collection config:\n\t%s\n'
|
42
|
+
'Metrics collection will be disabled.'
|
43
|
+
)
|
44
|
+
|
45
|
+
|
46
|
+
class _Config(object):
|
47
|
+
def __init__(self):
|
48
|
+
self._initialized = False
|
49
|
+
self._config = {}
|
50
|
+
|
51
|
+
def _ensure_initialized(self):
|
52
|
+
if self._initialized:
|
53
|
+
return
|
54
|
+
|
55
|
+
try:
|
56
|
+
config = json.loads(gclient_utils.FileRead(CONFIG_FILE))
|
57
|
+
except (IOError, ValueError):
|
58
|
+
config = {}
|
59
|
+
|
60
|
+
self._config = config.copy()
|
61
|
+
|
62
|
+
if 'is-googler' not in self._config:
|
63
|
+
# /should-upload is only accessible from Google IPs, so we only need to
|
64
|
+
# check if we can reach the page. An external developer would get access
|
65
|
+
# denied.
|
66
|
+
try:
|
67
|
+
req = urllib.urlopen(metrics_utils.APP_URL + '/should-upload')
|
68
|
+
self._config['is-googler'] = req.getcode() == 200
|
69
|
+
except (urllib.URLError, urllib.HTTPError):
|
70
|
+
self._config['is-googler'] = False
|
71
|
+
|
72
|
+
# Make sure the config variables we need are present, and initialize them to
|
73
|
+
# safe values otherwise.
|
74
|
+
self._config.setdefault('countdown', DEFAULT_COUNTDOWN)
|
75
|
+
self._config.setdefault('opt-in', None)
|
76
|
+
self._config.setdefault('version', metrics_utils.CURRENT_VERSION)
|
77
|
+
|
78
|
+
if config != self._config:
|
79
|
+
print(INVALID_CONFIG_WARNING, file=sys.stderr)
|
80
|
+
self._write_config()
|
81
|
+
|
82
|
+
self._initialized = True
|
83
|
+
|
84
|
+
def _write_config(self):
|
85
|
+
try:
|
86
|
+
gclient_utils.FileWrite(CONFIG_FILE, json.dumps(self._config))
|
87
|
+
except IOError as e:
|
88
|
+
print(PERMISSION_DENIED_WARNING % e, file=sys.stderr)
|
89
|
+
self._config['opt-in'] = False
|
90
|
+
|
91
|
+
@property
|
92
|
+
def version(self):
|
93
|
+
self._ensure_initialized()
|
94
|
+
return self._config['version']
|
95
|
+
|
96
|
+
@property
|
97
|
+
def is_googler(self):
|
98
|
+
self._ensure_initialized()
|
99
|
+
return self._config['is-googler']
|
100
|
+
|
101
|
+
@property
|
102
|
+
def opted_in(self):
|
103
|
+
self._ensure_initialized()
|
104
|
+
return self._config['opt-in']
|
105
|
+
|
106
|
+
@opted_in.setter
|
107
|
+
def opted_in(self, value):
|
108
|
+
self._ensure_initialized()
|
109
|
+
self._config['opt-in'] = value
|
110
|
+
self._config['version'] = metrics_utils.CURRENT_VERSION
|
111
|
+
self._write_config()
|
112
|
+
|
113
|
+
@property
|
114
|
+
def countdown(self):
|
115
|
+
self._ensure_initialized()
|
116
|
+
return self._config['countdown']
|
117
|
+
|
118
|
+
@property
|
119
|
+
def should_collect_metrics(self):
|
120
|
+
# Don't collect the metrics unless the user is a googler, the user has opted
|
121
|
+
# in, or the countdown has expired.
|
122
|
+
if not self.is_googler:
|
123
|
+
return False
|
124
|
+
if self.opted_in is False:
|
125
|
+
return False
|
126
|
+
if self.opted_in is None and self.countdown > 0:
|
127
|
+
return False
|
128
|
+
return True
|
129
|
+
|
130
|
+
def decrease_countdown(self):
|
131
|
+
self._ensure_initialized()
|
132
|
+
if self.countdown == 0:
|
133
|
+
return
|
134
|
+
self._config['countdown'] -= 1
|
135
|
+
if self.countdown == 0:
|
136
|
+
self._config['version'] = metrics_utils.CURRENT_VERSION
|
137
|
+
self._write_config()
|
138
|
+
|
139
|
+
def reset_config(self):
|
140
|
+
# Only reset countdown if we're already collecting metrics.
|
141
|
+
if self.should_collect_metrics:
|
142
|
+
self._ensure_initialized()
|
143
|
+
self._config['countdown'] = DEFAULT_COUNTDOWN
|
144
|
+
self._config['opt-in'] = None
|
145
|
+
|
146
|
+
|
147
|
+
class MetricsCollector(object):
|
148
|
+
def __init__(self):
|
149
|
+
self._metrics_lock = threading.Lock()
|
150
|
+
self._reported_metrics = {}
|
151
|
+
self._config = _Config()
|
152
|
+
self._collecting_metrics = False
|
153
|
+
self._collect_custom_metrics = True
|
154
|
+
|
155
|
+
@property
|
156
|
+
def config(self):
|
157
|
+
return self._config
|
158
|
+
|
159
|
+
@property
|
160
|
+
def collecting_metrics(self):
|
161
|
+
return self._collecting_metrics
|
162
|
+
|
163
|
+
def add(self, name, value):
|
164
|
+
if self._collect_custom_metrics:
|
165
|
+
with self._metrics_lock:
|
166
|
+
self._reported_metrics[name] = value
|
167
|
+
|
168
|
+
def add_repeated(self, name, value):
|
169
|
+
if self._collect_custom_metrics:
|
170
|
+
with self._metrics_lock:
|
171
|
+
self._reported_metrics.setdefault(name, []).append(value)
|
172
|
+
|
173
|
+
@contextlib.contextmanager
|
174
|
+
def pause_metrics_collection(self):
|
175
|
+
collect_custom_metrics = self._collect_custom_metrics
|
176
|
+
self._collect_custom_metrics = False
|
177
|
+
try:
|
178
|
+
yield
|
179
|
+
finally:
|
180
|
+
self._collect_custom_metrics = collect_custom_metrics
|
181
|
+
|
182
|
+
def _upload_metrics_data(self):
|
183
|
+
"""Upload the metrics data to the AppEngine app."""
|
184
|
+
# We invoke a subprocess, and use stdin.write instead of communicate(),
|
185
|
+
# so that we are able to return immediately, leaving the upload running in
|
186
|
+
# the background.
|
187
|
+
p = subprocess.Popen([sys.executable, UPLOAD_SCRIPT], stdin=subprocess.PIPE)
|
188
|
+
p.stdin.write(json.dumps(self._reported_metrics))
|
189
|
+
|
190
|
+
def _collect_metrics(self, func, command_name, *args, **kwargs):
|
191
|
+
# If we're already collecting metrics, just execute the function.
|
192
|
+
# e.g. git-cl split invokes git-cl upload several times to upload each
|
193
|
+
# splitted CL.
|
194
|
+
if self.collecting_metrics:
|
195
|
+
# Don't collect metrics for this function.
|
196
|
+
# e.g. Don't record the arguments git-cl split passes to git-cl upload.
|
197
|
+
with self.pause_metrics_collection():
|
198
|
+
return func(*args, **kwargs)
|
199
|
+
|
200
|
+
self._collecting_metrics = True
|
201
|
+
self.add('command', command_name)
|
202
|
+
try:
|
203
|
+
start = time.time()
|
204
|
+
result = func(*args, **kwargs)
|
205
|
+
exception = None
|
206
|
+
# pylint: disable=bare-except
|
207
|
+
except:
|
208
|
+
exception = sys.exc_info()
|
209
|
+
finally:
|
210
|
+
self.add('execution_time', time.time() - start)
|
211
|
+
|
212
|
+
exit_code = metrics_utils.return_code_from_exception(exception)
|
213
|
+
self.add('exit_code', exit_code)
|
214
|
+
|
215
|
+
# Add metrics regarding environment information.
|
216
|
+
self.add('timestamp', metrics_utils.seconds_to_weeks(time.time()))
|
217
|
+
self.add('python_version', metrics_utils.get_python_version())
|
218
|
+
self.add('host_os', gclient_utils.GetMacWinOrLinux())
|
219
|
+
self.add('host_arch', detect_host_arch.HostArch())
|
220
|
+
|
221
|
+
depot_tools_age = metrics_utils.get_repo_timestamp(DEPOT_TOOLS)
|
222
|
+
if depot_tools_age is not None:
|
223
|
+
self.add('depot_tools_age', depot_tools_age)
|
224
|
+
|
225
|
+
git_version = metrics_utils.get_git_version()
|
226
|
+
if git_version:
|
227
|
+
self.add('git_version', git_version)
|
228
|
+
|
229
|
+
self._upload_metrics_data()
|
230
|
+
if exception:
|
231
|
+
gclient_utils.reraise(exception[0], exception[1], exception[2])
|
232
|
+
return result
|
233
|
+
|
234
|
+
def collect_metrics(self, command_name):
|
235
|
+
"""A decorator used to collect metrics over the life of a function.
|
236
|
+
|
237
|
+
This decorator executes the function and collects metrics about the system
|
238
|
+
environment and the function performance.
|
239
|
+
"""
|
240
|
+
def _decorator(func):
|
241
|
+
# Do this first so we don't have to read, and possibly create a config
|
242
|
+
# file.
|
243
|
+
if DISABLE_METRICS_COLLECTION:
|
244
|
+
return func
|
245
|
+
if not self.config.should_collect_metrics:
|
246
|
+
return func
|
247
|
+
# Otherwise, collect the metrics.
|
248
|
+
# Needed to preserve the __name__ and __doc__ attributes of func.
|
249
|
+
@functools.wraps(func)
|
250
|
+
def _inner(*args, **kwargs):
|
251
|
+
return self._collect_metrics(func, command_name, *args, **kwargs)
|
252
|
+
return _inner
|
253
|
+
return _decorator
|
254
|
+
|
255
|
+
@contextlib.contextmanager
|
256
|
+
def print_notice_and_exit(self):
|
257
|
+
"""A context manager used to print the notice and terminate execution.
|
258
|
+
|
259
|
+
This decorator executes the function and prints the monitoring notice if
|
260
|
+
necessary. If an exception is raised, we will catch it, and print it before
|
261
|
+
printing the metrics collection notice.
|
262
|
+
This will call sys.exit() with an appropriate exit code to ensure the notice
|
263
|
+
is the last thing printed."""
|
264
|
+
# Needed to preserve the __name__ and __doc__ attributes of func.
|
265
|
+
try:
|
266
|
+
yield
|
267
|
+
exception = None
|
268
|
+
# pylint: disable=bare-except
|
269
|
+
except:
|
270
|
+
exception = sys.exc_info()
|
271
|
+
|
272
|
+
# Print the exception before the metrics notice, so that the notice is
|
273
|
+
# clearly visible even if gclient fails.
|
274
|
+
if exception:
|
275
|
+
if isinstance(exception[1], KeyboardInterrupt):
|
276
|
+
sys.stderr.write('Interrupted\n')
|
277
|
+
elif not isinstance(exception[1], SystemExit):
|
278
|
+
traceback.print_exception(*exception)
|
279
|
+
|
280
|
+
# Check if the version has changed
|
281
|
+
if (not DISABLE_METRICS_COLLECTION and self.config.is_googler
|
282
|
+
and self.config.opted_in is not False
|
283
|
+
and self.config.version != metrics_utils.CURRENT_VERSION):
|
284
|
+
metrics_utils.print_version_change(self.config.version)
|
285
|
+
self.config.reset_config()
|
286
|
+
|
287
|
+
# Print the notice
|
288
|
+
if (not DISABLE_METRICS_COLLECTION and self.config.is_googler
|
289
|
+
and self.config.opted_in is None):
|
290
|
+
metrics_utils.print_notice(self.config.countdown)
|
291
|
+
self.config.decrease_countdown()
|
292
|
+
|
293
|
+
sys.exit(metrics_utils.return_code_from_exception(exception))
|
294
|
+
|
295
|
+
|
296
|
+
collector = MetricsCollector()
|