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.
Files changed (408) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +3 -0
  3. data/CHANGELOG.md +4 -0
  4. data/README.md +2 -0
  5. data/ext/libv8/builder.rb +6 -2
  6. data/lib/libv8/version.rb +1 -1
  7. data/vendor/depot_tools/.gitattributes +1 -0
  8. data/vendor/depot_tools/.gitignore +7 -0
  9. data/vendor/depot_tools/CROS_OWNERS +5 -0
  10. data/vendor/depot_tools/OWNERS +12 -1
  11. data/vendor/depot_tools/PRESUBMIT.py +16 -9
  12. data/vendor/depot_tools/README.md +9 -2
  13. data/vendor/depot_tools/autoninja +14 -6
  14. data/vendor/depot_tools/autoninja.bat +11 -1
  15. data/vendor/depot_tools/autoninja.py +40 -18
  16. data/vendor/depot_tools/bb +12 -0
  17. data/vendor/depot_tools/bb.bat +7 -0
  18. data/vendor/depot_tools/bootstrap/win/manifest.txt +1 -1
  19. data/vendor/depot_tools/bootstrap/win/manifest_bleeding_edge.txt +1 -1
  20. data/vendor/depot_tools/bootstrap/win/win_tools.py +2 -1
  21. data/vendor/depot_tools/buildbucket.py +57 -4
  22. data/vendor/depot_tools/cipd +157 -44
  23. data/vendor/depot_tools/cipd.bat +51 -14
  24. data/vendor/depot_tools/cipd.ps1 +104 -42
  25. data/vendor/depot_tools/cipd_client_version +1 -1
  26. data/vendor/depot_tools/cipd_client_version.digests +21 -0
  27. data/vendor/depot_tools/cipd_manifest.txt +19 -6
  28. data/vendor/depot_tools/cipd_manifest.versions +318 -0
  29. data/vendor/depot_tools/clang_format.py +4 -4
  30. data/vendor/depot_tools/cpplint.py +44 -199
  31. data/vendor/depot_tools/dart_format.py +2 -2
  32. data/vendor/depot_tools/detect_host_arch.py +8 -3
  33. data/vendor/depot_tools/download_from_google_storage.py +47 -39
  34. data/vendor/depot_tools/fetch.py +30 -18
  35. data/vendor/depot_tools/fetch_configs/android_internal.py +34 -0
  36. data/vendor/depot_tools/fetch_configs/chromium.py +18 -1
  37. data/vendor/depot_tools/fetch_configs/config_util.py +4 -2
  38. data/vendor/depot_tools/fetch_configs/inspector_protocol.py +40 -0
  39. data/vendor/depot_tools/fetch_configs/node-ci.py +41 -0
  40. data/vendor/depot_tools/fix_encoding.py +3 -3
  41. data/vendor/depot_tools/gclient +1 -1
  42. data/vendor/depot_tools/gclient.py +415 -198
  43. data/vendor/depot_tools/gclient_eval.py +220 -171
  44. data/vendor/depot_tools/gclient_paths.py +142 -0
  45. data/vendor/depot_tools/gclient_scm.py +200 -51
  46. data/vendor/depot_tools/gclient_utils.py +88 -191
  47. data/vendor/depot_tools/gerrit_client.py +13 -0
  48. data/vendor/depot_tools/gerrit_util.py +158 -23
  49. data/vendor/depot_tools/git-nav-upstream +1 -1
  50. data/vendor/depot_tools/git_cache.py +77 -24
  51. data/vendor/depot_tools/git_cl.py +705 -1099
  52. data/vendor/depot_tools/git_common.py +9 -6
  53. data/vendor/depot_tools/git_map_branches.py +19 -2
  54. data/vendor/depot_tools/git_nav_downstream.py +3 -4
  55. data/vendor/depot_tools/git_rebase_update.py +14 -0
  56. data/vendor/depot_tools/git_reparent_branch.py +8 -2
  57. data/vendor/depot_tools/gn.py +38 -3
  58. data/vendor/depot_tools/gsutil.py +8 -3
  59. data/vendor/depot_tools/gsutil.py.bat +15 -0
  60. data/vendor/depot_tools/gsutil.vpython +16 -0
  61. data/vendor/depot_tools/infra/config/OWNERS +0 -1
  62. data/vendor/depot_tools/infra/config/recipes.cfg +3 -2
  63. data/vendor/depot_tools/lucicfg +12 -0
  64. data/vendor/depot_tools/lucicfg.bat +7 -0
  65. data/vendor/depot_tools/man/html/git-map-branches.html +34 -2
  66. data/vendor/depot_tools/man/html/git-new-branch.html +40 -32
  67. data/vendor/depot_tools/man/man1/git-map-branches.1 +24 -5
  68. data/vendor/depot_tools/man/man1/git-new-branch.1 +35 -27
  69. data/vendor/depot_tools/man/src/git-map-branches.demo.1.sh +1 -0
  70. data/vendor/depot_tools/man/src/git-map-branches.txt +10 -0
  71. data/vendor/depot_tools/man/src/git-new-branch.demo.1.sh +9 -4
  72. data/vendor/depot_tools/man/src/git-new-branch.txt +1 -1
  73. data/vendor/depot_tools/metrics.README.md +98 -0
  74. data/vendor/depot_tools/metrics.py +296 -0
  75. data/vendor/depot_tools/metrics_utils.py +303 -0
  76. data/vendor/depot_tools/my_activity.py +91 -29
  77. data/vendor/depot_tools/ninja +1 -1
  78. data/vendor/depot_tools/ninjalog.README.md +64 -0
  79. data/vendor/depot_tools/ninjalog_uploader.py +232 -0
  80. data/vendor/depot_tools/ninjalog_uploader_wrapper.py +116 -0
  81. data/vendor/depot_tools/owners.py +30 -13
  82. data/vendor/depot_tools/owners_finder.py +5 -2
  83. data/vendor/depot_tools/presubmit_canned_checks.py +188 -29
  84. data/vendor/depot_tools/presubmit_support.py +18 -41
  85. data/vendor/depot_tools/pylintrc +23 -19
  86. data/vendor/depot_tools/recipes/OWNERS +2 -0
  87. data/vendor/depot_tools/recipes/README.recipes.md +344 -151
  88. data/vendor/depot_tools/recipes/recipe_modules/bot_update/OWNERS +2 -0
  89. data/vendor/depot_tools/recipes/recipe_modules/bot_update/__init__.py +2 -16
  90. data/vendor/depot_tools/recipes/recipe_modules/bot_update/api.py +141 -99
  91. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic.json +5 -8
  92. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_luci.json +5 -8
  93. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_with_branch_heads.json +6 -98
  94. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/clobber.json +4 -9
  95. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/deprecated_got_revision_mapping.json +45 -5
  96. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_rebase_patch_ref.json +4 -9
  97. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_reset.json +4 -9
  98. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{tryjob.json → input_commit_with_id_without_repo.json} +6 -11
  99. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{tryjob_empty_revision.json → multiple_patch_refs.json} +8 -9
  100. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_apply_patch_on_gclient.json +19 -29
  101. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{trychange.json → refs.json} +4 -9
  102. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/reset_root_solution_revision.json +4 -9
  103. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail.json +51 -6
  104. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch.json +50 -6
  105. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch_download.json +51 -6
  106. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle.json +17 -25
  107. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_branch_heads.json +17 -25
  108. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_feature_branch.json +18 -26
  109. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8_feature_branch.json +18 -26
  110. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_webrtc.json +26 -28
  111. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8.json +45 -5
  112. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8_head_by_default.json +17 -25
  113. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/unrecognized_commit_repo.json +13 -0
  114. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name.json +13 -152
  115. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_tags.json +4 -9
  116. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.py +185 -202
  117. data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/bot_update.py +52 -157
  118. data/vendor/depot_tools/recipes/recipe_modules/bot_update/test_api.py +5 -14
  119. data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/ensure_checkout.py +34 -0
  120. data/vendor/depot_tools/recipes/recipe_modules/cipd/api.py +14 -2
  121. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic.json +4 -5
  122. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic_pkg.json +4 -5
  123. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-failed.json +7 -5
  124. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-many-instances.json +4 -5
  125. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/mac64.json +4 -5
  126. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_file.json +9 -3
  127. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_mode.json +9 -3
  128. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_verfile.json +9 -3
  129. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/win64.json +4 -5
  130. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk arch.json +2 -3
  131. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk bits.json +2 -3
  132. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_32.json +2 -3
  133. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_64.json +2 -3
  134. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_32.json +2 -3
  135. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_64.json +2 -3
  136. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_mips_64.json +2 -3
  137. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/mac_intel_64.json +2 -3
  138. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_32.json +2 -3
  139. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_64.json +2 -3
  140. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/api.py +13 -8
  141. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic.json +18 -12
  142. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic_luci.json +18 -12
  143. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/win.json +18 -12
  144. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.py +3 -0
  145. data/vendor/depot_tools/recipes/recipe_modules/gclient/__init__.py +1 -0
  146. data/vendor/depot_tools/recipes/recipe_modules/gclient/api.py +58 -46
  147. data/vendor/depot_tools/recipes/recipe_modules/gclient/config.py +65 -22
  148. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/basic.json +20 -21
  149. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/buildbot.json +20 -21
  150. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/revision.json +20 -21
  151. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/tryserver.json +20 -21
  152. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.py +5 -2
  153. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/patch_project.py +62 -14
  154. data/vendor/depot_tools/recipes/recipe_modules/gerrit/api.py +24 -38
  155. data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.expected/basic.json +56 -50
  156. data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.py +15 -9
  157. data/vendor/depot_tools/recipes/recipe_modules/git/__init__.py +4 -1
  158. data/vendor/depot_tools/recipes/recipe_modules/git/api.py +34 -22
  159. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic.json +5 -6
  160. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_branch.json +5 -6
  161. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_file_name.json +5 -6
  162. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_hash.json +5 -6
  163. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_luci.json +222 -0
  164. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_ref.json +5 -6
  165. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_submodule_update_force.json +5 -6
  166. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_tags.json +224 -0
  167. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/can_fail_build.json +10 -6
  168. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cannot_fail_build.json +5 -7
  169. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cat-file_test.json +5 -6
  170. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_delta.json +5 -6
  171. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_failed.json +5 -7
  172. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output.json +5 -6
  173. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output_fails_build.json +10 -5
  174. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/curl_trace_file.json +5 -6
  175. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/git-cache-checkout.json +8 -9
  176. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/platform_win.json +5 -6
  177. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/rebase_failed.json +12 -8
  178. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/remote_not_origin.json +5 -6
  179. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/set_got_revision.json +5 -6
  180. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.py +27 -11
  181. data/vendor/depot_tools/recipes/recipe_modules/git_cl/api.py +1 -1
  182. data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.expected/basic.json +12 -13
  183. data/vendor/depot_tools/recipes/recipe_modules/gitiles/__init__.py +5 -0
  184. data/vendor/depot_tools/recipes/recipe_modules/gitiles/api.py +120 -5
  185. data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.expected/basic.json +45 -3
  186. data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.py +25 -0
  187. data/vendor/depot_tools/recipes/recipe_modules/gitiles/resources/gerrit_client.py +56 -4
  188. data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.expected/basic.json +6 -0
  189. data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.py +49 -0
  190. data/vendor/depot_tools/recipes/recipe_modules/gsutil/api.py +24 -13
  191. data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.expected/basic.json +13 -14
  192. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/basic.json +2 -3
  193. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_linux.json +2 -3
  194. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_mac.json +2 -3
  195. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_win.json +2 -3
  196. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_linux.json +2 -3
  197. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_mac.json +2 -3
  198. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_win.json +2 -3
  199. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_linux.json +2 -3
  200. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_mac.json +2 -3
  201. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_win.json +2 -3
  202. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/path_config.py +1 -2
  203. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/__init__.py +35 -0
  204. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/api.py +116 -0
  205. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/linux.json +22 -0
  206. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/mac.json +82 -0
  207. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/win.json +22 -0
  208. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.py +23 -0
  209. data/vendor/depot_tools/recipes/recipe_modules/presubmit/__init__.py +1 -0
  210. data/vendor/depot_tools/recipes/recipe_modules/presubmit/api.py +2 -7
  211. data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.expected/basic.json +7 -6
  212. data/vendor/depot_tools/recipes/recipe_modules/tryserver/__init__.py +1 -0
  213. data/vendor/depot_tools/recipes/recipe_modules/tryserver/api.py +117 -8
  214. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/basic_tags.json +4 -5
  215. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/set_failure_hash_with_no_steps.json +7 -4
  216. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch.json +98 -7
  217. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch_and_target_ref.json +147 -0
  218. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch.json +8 -5
  219. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch_luci.json +8 -5
  220. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch.json +9 -6
  221. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch_new.json +9 -6
  222. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.py +27 -2
  223. data/vendor/depot_tools/recipes/recipe_modules/tryserver/test_api.py +14 -0
  224. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/__init__.py +25 -0
  225. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/api.py +137 -0
  226. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/linux.json +22 -0
  227. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/mac.json +22 -0
  228. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/win.json +107 -0
  229. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.py +26 -0
  230. data/vendor/depot_tools/recipes/recipes.py +37 -27
  231. data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.expected/basic.json +7 -10
  232. data/vendor/depot_tools/repo +34 -8
  233. data/vendor/depot_tools/roll_dep.py +52 -49
  234. data/vendor/depot_tools/scm.py +38 -23
  235. data/vendor/depot_tools/setup_color.py +4 -2
  236. data/vendor/depot_tools/split_cl.py +32 -4
  237. data/vendor/depot_tools/subprocess2.py +22 -4
  238. data/vendor/depot_tools/third_party/httplib2/README.chromium +2 -2
  239. data/vendor/depot_tools/third_party/httplib2/__init__.py +242 -158
  240. data/vendor/depot_tools/third_party/httplib2/cacerts.txt +57 -44
  241. data/vendor/depot_tools/third_party/httplib2/socks.py +15 -5
  242. data/vendor/depot_tools/third_party/logilab/README.chromium +2 -4
  243. data/vendor/depot_tools/third_party/logilab/astroid/README.chromium +2 -1
  244. data/vendor/depot_tools/third_party/logilab/astroid/__init__.py +10 -5
  245. data/vendor/depot_tools/third_party/logilab/astroid/__pkginfo__.py +5 -5
  246. data/vendor/depot_tools/third_party/logilab/astroid/arguments.py +233 -0
  247. data/vendor/depot_tools/third_party/logilab/astroid/as_string.py +82 -33
  248. data/vendor/depot_tools/third_party/logilab/astroid/bases.py +137 -153
  249. data/vendor/depot_tools/third_party/logilab/astroid/brain/{builtin_inference.py → brain_builtin_inference.py} +117 -26
  250. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_dateutil.py +15 -0
  251. data/vendor/depot_tools/third_party/logilab/astroid/brain/{py2gi.py → brain_gi.py} +48 -8
  252. data/vendor/depot_tools/third_party/logilab/astroid/brain/{py2mechanize.py → brain_mechanize.py} +0 -0
  253. data/vendor/depot_tools/third_party/logilab/astroid/brain/{pynose.py → brain_nose.py} +4 -1
  254. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_numpy.py +62 -0
  255. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_pytest.py +76 -0
  256. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_qt.py +44 -0
  257. data/vendor/depot_tools/third_party/logilab/astroid/brain/{pysix_moves.py → brain_six.py} +28 -1
  258. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_ssl.py +65 -0
  259. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_stdlib.py +473 -0
  260. data/vendor/depot_tools/third_party/logilab/astroid/builder.py +104 -81
  261. data/vendor/depot_tools/third_party/logilab/astroid/context.py +81 -0
  262. data/vendor/depot_tools/third_party/logilab/astroid/decorators.py +75 -0
  263. data/vendor/depot_tools/third_party/logilab/astroid/exceptions.py +20 -0
  264. data/vendor/depot_tools/third_party/logilab/astroid/inference.py +137 -183
  265. data/vendor/depot_tools/third_party/logilab/astroid/manager.py +45 -169
  266. data/vendor/depot_tools/third_party/logilab/astroid/mixins.py +37 -14
  267. data/vendor/depot_tools/third_party/logilab/astroid/modutils.py +112 -41
  268. data/vendor/depot_tools/third_party/logilab/astroid/node_classes.py +243 -156
  269. data/vendor/depot_tools/third_party/logilab/astroid/nodes.py +35 -22
  270. data/vendor/depot_tools/third_party/logilab/astroid/objects.py +186 -0
  271. data/vendor/depot_tools/third_party/logilab/astroid/protocols.py +157 -102
  272. data/vendor/depot_tools/third_party/logilab/astroid/raw_building.py +32 -8
  273. data/vendor/depot_tools/third_party/logilab/astroid/rebuilder.py +372 -309
  274. data/vendor/depot_tools/third_party/logilab/astroid/scoped_nodes.py +652 -420
  275. data/vendor/depot_tools/third_party/logilab/astroid/test_utils.py +4 -21
  276. data/vendor/depot_tools/third_party/logilab/astroid/transforms.py +96 -0
  277. data/vendor/depot_tools/third_party/logilab/astroid/util.py +89 -0
  278. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/LICENSE +19 -0
  279. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/README.chromium +11 -0
  280. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/__init__.py +20 -0
  281. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/cext.c +1421 -0
  282. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/compat.py +9 -0
  283. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/simple.py +246 -0
  284. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/slots.py +414 -0
  285. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/utils.py +13 -0
  286. data/vendor/depot_tools/third_party/logilab/wrapt/LICENSE +24 -0
  287. data/vendor/depot_tools/third_party/logilab/wrapt/README.chromium +11 -0
  288. data/vendor/depot_tools/third_party/logilab/wrapt/__init__.py +19 -0
  289. data/vendor/depot_tools/third_party/logilab/wrapt/_wrappers.c +2729 -0
  290. data/vendor/depot_tools/third_party/logilab/wrapt/arguments.py +96 -0
  291. data/vendor/depot_tools/third_party/logilab/wrapt/decorators.py +512 -0
  292. data/vendor/depot_tools/third_party/logilab/wrapt/importer.py +228 -0
  293. data/vendor/depot_tools/third_party/logilab/wrapt/wrappers.py +901 -0
  294. data/vendor/depot_tools/third_party/pylint/README.chromium +2 -25
  295. data/vendor/depot_tools/third_party/pylint/__pkginfo__.py +13 -3
  296. data/vendor/depot_tools/third_party/pylint/checkers/__init__.py +1 -2
  297. data/vendor/depot_tools/third_party/pylint/checkers/async.py +82 -0
  298. data/vendor/depot_tools/third_party/pylint/checkers/base.py +893 -119
  299. data/vendor/depot_tools/third_party/pylint/checkers/classes.py +342 -204
  300. data/vendor/depot_tools/third_party/pylint/checkers/design_analysis.py +51 -34
  301. data/vendor/depot_tools/third_party/pylint/checkers/exceptions.py +84 -47
  302. data/vendor/depot_tools/third_party/pylint/checkers/format.py +55 -30
  303. data/vendor/depot_tools/third_party/pylint/checkers/imports.py +314 -73
  304. data/vendor/depot_tools/third_party/pylint/checkers/logging.py +10 -8
  305. data/vendor/depot_tools/third_party/pylint/checkers/misc.py +2 -1
  306. data/vendor/depot_tools/third_party/pylint/checkers/newstyle.py +45 -48
  307. data/vendor/depot_tools/third_party/pylint/checkers/python3.py +31 -21
  308. data/vendor/depot_tools/third_party/pylint/checkers/raw_metrics.py +3 -3
  309. data/vendor/depot_tools/third_party/pylint/checkers/similar.py +4 -5
  310. data/vendor/depot_tools/third_party/pylint/checkers/spelling.py +24 -10
  311. data/vendor/depot_tools/third_party/pylint/checkers/stdlib.py +120 -56
  312. data/vendor/depot_tools/third_party/pylint/checkers/strings.py +38 -35
  313. data/vendor/depot_tools/third_party/pylint/checkers/typecheck.py +485 -138
  314. data/vendor/depot_tools/third_party/pylint/checkers/utils.py +319 -142
  315. data/vendor/depot_tools/third_party/pylint/checkers/variables.py +329 -207
  316. data/vendor/depot_tools/third_party/pylint/config.py +739 -76
  317. data/vendor/depot_tools/third_party/pylint/epylint.py +9 -5
  318. data/vendor/depot_tools/third_party/pylint/extensions/__init__.py +0 -0
  319. data/vendor/depot_tools/third_party/pylint/extensions/check_docs.py +311 -0
  320. data/vendor/depot_tools/third_party/pylint/extensions/check_elif.py +62 -0
  321. data/vendor/depot_tools/third_party/{logilab/common → pylint}/graph.py +30 -133
  322. data/vendor/depot_tools/third_party/pylint/gui.py +2 -2
  323. data/vendor/depot_tools/third_party/pylint/interfaces.py +21 -3
  324. data/vendor/depot_tools/third_party/pylint/lint.py +123 -140
  325. data/vendor/depot_tools/third_party/pylint/pyreverse/diadefslib.py +10 -13
  326. data/vendor/depot_tools/third_party/pylint/pyreverse/diagrams.py +15 -4
  327. data/vendor/depot_tools/third_party/pylint/pyreverse/inspector.py +372 -0
  328. data/vendor/depot_tools/third_party/pylint/pyreverse/main.py +30 -7
  329. data/vendor/depot_tools/third_party/pylint/pyreverse/utils.py +80 -2
  330. data/vendor/depot_tools/third_party/{logilab/common → pylint/pyreverse}/vcgutils.py +19 -37
  331. data/vendor/depot_tools/third_party/pylint/pyreverse/writer.py +3 -4
  332. data/vendor/depot_tools/third_party/pylint/reporters/__init__.py +34 -18
  333. data/vendor/depot_tools/third_party/pylint/reporters/guireporter.py +1 -1
  334. data/vendor/depot_tools/third_party/pylint/reporters/html.py +10 -3
  335. data/vendor/depot_tools/third_party/pylint/reporters/json.py +10 -4
  336. data/vendor/depot_tools/third_party/pylint/reporters/text.py +94 -3
  337. data/vendor/depot_tools/third_party/pylint/reporters/ureports/__init__.py +106 -0
  338. data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/html_writer.py +17 -57
  339. data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/nodes.py +52 -74
  340. data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/text_writer.py +14 -60
  341. data/vendor/depot_tools/third_party/pylint/testutils.py +22 -20
  342. data/vendor/depot_tools/third_party/pylint/utils.py +268 -44
  343. data/vendor/depot_tools/third_party/repo/progress.py +42 -0
  344. data/vendor/depot_tools/update_depot_tools +1 -1
  345. data/vendor/depot_tools/upload_metrics.py +25 -0
  346. data/vendor/depot_tools/win_toolchain/get_toolchain_if_necessary.py +45 -15
  347. data/vendor/depot_tools/win_toolchain/package_from_installed.py +71 -24
  348. data/vendor/depot_tools/yapf +1 -1
  349. data/vendor/depot_tools/yapf.bat +1 -1
  350. metadata +92 -77
  351. data/vendor/depot_tools/git-crsync +0 -3
  352. data/vendor/depot_tools/infra/config/cq.cfg +0 -32
  353. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/apply_gerrit_ref.json +0 -29
  354. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/apply_gerrit_ref_custom.json +0 -29
  355. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/buildbot.json +0 -105
  356. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/shallow.json +0 -195
  357. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle_deprecated.json +0 -248
  358. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8.json +0 -248
  359. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name_no_patch.json +0 -105
  360. data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/apply_gerrit.py +0 -33
  361. data/vendor/depot_tools/third_party/logilab/astroid/brain/py2pytest.py +0 -31
  362. data/vendor/depot_tools/third_party/logilab/astroid/brain/py2qt4.py +0 -22
  363. data/vendor/depot_tools/third_party/logilab/astroid/brain/py2stdlib.py +0 -334
  364. data/vendor/depot_tools/third_party/logilab/astroid/inspector.py +0 -273
  365. data/vendor/depot_tools/third_party/logilab/astroid/utils.py +0 -239
  366. data/vendor/depot_tools/third_party/logilab/common/LICENSE.txt +0 -339
  367. data/vendor/depot_tools/third_party/logilab/common/README.chromium +0 -11
  368. data/vendor/depot_tools/third_party/logilab/common/__init__.py +0 -175
  369. data/vendor/depot_tools/third_party/logilab/common/__pkginfo__.py +0 -57
  370. data/vendor/depot_tools/third_party/logilab/common/cache.py +0 -114
  371. data/vendor/depot_tools/third_party/logilab/common/changelog.py +0 -238
  372. data/vendor/depot_tools/third_party/logilab/common/clcommands.py +0 -334
  373. data/vendor/depot_tools/third_party/logilab/common/cli.py +0 -211
  374. data/vendor/depot_tools/third_party/logilab/common/compat.py +0 -78
  375. data/vendor/depot_tools/third_party/logilab/common/configuration.py +0 -1105
  376. data/vendor/depot_tools/third_party/logilab/common/contexts.py +0 -5
  377. data/vendor/depot_tools/third_party/logilab/common/corbautils.py +0 -117
  378. data/vendor/depot_tools/third_party/logilab/common/daemon.py +0 -101
  379. data/vendor/depot_tools/third_party/logilab/common/date.py +0 -335
  380. data/vendor/depot_tools/third_party/logilab/common/dbf.py +0 -231
  381. data/vendor/depot_tools/third_party/logilab/common/debugger.py +0 -214
  382. data/vendor/depot_tools/third_party/logilab/common/decorators.py +0 -281
  383. data/vendor/depot_tools/third_party/logilab/common/deprecation.py +0 -189
  384. data/vendor/depot_tools/third_party/logilab/common/fileutils.py +0 -404
  385. data/vendor/depot_tools/third_party/logilab/common/interface.py +0 -71
  386. data/vendor/depot_tools/third_party/logilab/common/logging_ext.py +0 -195
  387. data/vendor/depot_tools/third_party/logilab/common/modutils.py +0 -702
  388. data/vendor/depot_tools/third_party/logilab/common/optik_ext.py +0 -392
  389. data/vendor/depot_tools/third_party/logilab/common/optparser.py +0 -92
  390. data/vendor/depot_tools/third_party/logilab/common/proc.py +0 -277
  391. data/vendor/depot_tools/third_party/logilab/common/pyro_ext.py +0 -180
  392. data/vendor/depot_tools/third_party/logilab/common/pytest.py +0 -1199
  393. data/vendor/depot_tools/third_party/logilab/common/registry.py +0 -1119
  394. data/vendor/depot_tools/third_party/logilab/common/shellutils.py +0 -462
  395. data/vendor/depot_tools/third_party/logilab/common/sphinx_ext.py +0 -87
  396. data/vendor/depot_tools/third_party/logilab/common/sphinxutils.py +0 -122
  397. data/vendor/depot_tools/third_party/logilab/common/table.py +0 -929
  398. data/vendor/depot_tools/third_party/logilab/common/tasksqueue.py +0 -101
  399. data/vendor/depot_tools/third_party/logilab/common/testlib.py +0 -1392
  400. data/vendor/depot_tools/third_party/logilab/common/textutils.py +0 -537
  401. data/vendor/depot_tools/third_party/logilab/common/tree.py +0 -369
  402. data/vendor/depot_tools/third_party/logilab/common/umessage.py +0 -194
  403. data/vendor/depot_tools/third_party/logilab/common/ureports/__init__.py +0 -172
  404. data/vendor/depot_tools/third_party/logilab/common/ureports/docbook_writer.py +0 -140
  405. data/vendor/depot_tools/third_party/logilab/common/urllib2ext.py +0 -89
  406. data/vendor/depot_tools/third_party/logilab/common/visitor.py +0 -109
  407. data/vendor/depot_tools/third_party/logilab/common/xmlrpcutils.py +0 -131
  408. data/vendor/depot_tools/third_party/logilab/common/xmlutils.py +0 -61
@@ -0,0 +1,2 @@
1
+ tandrii@chromium.org
2
+ ehmaldonado@chromium.org
@@ -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, patch_issue, patch_set,
13
- repository, patch_repository_url, gerrit_ref, patch_ref,
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
- # DO NOT USE.
45
- # TODO(tandrii): refactor this into tryserver.maybe_apply_patch
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
- env_prefixes = {
63
- 'PATH': [self.m.depot_tools.root],
64
- }
65
- with self.m.context(env_prefixes=env_prefixes):
66
- return self.m.python(step_name, apply_gerrit_path, cmd, **kwargs)
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, no_shallow=True,
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
- root = patch_root
107
- if root is None:
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.set_patch_project_revision(
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', 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
- elif solution == cfg.solutions[0]:
157
- # TODO(machenbach): We should explicitly pass HEAD for ALL solutions
158
- # that don't specify anything else.
159
- revisions[solution.name] = (
160
- self._parent_got_revision or
161
- self._revision or
162
- 'HEAD')
163
- if self.m.gclient.c and self.m.gclient.c.revisions:
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 self.m.gclient.c.revisions.iteritems() if v)
183
+ (k, v) for k, v in cfg.revisions.iteritems() if v)
168
184
  if cfg.solutions and root_solution_revision:
169
- revisions[cfg.solutions[0].name] = root_solution_revision
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
- root, first_sln, reverse_rev_map, self._fail_patch,
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 = step_result.json.output.get(
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, result.get('source_manifest', {}))
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['did_run'] and 'checkout' not in self.m.path:
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
- This is a noop if there's no Gerrit CL associated with the run.
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
- # Bail out if this is not a gerrit issue.
327
- if (not self.m.tryserver.is_gerrit_issue or
328
- not self._gerrit or not self._issue):
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
- # Ignore other project paths than the one belonging to the CL.
332
- if path != cfg.patch_projects.get(
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
- # Query Gerrit to check if a CL's destination branch differs from master.
338
- destination_branch = self.m.gerrit.get_change_destination_branch(
339
- host=self._gerrit,
340
- change=self._issue,
341
- name='get_patch_destination_branch',
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
- # Only use prefix if different from bot_update.py's default.
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@abc",
18
+ "src@2d72510e447ab60a9728aeea2362d8be2cbd7789",
21
19
  "--disable-syntax-validation"
22
20
  ],
23
21
  "env_prefixes": {
24
22
  "PATH": [
25
- "RECIPE_PACKAGE_REPO[depot_tools]"
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\": \"abc\"@@@",
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
- "name": "$result",
102
- "recipe_result": null,
103
- "status_code": 0
99
+ "jsonResult": null,
100
+ "name": "$result"
104
101
  }
105
102
  ]