libv8 8.4.255.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (639) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +19 -0
  3. data/.gitmodules +3 -0
  4. data/.rspec +3 -0
  5. data/.travis.yml +45 -0
  6. data/CHANGELOG.md +111 -0
  7. data/Gemfile +4 -0
  8. data/README.md +152 -0
  9. data/Rakefile +125 -0
  10. data/appveyor.yml.disabled +36 -0
  11. data/ext/libv8/arch.rb +20 -0
  12. data/ext/libv8/builder.rb +106 -0
  13. data/ext/libv8/extconf.rb +7 -0
  14. data/ext/libv8/location.rb +89 -0
  15. data/ext/libv8/paths.rb +28 -0
  16. data/lib/libv8.rb +9 -0
  17. data/lib/libv8/version.rb +3 -0
  18. data/libv8.gemspec +30 -0
  19. data/scaleway.png +0 -0
  20. data/spec/location_spec.rb +69 -0
  21. data/spec/spec_helper.rb +4 -0
  22. data/thefrontside.png +0 -0
  23. data/vendor/depot_tools/.cipd_impl.ps1 +129 -0
  24. data/vendor/depot_tools/.gitattributes +55 -0
  25. data/vendor/depot_tools/.gitignore +92 -0
  26. data/vendor/depot_tools/.style.yapf +4 -0
  27. data/vendor/depot_tools/.vpython +55 -0
  28. data/vendor/depot_tools/.vpython3 +23 -0
  29. data/vendor/depot_tools/CROS_OWNERS +7 -0
  30. data/vendor/depot_tools/GOMA_OWNERS +9 -0
  31. data/vendor/depot_tools/LICENSE +27 -0
  32. data/vendor/depot_tools/LUCI_OWNERS +5 -0
  33. data/vendor/depot_tools/OWNERS +39 -0
  34. data/vendor/depot_tools/PRESUBMIT.py +150 -0
  35. data/vendor/depot_tools/README.gclient.md +67 -0
  36. data/vendor/depot_tools/README.git-cl.md +99 -0
  37. data/vendor/depot_tools/README.md +78 -0
  38. data/vendor/depot_tools/WATCHLISTS +26 -0
  39. data/vendor/depot_tools/auth.py +163 -0
  40. data/vendor/depot_tools/autoninja +36 -0
  41. data/vendor/depot_tools/autoninja.bat +33 -0
  42. data/vendor/depot_tools/autoninja.py +148 -0
  43. data/vendor/depot_tools/bb +12 -0
  44. data/vendor/depot_tools/bb.bat +7 -0
  45. data/vendor/depot_tools/bootstrap/README.md +155 -0
  46. data/vendor/depot_tools/bootstrap/bootstrap.py +356 -0
  47. data/vendor/depot_tools/bootstrap/git-bash.template.sh +12 -0
  48. data/vendor/depot_tools/bootstrap/git.template.bat +5 -0
  49. data/vendor/depot_tools/bootstrap/manifest.txt +27 -0
  50. data/vendor/depot_tools/bootstrap/manifest_bleeding_edge.txt +27 -0
  51. data/vendor/depot_tools/bootstrap/profile.d.python.sh +20 -0
  52. data/vendor/depot_tools/bootstrap/python27.bat +46 -0
  53. data/vendor/depot_tools/bootstrap/python3.bat +46 -0
  54. data/vendor/depot_tools/bootstrap/win_tools.bat +79 -0
  55. data/vendor/depot_tools/bootstrap_python3 +35 -0
  56. data/vendor/depot_tools/breakpad.py +12 -0
  57. data/vendor/depot_tools/cbuildbot +1 -0
  58. data/vendor/depot_tools/chrome_set_ver +1 -0
  59. data/vendor/depot_tools/cipd +247 -0
  60. data/vendor/depot_tools/cipd.bat +67 -0
  61. data/vendor/depot_tools/cipd_bin_setup.bat +6 -0
  62. data/vendor/depot_tools/cipd_bin_setup.sh +22 -0
  63. data/vendor/depot_tools/cipd_client_version +1 -0
  64. data/vendor/depot_tools/cipd_client_version.digests +22 -0
  65. data/vendor/depot_tools/cipd_manifest.txt +63 -0
  66. data/vendor/depot_tools/cipd_manifest.versions +438 -0
  67. data/vendor/depot_tools/cit +8 -0
  68. data/vendor/depot_tools/cit.bat +12 -0
  69. data/vendor/depot_tools/cit.py +167 -0
  70. data/vendor/depot_tools/clang-format +8 -0
  71. data/vendor/depot_tools/clang-format.bat +12 -0
  72. data/vendor/depot_tools/clang_format.py +79 -0
  73. data/vendor/depot_tools/clang_format_merge_driver +8 -0
  74. data/vendor/depot_tools/clang_format_merge_driver.bat +12 -0
  75. data/vendor/depot_tools/clang_format_merge_driver.py +69 -0
  76. data/vendor/depot_tools/codereview.settings +6 -0
  77. data/vendor/depot_tools/compile_single_file +8 -0
  78. data/vendor/depot_tools/compile_single_file.bat +11 -0
  79. data/vendor/depot_tools/compile_single_file.py +79 -0
  80. data/vendor/depot_tools/cpplint.bat +11 -0
  81. data/vendor/depot_tools/cpplint.py +6097 -0
  82. data/vendor/depot_tools/cpplint_chromium.py +50 -0
  83. data/vendor/depot_tools/cros +87 -0
  84. data/vendor/depot_tools/cros_sdk +1 -0
  85. data/vendor/depot_tools/crosjobs +13 -0
  86. data/vendor/depot_tools/detect_host_arch.py +55 -0
  87. data/vendor/depot_tools/dirmd +12 -0
  88. data/vendor/depot_tools/dirmd.bat +7 -0
  89. data/vendor/depot_tools/download_from_google_storage +8 -0
  90. data/vendor/depot_tools/download_from_google_storage.bat +12 -0
  91. data/vendor/depot_tools/download_from_google_storage.py +634 -0
  92. data/vendor/depot_tools/ensure_bootstrap +53 -0
  93. data/vendor/depot_tools/fetch +21 -0
  94. data/vendor/depot_tools/fetch.bat +28 -0
  95. data/vendor/depot_tools/fetch.py +319 -0
  96. data/vendor/depot_tools/fetch_configs/android.py +34 -0
  97. data/vendor/depot_tools/fetch_configs/android_internal.py +34 -0
  98. data/vendor/depot_tools/fetch_configs/breakpad.py +44 -0
  99. data/vendor/depot_tools/fetch_configs/chromium.py +66 -0
  100. data/vendor/depot_tools/fetch_configs/config_util.py +52 -0
  101. data/vendor/depot_tools/fetch_configs/crashpad.py +41 -0
  102. data/vendor/depot_tools/fetch_configs/dart.py +45 -0
  103. data/vendor/depot_tools/fetch_configs/depot_tools.py +44 -0
  104. data/vendor/depot_tools/fetch_configs/devtools-frontend.py +44 -0
  105. data/vendor/depot_tools/fetch_configs/goma_client.py +41 -0
  106. data/vendor/depot_tools/fetch_configs/gyp.py +41 -0
  107. data/vendor/depot_tools/fetch_configs/infra.py +40 -0
  108. data/vendor/depot_tools/fetch_configs/infra_internal.py +45 -0
  109. data/vendor/depot_tools/fetch_configs/inspector_protocol.py +40 -0
  110. data/vendor/depot_tools/fetch_configs/ios.py +34 -0
  111. data/vendor/depot_tools/fetch_configs/ios_internal.py +39 -0
  112. data/vendor/depot_tools/fetch_configs/nacl.py +48 -0
  113. data/vendor/depot_tools/fetch_configs/naclports.py +47 -0
  114. data/vendor/depot_tools/fetch_configs/node-ci.py +41 -0
  115. data/vendor/depot_tools/fetch_configs/pdfium.py +40 -0
  116. data/vendor/depot_tools/fetch_configs/skia.py +41 -0
  117. data/vendor/depot_tools/fetch_configs/skia_buildbot.py +41 -0
  118. data/vendor/depot_tools/fetch_configs/syzygy.py +41 -0
  119. data/vendor/depot_tools/fetch_configs/v8.py +44 -0
  120. data/vendor/depot_tools/fetch_configs/webrtc.py +52 -0
  121. data/vendor/depot_tools/fetch_configs/webrtc_android.py +34 -0
  122. data/vendor/depot_tools/fetch_configs/webrtc_ios.py +34 -0
  123. data/vendor/depot_tools/fix_encoding.py +385 -0
  124. data/vendor/depot_tools/gclient +38 -0
  125. data/vendor/depot_tools/gclient-new-workdir.py +124 -0
  126. data/vendor/depot_tools/gclient.bat +32 -0
  127. data/vendor/depot_tools/gclient.py +3198 -0
  128. data/vendor/depot_tools/gclient_completion.sh +76 -0
  129. data/vendor/depot_tools/gclient_eval.py +891 -0
  130. data/vendor/depot_tools/gclient_paths.py +152 -0
  131. data/vendor/depot_tools/gclient_scm.py +1615 -0
  132. data/vendor/depot_tools/gclient_utils.py +1280 -0
  133. data/vendor/depot_tools/gerrit_client.py +151 -0
  134. data/vendor/depot_tools/gerrit_util.py +996 -0
  135. data/vendor/depot_tools/git-cache +6 -0
  136. data/vendor/depot_tools/git-cl +6 -0
  137. data/vendor/depot_tools/git-crrev-parse +53 -0
  138. data/vendor/depot_tools/git-drover +6 -0
  139. data/vendor/depot_tools/git-find-releases +6 -0
  140. data/vendor/depot_tools/git-footers +6 -0
  141. data/vendor/depot_tools/git-freeze +8 -0
  142. data/vendor/depot_tools/git-gs +9 -0
  143. data/vendor/depot_tools/git-hyper-blame +6 -0
  144. data/vendor/depot_tools/git-map +6 -0
  145. data/vendor/depot_tools/git-map-branches +6 -0
  146. data/vendor/depot_tools/git-mark-merge-base +6 -0
  147. data/vendor/depot_tools/git-nav-downstream +6 -0
  148. data/vendor/depot_tools/git-nav-upstream +6 -0
  149. data/vendor/depot_tools/git-new-branch +6 -0
  150. data/vendor/depot_tools/git-number +6 -0
  151. data/vendor/depot_tools/git-rebase-update +6 -0
  152. data/vendor/depot_tools/git-rename-branch +6 -0
  153. data/vendor/depot_tools/git-reparent-branch +6 -0
  154. data/vendor/depot_tools/git-retry +8 -0
  155. data/vendor/depot_tools/git-runhooks +23 -0
  156. data/vendor/depot_tools/git-squash-branch +6 -0
  157. data/vendor/depot_tools/git-templates/description +3 -0
  158. data/vendor/depot_tools/git-templates/hooks/applypatch-msg +4 -0
  159. data/vendor/depot_tools/git-templates/hooks/post-applypatch +4 -0
  160. data/vendor/depot_tools/git-templates/hooks/post-checkout +4 -0
  161. data/vendor/depot_tools/git-templates/hooks/post-commit +4 -0
  162. data/vendor/depot_tools/git-templates/hooks/post-merge +4 -0
  163. data/vendor/depot_tools/git-templates/hooks/post-update +4 -0
  164. data/vendor/depot_tools/git-templates/hooks/pre-applypatch +4 -0
  165. data/vendor/depot_tools/git-templates/hooks/pre-auto-gc +4 -0
  166. data/vendor/depot_tools/git-templates/hooks/pre-commit +4 -0
  167. data/vendor/depot_tools/git-templates/hooks/pre-rebase +4 -0
  168. data/vendor/depot_tools/git-templates/hooks/prepare-commit-msg +4 -0
  169. data/vendor/depot_tools/git-templates/info/exclude +6 -0
  170. data/vendor/depot_tools/git-thaw +13 -0
  171. data/vendor/depot_tools/git-upstream-diff +9 -0
  172. data/vendor/depot_tools/git_cache.py +786 -0
  173. data/vendor/depot_tools/git_cl.py +5158 -0
  174. data/vendor/depot_tools/git_cl_completion.sh +48 -0
  175. data/vendor/depot_tools/git_common.py +1101 -0
  176. data/vendor/depot_tools/git_dates.py +62 -0
  177. data/vendor/depot_tools/git_drover.py +469 -0
  178. data/vendor/depot_tools/git_find_releases.py +67 -0
  179. data/vendor/depot_tools/git_footers.py +261 -0
  180. data/vendor/depot_tools/git_freezer.py +40 -0
  181. data/vendor/depot_tools/git_hyper_blame.py +391 -0
  182. data/vendor/depot_tools/git_map.py +166 -0
  183. data/vendor/depot_tools/git_map_branches.py +354 -0
  184. data/vendor/depot_tools/git_mark_merge_base.py +73 -0
  185. data/vendor/depot_tools/git_nav_downstream.py +69 -0
  186. data/vendor/depot_tools/git_new_branch.py +82 -0
  187. data/vendor/depot_tools/git_number.py +301 -0
  188. data/vendor/depot_tools/git_rebase_update.py +351 -0
  189. data/vendor/depot_tools/git_rename_branch.py +55 -0
  190. data/vendor/depot_tools/git_reparent_branch.py +101 -0
  191. data/vendor/depot_tools/git_retry.py +181 -0
  192. data/vendor/depot_tools/git_squash_branch.py +28 -0
  193. data/vendor/depot_tools/git_upstream_diff.py +64 -0
  194. data/vendor/depot_tools/gn +8 -0
  195. data/vendor/depot_tools/gn.bat +12 -0
  196. data/vendor/depot_tools/gn.py +78 -0
  197. data/vendor/depot_tools/goma_auth +12 -0
  198. data/vendor/depot_tools/goma_auth.bat +8 -0
  199. data/vendor/depot_tools/goma_ctl +12 -0
  200. data/vendor/depot_tools/goma_ctl.bat +8 -0
  201. data/vendor/depot_tools/gsutil.py +190 -0
  202. data/vendor/depot_tools/gsutil.py.bat +23 -0
  203. data/vendor/depot_tools/gsutil.vpython +120 -0
  204. data/vendor/depot_tools/infra/README.md +1 -0
  205. data/vendor/depot_tools/infra/config/OWNERS +7 -0
  206. data/vendor/depot_tools/infra/config/README.md +1 -0
  207. data/vendor/depot_tools/infra/config/recipes.cfg +26 -0
  208. data/vendor/depot_tools/led +12 -0
  209. data/vendor/depot_tools/led.bat +7 -0
  210. data/vendor/depot_tools/lockfile.py +116 -0
  211. data/vendor/depot_tools/luci-auth +13 -0
  212. data/vendor/depot_tools/luci-auth.bat +8 -0
  213. data/vendor/depot_tools/lucicfg +12 -0
  214. data/vendor/depot_tools/lucicfg.bat +7 -0
  215. data/vendor/depot_tools/mac_toolchain +12 -0
  216. data/vendor/depot_tools/man/html/depot_tools.html +934 -0
  217. data/vendor/depot_tools/man/html/depot_tools_tutorial.html +1593 -0
  218. data/vendor/depot_tools/man/html/git-cl.html +1033 -0
  219. data/vendor/depot_tools/man/html/git-drover.html +1048 -0
  220. data/vendor/depot_tools/man/html/git-footers.html +878 -0
  221. data/vendor/depot_tools/man/html/git-freeze.html +859 -0
  222. data/vendor/depot_tools/man/html/git-hyper-blame.html +878 -0
  223. data/vendor/depot_tools/man/html/git-map-branches.html +904 -0
  224. data/vendor/depot_tools/man/html/git-map.html +887 -0
  225. data/vendor/depot_tools/man/html/git-mark-merge-base.html +826 -0
  226. data/vendor/depot_tools/man/html/git-nav-downstream.html +844 -0
  227. data/vendor/depot_tools/man/html/git-nav-upstream.html +853 -0
  228. data/vendor/depot_tools/man/html/git-new-branch.html +932 -0
  229. data/vendor/depot_tools/man/html/git-rebase-update.html +961 -0
  230. data/vendor/depot_tools/man/html/git-rename-branch.html +794 -0
  231. data/vendor/depot_tools/man/html/git-reparent-branch.html +847 -0
  232. data/vendor/depot_tools/man/html/git-retry.html +858 -0
  233. data/vendor/depot_tools/man/html/git-squash-branch.html +881 -0
  234. data/vendor/depot_tools/man/html/git-thaw.html +794 -0
  235. data/vendor/depot_tools/man/html/git-upstream-diff.html +923 -0
  236. data/vendor/depot_tools/man/man1/git-cl.1 +198 -0
  237. data/vendor/depot_tools/man/man1/git-drover.1 +330 -0
  238. data/vendor/depot_tools/man/man1/git-footers.1 +144 -0
  239. data/vendor/depot_tools/man/man1/git-freeze.1 +113 -0
  240. data/vendor/depot_tools/man/man1/git-hyper-blame.1 +128 -0
  241. data/vendor/depot_tools/man/man1/git-map-branches.1 +210 -0
  242. data/vendor/depot_tools/man/man1/git-map.1 +179 -0
  243. data/vendor/depot_tools/man/man1/git-mark-merge-base.1 +69 -0
  244. data/vendor/depot_tools/man/man1/git-nav-downstream.1 +112 -0
  245. data/vendor/depot_tools/man/man1/git-nav-upstream.1 +122 -0
  246. data/vendor/depot_tools/man/man1/git-new-branch.1 +176 -0
  247. data/vendor/depot_tools/man/man1/git-rebase-update.1 +177 -0
  248. data/vendor/depot_tools/man/man1/git-rename-branch.1 +53 -0
  249. data/vendor/depot_tools/man/man1/git-reparent-branch.1 +93 -0
  250. data/vendor/depot_tools/man/man1/git-retry.1 +108 -0
  251. data/vendor/depot_tools/man/man1/git-squash-branch.1 +129 -0
  252. data/vendor/depot_tools/man/man1/git-thaw.1 +54 -0
  253. data/vendor/depot_tools/man/man1/git-upstream-diff.1 +153 -0
  254. data/vendor/depot_tools/man/man7/depot_tools.7 +139 -0
  255. data/vendor/depot_tools/man/man7/depot_tools_tutorial.7 +1061 -0
  256. data/vendor/depot_tools/man/push_to_gs.sh +4 -0
  257. data/vendor/depot_tools/man/src/.gitignore +5 -0
  258. data/vendor/depot_tools/man/src/_aliases.txt +5 -0
  259. data/vendor/depot_tools/man/src/_footer.txt +8 -0
  260. data/vendor/depot_tools/man/src/_git-cl_desc.helper.txt +1 -0
  261. data/vendor/depot_tools/man/src/_git-drover_desc.helper.txt +2 -0
  262. data/vendor/depot_tools/man/src/_git-footers_desc.helper.txt +1 -0
  263. data/vendor/depot_tools/man/src/_git-freeze_desc.helper.txt +1 -0
  264. data/vendor/depot_tools/man/src/_git-hyper-blame_desc.helper.txt +1 -0
  265. data/vendor/depot_tools/man/src/_git-map-branches_desc.helper.txt +4 -0
  266. data/vendor/depot_tools/man/src/_git-map_desc.helper.txt +3 -0
  267. data/vendor/depot_tools/man/src/_git-mark-merge-base_desc.helper.txt +1 -0
  268. data/vendor/depot_tools/man/src/_git-nav-downstream_desc.helper.txt +1 -0
  269. data/vendor/depot_tools/man/src/_git-nav-upstream_desc.helper.txt +1 -0
  270. data/vendor/depot_tools/man/src/_git-new-branch_desc.helper.txt +1 -0
  271. data/vendor/depot_tools/man/src/_git-rebase-update_desc.helper.txt +1 -0
  272. data/vendor/depot_tools/man/src/_git-rename-branch_desc.helper.txt +1 -0
  273. data/vendor/depot_tools/man/src/_git-reparent-branch_desc.helper.txt +1 -0
  274. data/vendor/depot_tools/man/src/_git-retry_desc.helper.txt +2 -0
  275. data/vendor/depot_tools/man/src/_git-squash-branch_desc.helper.txt +1 -0
  276. data/vendor/depot_tools/man/src/_git-thaw_desc.helper.txt +2 -0
  277. data/vendor/depot_tools/man/src/_git-upstream-diff_desc.helper.txt +1 -0
  278. data/vendor/depot_tools/man/src/_helper_prefix.txt +1 -0
  279. data/vendor/depot_tools/man/src/asciidoc-override.css +7 -0
  280. data/vendor/depot_tools/man/src/common_demo_functions.sh +84 -0
  281. data/vendor/depot_tools/man/src/demo_repo.sh +43 -0
  282. data/vendor/depot_tools/man/src/depot_tools.txt +28 -0
  283. data/vendor/depot_tools/man/src/depot_tools_tutorial.demo.walkthrough.sh +155 -0
  284. data/vendor/depot_tools/man/src/depot_tools_tutorial.txt +432 -0
  285. data/vendor/depot_tools/man/src/filter_demo_output.py +141 -0
  286. data/vendor/depot_tools/man/src/git-cl.txt +119 -0
  287. data/vendor/depot_tools/man/src/git-drover.demo.1.sh +22 -0
  288. data/vendor/depot_tools/man/src/git-drover.demo.2.sh +23 -0
  289. data/vendor/depot_tools/man/src/git-drover.demo.3.sh +27 -0
  290. data/vendor/depot_tools/man/src/git-drover.demo.4.sh +39 -0
  291. data/vendor/depot_tools/man/src/git-drover.demo.common.sh +19 -0
  292. data/vendor/depot_tools/man/src/git-drover.txt +102 -0
  293. data/vendor/depot_tools/man/src/git-footers.demo.1.sh +17 -0
  294. data/vendor/depot_tools/man/src/git-footers.txt +71 -0
  295. data/vendor/depot_tools/man/src/git-freeze.demo.1.sh +23 -0
  296. data/vendor/depot_tools/man/src/git-freeze.txt +54 -0
  297. data/vendor/depot_tools/man/src/git-hyper-blame.demo.1.sh +3 -0
  298. data/vendor/depot_tools/man/src/git-hyper-blame.demo.2.sh +4 -0
  299. data/vendor/depot_tools/man/src/git-hyper-blame.demo.common.sh +57 -0
  300. data/vendor/depot_tools/man/src/git-hyper-blame.txt +85 -0
  301. data/vendor/depot_tools/man/src/git-map-branches.demo.1.sh +8 -0
  302. data/vendor/depot_tools/man/src/git-map-branches.txt +64 -0
  303. data/vendor/depot_tools/man/src/git-map.demo.1.sh +3 -0
  304. data/vendor/depot_tools/man/src/git-map.txt +67 -0
  305. data/vendor/depot_tools/man/src/git-mark-merge-base.txt +46 -0
  306. data/vendor/depot_tools/man/src/git-nav-downstream.demo.1.sh +12 -0
  307. data/vendor/depot_tools/man/src/git-nav-downstream.txt +40 -0
  308. data/vendor/depot_tools/man/src/git-nav-upstream.demo.1.sh +12 -0
  309. data/vendor/depot_tools/man/src/git-nav-upstream.txt +39 -0
  310. data/vendor/depot_tools/man/src/git-new-branch.demo.1.sh +17 -0
  311. data/vendor/depot_tools/man/src/git-new-branch.txt +82 -0
  312. data/vendor/depot_tools/man/src/git-rebase-update.txt +141 -0
  313. data/vendor/depot_tools/man/src/git-rename-branch.txt +28 -0
  314. data/vendor/depot_tools/man/src/git-reparent-branch.txt +61 -0
  315. data/vendor/depot_tools/man/src/git-retry.txt +67 -0
  316. data/vendor/depot_tools/man/src/git-squash-branch.demo.1.sh +12 -0
  317. data/vendor/depot_tools/man/src/git-squash-branch.txt +59 -0
  318. data/vendor/depot_tools/man/src/git-thaw.txt +29 -0
  319. data/vendor/depot_tools/man/src/git-upstream-diff.txt +107 -0
  320. data/vendor/depot_tools/man/src/make_docs.sh +260 -0
  321. data/vendor/depot_tools/man/src/prep_demo_repo.sh +103 -0
  322. data/vendor/depot_tools/metrics.README.md +101 -0
  323. data/vendor/depot_tools/metrics.py +297 -0
  324. data/vendor/depot_tools/metrics_utils.py +293 -0
  325. data/vendor/depot_tools/my_activity.py +971 -0
  326. data/vendor/depot_tools/ninja +44 -0
  327. data/vendor/depot_tools/ninja-linux32 +0 -0
  328. data/vendor/depot_tools/ninja-linux64 +0 -0
  329. data/vendor/depot_tools/ninja-mac +0 -0
  330. data/vendor/depot_tools/ninja.exe +0 -0
  331. data/vendor/depot_tools/ninjalog.README.md +64 -0
  332. data/vendor/depot_tools/ninjalog_uploader.py +233 -0
  333. data/vendor/depot_tools/ninjalog_uploader_wrapper.py +125 -0
  334. data/vendor/depot_tools/owners.py +641 -0
  335. data/vendor/depot_tools/owners_finder.py +385 -0
  336. data/vendor/depot_tools/post_build_ninja_summary.py +350 -0
  337. data/vendor/depot_tools/presubmit_canned_checks.py +1655 -0
  338. data/vendor/depot_tools/presubmit_support.py +1923 -0
  339. data/vendor/depot_tools/profile.xml +8 -0
  340. data/vendor/depot_tools/prpc +13 -0
  341. data/vendor/depot_tools/prpc.bat +8 -0
  342. data/vendor/depot_tools/pylint +9 -0
  343. data/vendor/depot_tools/pylint-1.5 +78 -0
  344. data/vendor/depot_tools/pylint-1.6 +78 -0
  345. data/vendor/depot_tools/pylint-1.7 +78 -0
  346. data/vendor/depot_tools/pylint-1.8 +78 -0
  347. data/vendor/depot_tools/pylint-1.9 +78 -0
  348. data/vendor/depot_tools/pylint.bat +12 -0
  349. data/vendor/depot_tools/pylint_main.py +45 -0
  350. data/vendor/depot_tools/pylintrc +349 -0
  351. data/vendor/depot_tools/python-bin/python3 +7 -0
  352. data/vendor/depot_tools/python_runner.sh +60 -0
  353. data/vendor/depot_tools/rdb +12 -0
  354. data/vendor/depot_tools/rdb.bat +7 -0
  355. data/vendor/depot_tools/recipes/OWNERS +4 -0
  356. data/vendor/depot_tools/recipes/README.recipes.md +1079 -0
  357. data/vendor/depot_tools/recipes/recipe_modules/OWNERS +1 -0
  358. data/vendor/depot_tools/recipes/recipe_modules/bot_update/OWNERS +2 -0
  359. data/vendor/depot_tools/recipes/recipe_modules/bot_update/__init__.py +38 -0
  360. data/vendor/depot_tools/recipes/recipe_modules/bot_update/api.py +516 -0
  361. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic.json +117 -0
  362. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_luci.json +117 -0
  363. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_with_branch_heads.json +118 -0
  364. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/clobber.json +211 -0
  365. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/deprecated_got_revision_mapping.json +194 -0
  366. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_rebase_patch_ref.json +211 -0
  367. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_reset.json +211 -0
  368. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/input_commit_with_id_without_repo.json +210 -0
  369. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/multiple_patch_refs.json +214 -0
  370. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_apply_patch_on_gclient.json +265 -0
  371. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_HEAD.json +65 -0
  372. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_a_branch_head.json +65 -0
  373. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_a_specific_commit.json +65 -0
  374. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_master.json +65 -0
  375. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/refs.json +212 -0
  376. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/reset_root_solution_revision.json +210 -0
  377. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/resolve_chromium_fixed_version.json +117 -0
  378. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail.json +95 -0
  379. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch.json +209 -0
  380. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch_download.json +193 -0
  381. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle.json +265 -0
  382. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_branch_heads.json +261 -0
  383. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_feature_branch.json +261 -0
  384. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8_feature_branch.json +265 -0
  385. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_webrtc.json +265 -0
  386. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8.json +265 -0
  387. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8_head_by_default.json +265 -0
  388. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/unrecognized_commit_repo.json +8 -0
  389. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_tags.json +211 -0
  390. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.py +308 -0
  391. data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/__init__.py +0 -0
  392. data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/bot_update.py +1258 -0
  393. data/vendor/depot_tools/recipes/recipe_modules/bot_update/test_api.py +93 -0
  394. data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/do_not_retry_patch_failures_in_cq.py +42 -0
  395. data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/ensure_checkout.py +35 -0
  396. data/vendor/depot_tools/recipes/recipe_modules/cipd/__init__.py +9 -0
  397. data/vendor/depot_tools/recipes/recipe_modules/cipd/api.py +455 -0
  398. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic.json +403 -0
  399. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic_pkg.json +403 -0
  400. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-failed.json +82 -0
  401. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-many-instances.json +411 -0
  402. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/mac64.json +403 -0
  403. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_file.json +315 -0
  404. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_mode.json +313 -0
  405. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_verfile.json +313 -0
  406. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/win64.json +403 -0
  407. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.py +187 -0
  408. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk arch.json +5 -0
  409. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk bits.json +5 -0
  410. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_32.json +12 -0
  411. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_64.json +12 -0
  412. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_32.json +12 -0
  413. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_64.json +12 -0
  414. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_mips_64.json +12 -0
  415. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/mac_intel_64.json +12 -0
  416. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_32.json +12 -0
  417. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_64.json +12 -0
  418. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.py +59 -0
  419. data/vendor/depot_tools/recipes/recipe_modules/cipd/test_api.py +93 -0
  420. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/__init__.py +9 -0
  421. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/api.py +75 -0
  422. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic.json +83 -0
  423. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic_luci.json +83 -0
  424. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/win.json +83 -0
  425. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.py +55 -0
  426. data/vendor/depot_tools/recipes/recipe_modules/gclient/__init__.py +13 -0
  427. data/vendor/depot_tools/recipes/recipe_modules/gclient/api.py +428 -0
  428. data/vendor/depot_tools/recipes/recipe_modules/gclient/config.py +462 -0
  429. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/basic.json +238 -0
  430. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/revision.json +240 -0
  431. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/tryserver.json +238 -0
  432. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.py +95 -0
  433. data/vendor/depot_tools/recipes/recipe_modules/gclient/resources/diff_deps.py +16 -0
  434. data/vendor/depot_tools/recipes/recipe_modules/gclient/test_api.py +36 -0
  435. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/basic.json +55 -0
  436. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/dont have revision yet.json +84 -0
  437. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/no change, exception.json +83 -0
  438. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/windows.json +55 -0
  439. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.py +88 -0
  440. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/patch_project.py +92 -0
  441. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/sync_failure.py +24 -0
  442. data/vendor/depot_tools/recipes/recipe_modules/gerrit/__init__.py +8 -0
  443. data/vendor/depot_tools/recipes/recipe_modules/gerrit/api.py +178 -0
  444. data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.expected/basic.json +284 -0
  445. data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.py +73 -0
  446. data/vendor/depot_tools/recipes/recipe_modules/gerrit/test_api.py +53 -0
  447. data/vendor/depot_tools/recipes/recipe_modules/git/__init__.py +11 -0
  448. data/vendor/depot_tools/recipes/recipe_modules/git/api.py +405 -0
  449. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic.json +217 -0
  450. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_branch.json +217 -0
  451. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_file_name.json +219 -0
  452. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_hash.json +216 -0
  453. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_ref.json +217 -0
  454. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_submodule_update_force.json +218 -0
  455. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_tags.json +218 -0
  456. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/can_fail_build.json +164 -0
  457. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cannot_fail_build.json +220 -0
  458. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cat-file_test.json +239 -0
  459. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_delta.json +290 -0
  460. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_failed.json +220 -0
  461. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output.json +222 -0
  462. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output_fails_build.json +111 -0
  463. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/curl_trace_file.json +218 -0
  464. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/git-cache-checkout.json +265 -0
  465. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/platform_win.json +217 -0
  466. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/rebase_failed.json +221 -0
  467. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/remote_not_origin.json +219 -0
  468. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/set_got_revision.json +218 -0
  469. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.py +170 -0
  470. data/vendor/depot_tools/recipes/recipe_modules/git/resources/git_setup.py +52 -0
  471. data/vendor/depot_tools/recipes/recipe_modules/git/test_api.py +18 -0
  472. data/vendor/depot_tools/recipes/recipe_modules/git_cl/__init__.py +5 -0
  473. data/vendor/depot_tools/recipes/recipe_modules/git_cl/api.py +50 -0
  474. data/vendor/depot_tools/recipes/recipe_modules/git_cl/config.py +22 -0
  475. data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.expected/basic.json +105 -0
  476. data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.py +47 -0
  477. data/vendor/depot_tools/recipes/recipe_modules/gitiles/OWNERS +2 -0
  478. data/vendor/depot_tools/recipes/recipe_modules/gitiles/__init__.py +12 -0
  479. data/vendor/depot_tools/recipes/recipe_modules/gitiles/api.py +257 -0
  480. data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.expected/basic.json +596 -0
  481. data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.py +93 -0
  482. data/vendor/depot_tools/recipes/recipe_modules/gitiles/resources/gerrit_client.py +251 -0
  483. data/vendor/depot_tools/recipes/recipe_modules/gitiles/test_api.py +95 -0
  484. data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.expected/basic.json +5 -0
  485. data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.py +49 -0
  486. data/vendor/depot_tools/recipes/recipe_modules/gsutil/__init__.py +4 -0
  487. data/vendor/depot_tools/recipes/recipe_modules/gsutil/api.py +222 -0
  488. data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.expected/basic.json +247 -0
  489. data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.py +92 -0
  490. data/vendor/depot_tools/recipes/recipe_modules/gsutil/resources/gsutil_smart_retry.py +69 -0
  491. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/__init__.py +36 -0
  492. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/api.py +140 -0
  493. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/ancient_version.json +83 -0
  494. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/automatic_version.json +83 -0
  495. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/explicit_version.json +83 -0
  496. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/linux.json +21 -0
  497. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/mac.json +83 -0
  498. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/win.json +21 -0
  499. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.py +42 -0
  500. data/vendor/depot_tools/recipes/recipe_modules/presubmit/__init__.py +27 -0
  501. data/vendor/depot_tools/recipes/recipe_modules/presubmit/api.py +251 -0
  502. data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.expected/basic.json +27 -0
  503. data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.py +19 -0
  504. data/vendor/depot_tools/recipes/recipe_modules/presubmit/properties.proto +14 -0
  505. data/vendor/depot_tools/recipes/recipe_modules/presubmit/test_api.py +19 -0
  506. data/vendor/depot_tools/recipes/recipe_modules/presubmit/tests/execute.py +247 -0
  507. data/vendor/depot_tools/recipes/recipe_modules/presubmit/tests/prepare.py +49 -0
  508. data/vendor/depot_tools/recipes/recipe_modules/tryserver/__init__.py +18 -0
  509. data/vendor/depot_tools/recipes/recipe_modules/tryserver/api.py +264 -0
  510. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/basic_tags.json +57 -0
  511. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch.json +190 -0
  512. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch_and_target_ref.json +190 -0
  513. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch.json +21 -0
  514. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch_new.json +22 -0
  515. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.py +95 -0
  516. data/vendor/depot_tools/recipes/recipe_modules/tryserver/test_api.py +14 -0
  517. data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_fetch_ref_timeout.py +29 -0
  518. data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.expected/basic.json +5 -0
  519. data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.py +22 -0
  520. data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_target_ref.py +32 -0
  521. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/__init__.py +25 -0
  522. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/api.py +137 -0
  523. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/linux.json +21 -0
  524. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/mac.json +21 -0
  525. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/win.json +108 -0
  526. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.py +21 -0
  527. data/vendor/depot_tools/recipes/recipes.py +249 -0
  528. data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.expected/basic.json +175 -0
  529. data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.py +56 -0
  530. data/vendor/depot_tools/recipes/trigger_recipe_roller.txt +13 -0
  531. data/vendor/depot_tools/repo +1194 -0
  532. data/vendor/depot_tools/roll-dep +21 -0
  533. data/vendor/depot_tools/roll-dep.bat +21 -0
  534. data/vendor/depot_tools/roll_dep.py +282 -0
  535. data/vendor/depot_tools/scm.py +415 -0
  536. data/vendor/depot_tools/setup_color.py +130 -0
  537. data/vendor/depot_tools/split_cl.py +263 -0
  538. data/vendor/depot_tools/subcommand.py +261 -0
  539. data/vendor/depot_tools/subprocess2.py +258 -0
  540. data/vendor/depot_tools/third_party/__init__.py +5 -0
  541. data/vendor/depot_tools/third_party/colorama/LICENSE.txt +27 -0
  542. data/vendor/depot_tools/third_party/colorama/README.chromium +12 -0
  543. data/vendor/depot_tools/third_party/colorama/README.rst +346 -0
  544. data/vendor/depot_tools/third_party/colorama/__init__.py +6 -0
  545. data/vendor/depot_tools/third_party/colorama/ansi.py +102 -0
  546. data/vendor/depot_tools/third_party/colorama/ansitowin32.py +257 -0
  547. data/vendor/depot_tools/third_party/colorama/initialise.py +80 -0
  548. data/vendor/depot_tools/third_party/colorama/win32.py +152 -0
  549. data/vendor/depot_tools/third_party/colorama/winterm.py +169 -0
  550. data/vendor/depot_tools/third_party/coverage/AUTHORS.txt +43 -0
  551. data/vendor/depot_tools/third_party/coverage/PKG-INFO +41 -0
  552. data/vendor/depot_tools/third_party/coverage/README.chromium +13 -0
  553. data/vendor/depot_tools/third_party/coverage/__init__.py +120 -0
  554. data/vendor/depot_tools/third_party/coverage/__main__.py +4 -0
  555. data/vendor/depot_tools/third_party/coverage/annotate.py +101 -0
  556. data/vendor/depot_tools/third_party/coverage/backward.py +184 -0
  557. data/vendor/depot_tools/third_party/coverage/bytecode.py +75 -0
  558. data/vendor/depot_tools/third_party/coverage/cmdline.py +740 -0
  559. data/vendor/depot_tools/third_party/coverage/codeunit.py +145 -0
  560. data/vendor/depot_tools/third_party/coverage/collector.py +353 -0
  561. data/vendor/depot_tools/third_party/coverage/config.py +213 -0
  562. data/vendor/depot_tools/third_party/coverage/control.py +776 -0
  563. data/vendor/depot_tools/third_party/coverage/data.py +278 -0
  564. data/vendor/depot_tools/third_party/coverage/debug.py +54 -0
  565. data/vendor/depot_tools/third_party/coverage/execfile.py +171 -0
  566. data/vendor/depot_tools/third_party/coverage/files.py +309 -0
  567. data/vendor/depot_tools/third_party/coverage/fullcoverage/encodings.py +57 -0
  568. data/vendor/depot_tools/third_party/coverage/html.py +387 -0
  569. data/vendor/depot_tools/third_party/coverage/htmlfiles/coverage_html.js +376 -0
  570. data/vendor/depot_tools/third_party/coverage/htmlfiles/index.html +104 -0
  571. data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery-1.4.3.min.js +166 -0
  572. data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.hotkeys.js +99 -0
  573. data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.isonscreen.js +53 -0
  574. data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.min.js +166 -0
  575. data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.tablesorter.min.js +2 -0
  576. data/vendor/depot_tools/third_party/coverage/htmlfiles/keybd_closed.png +0 -0
  577. data/vendor/depot_tools/third_party/coverage/htmlfiles/keybd_open.png +0 -0
  578. data/vendor/depot_tools/third_party/coverage/htmlfiles/pyfile.html +90 -0
  579. data/vendor/depot_tools/third_party/coverage/htmlfiles/style.css +300 -0
  580. data/vendor/depot_tools/third_party/coverage/misc.py +163 -0
  581. data/vendor/depot_tools/third_party/coverage/parser.py +666 -0
  582. data/vendor/depot_tools/third_party/coverage/phystokens.py +208 -0
  583. data/vendor/depot_tools/third_party/coverage/report.py +92 -0
  584. data/vendor/depot_tools/third_party/coverage/results.py +286 -0
  585. data/vendor/depot_tools/third_party/coverage/summary.py +86 -0
  586. data/vendor/depot_tools/third_party/coverage/templite.py +166 -0
  587. data/vendor/depot_tools/third_party/coverage/version.py +9 -0
  588. data/vendor/depot_tools/third_party/coverage/xmlreport.py +155 -0
  589. data/vendor/depot_tools/third_party/httplib2/LICENSE +1339 -0
  590. data/vendor/depot_tools/third_party/httplib2/README.chromium +15 -0
  591. data/vendor/depot_tools/third_party/httplib2/__init__.py +1780 -0
  592. data/vendor/depot_tools/third_party/httplib2/cacerts.txt +2196 -0
  593. data/vendor/depot_tools/third_party/httplib2/iri2uri.py +110 -0
  594. data/vendor/depot_tools/third_party/httplib2/socks.py +448 -0
  595. data/vendor/depot_tools/third_party/repo/COPYING +202 -0
  596. data/vendor/depot_tools/third_party/repo/README.chromium +4 -0
  597. data/vendor/depot_tools/third_party/repo/__init__.py +0 -0
  598. data/vendor/depot_tools/third_party/repo/progress.py +117 -0
  599. data/vendor/depot_tools/third_party/retry_decorator/LICENSE.google +30 -0
  600. data/vendor/depot_tools/third_party/retry_decorator/__init__.py +0 -0
  601. data/vendor/depot_tools/third_party/retry_decorator/decorators.py +45 -0
  602. data/vendor/depot_tools/third_party/schema/.editorconfig +15 -0
  603. data/vendor/depot_tools/third_party/schema/.gitignore +174 -0
  604. data/vendor/depot_tools/third_party/schema/.travis.yml +37 -0
  605. data/vendor/depot_tools/third_party/schema/LICENSE-MIT +19 -0
  606. data/vendor/depot_tools/third_party/schema/MANIFEST.in +1 -0
  607. data/vendor/depot_tools/third_party/schema/README.chromium +12 -0
  608. data/vendor/depot_tools/third_party/schema/README.rst +382 -0
  609. data/vendor/depot_tools/third_party/schema/__init__.py +1 -0
  610. data/vendor/depot_tools/third_party/schema/schema.py +338 -0
  611. data/vendor/depot_tools/third_party/schema/setup.cfg +5 -0
  612. data/vendor/depot_tools/third_party/schema/setup.py +30 -0
  613. data/vendor/depot_tools/third_party/schema/test_schema.py +556 -0
  614. data/vendor/depot_tools/third_party/schema/tox.ini +33 -0
  615. data/vendor/depot_tools/third_party/six/LICENSE.txt +18 -0
  616. data/vendor/depot_tools/third_party/six/README.chromium +10 -0
  617. data/vendor/depot_tools/third_party/six/__init__.py +762 -0
  618. data/vendor/depot_tools/update_depot_tools +138 -0
  619. data/vendor/depot_tools/update_depot_tools.bat +65 -0
  620. data/vendor/depot_tools/update_depot_tools_toggle.py +38 -0
  621. data/vendor/depot_tools/upload_metrics.py +26 -0
  622. data/vendor/depot_tools/upload_to_google_storage.py +306 -0
  623. data/vendor/depot_tools/vpython +42 -0
  624. data/vendor/depot_tools/vpython.bat +7 -0
  625. data/vendor/depot_tools/vpython3 +55 -0
  626. data/vendor/depot_tools/vpython3.bat +12 -0
  627. data/vendor/depot_tools/watchlists.py +141 -0
  628. data/vendor/depot_tools/weekly +54 -0
  629. data/vendor/depot_tools/win32imports.py +61 -0
  630. data/vendor/depot_tools/win_toolchain/OWNERS +2 -0
  631. data/vendor/depot_tools/win_toolchain/README.md +74 -0
  632. data/vendor/depot_tools/win_toolchain/get_toolchain_if_necessary.py +599 -0
  633. data/vendor/depot_tools/win_toolchain/package_from_installed.py +524 -0
  634. data/vendor/depot_tools/wtf +81 -0
  635. data/vendor/depot_tools/yapf +21 -0
  636. data/vendor/depot_tools/yapf.bat +12 -0
  637. data/vendor/depot_tools/zsh-goodies/README +6 -0
  638. data/vendor/depot_tools/zsh-goodies/_gclient +14 -0
  639. metadata +729 -0
@@ -0,0 +1,151 @@
1
+ #!/usr/bin/python
2
+ # Copyright 2017 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
+ """Simple client for the Gerrit REST API.
7
+
8
+ Example usage:
9
+ ./gerrit_client.py [command] [args]""
10
+ """
11
+
12
+ from __future__ import print_function
13
+
14
+ import json
15
+ import logging
16
+ import optparse
17
+ import subcommand
18
+ import sys
19
+
20
+ if sys.version_info.major == 2:
21
+ import urlparse
22
+ from urllib import quote_plus
23
+ else:
24
+ from urllib.parse import quote_plus
25
+ import urllib.parse as urlparse
26
+
27
+ import fix_encoding
28
+ import gerrit_util
29
+ import setup_color
30
+
31
+ __version__ = '0.1'
32
+
33
+
34
+ def write_result(result, opt):
35
+ if opt.json_file:
36
+ with open(opt.json_file, 'w') as json_file:
37
+ json_file.write(json.dumps(result))
38
+
39
+
40
+ @subcommand.usage('[args ...]')
41
+ def CMDbranchinfo(parser, args):
42
+ parser.add_option('--branch', dest='branch', help='branch name')
43
+
44
+ (opt, args) = parser.parse_args(args)
45
+ host = urlparse.urlparse(opt.host).netloc
46
+ project = quote_plus(opt.project)
47
+ branch = quote_plus(opt.branch)
48
+ result = gerrit_util.GetGerritBranch(host, project, branch)
49
+ logging.info(result)
50
+ write_result(result, opt)
51
+
52
+
53
+ @subcommand.usage('[args ...]')
54
+ def CMDbranch(parser, args):
55
+ parser.add_option('--branch', dest='branch', help='branch name')
56
+ parser.add_option('--commit', dest='commit', help='commit hash')
57
+
58
+ (opt, args) = parser.parse_args(args)
59
+ assert opt.project, "--project not defined"
60
+ assert opt.branch, "--branch not defined"
61
+ assert opt.commit, "--commit not defined"
62
+
63
+ project = quote_plus(opt.project)
64
+ host = urlparse.urlparse(opt.host).netloc
65
+ branch = quote_plus(opt.branch)
66
+ commit = quote_plus(opt.commit)
67
+ result = gerrit_util.CreateGerritBranch(host, project, branch, commit)
68
+ logging.info(result)
69
+ write_result(result, opt)
70
+
71
+
72
+ @subcommand.usage('[args ...]')
73
+ def CMDchanges(parser, args):
74
+ parser.add_option('-p', '--param', dest='params', action='append',
75
+ help='repeatable query parameter, format: -p key=value')
76
+ parser.add_option('-o', '--o-param', dest='o_params', action='append',
77
+ help='gerrit output parameters, e.g. ALL_REVISIONS')
78
+ parser.add_option('--limit', dest='limit', type=int,
79
+ help='maximum number of results to return')
80
+ parser.add_option('--start', dest='start', type=int,
81
+ help='how many changes to skip '
82
+ '(starting with the most recent)')
83
+
84
+ (opt, args) = parser.parse_args(args)
85
+
86
+ result = gerrit_util.QueryChanges(
87
+ urlparse.urlparse(opt.host).netloc,
88
+ list(tuple(p.split('=', 1)) for p in opt.params),
89
+ start=opt.start, # Default: None
90
+ limit=opt.limit, # Default: None
91
+ o_params=opt.o_params, # Default: None
92
+ )
93
+ logging.info('Change query returned %d changes.', len(result))
94
+ write_result(result, opt)
95
+
96
+
97
+ @subcommand.usage('')
98
+ def CMDabandon(parser, args):
99
+ parser.add_option('-c', '--change', type=int, help='change number')
100
+ parser.add_option('-m', '--message', default='', help='reason for abandoning')
101
+
102
+ (opt, args) = parser.parse_args(args)
103
+ assert opt.change, "-c not defined"
104
+ result = gerrit_util.AbandonChange(
105
+ urlparse.urlparse(opt.host).netloc,
106
+ opt.change, opt.message)
107
+ logging.info(result)
108
+ write_result(result, opt)
109
+
110
+
111
+ class OptionParser(optparse.OptionParser):
112
+ """Creates the option parse and add --verbose support."""
113
+ def __init__(self, *args, **kwargs):
114
+ optparse.OptionParser.__init__(self, *args, version=__version__, **kwargs)
115
+ self.add_option(
116
+ '--verbose', action='count', default=0,
117
+ help='Use 2 times for more debugging info')
118
+ self.add_option('--host', dest='host', help='Url of host.')
119
+ self.add_option('--project', dest='project', help='project name')
120
+ self.add_option(
121
+ '--json_file', dest='json_file', help='output json filepath')
122
+
123
+ def parse_args(self, args=None, values=None):
124
+ options, args = optparse.OptionParser.parse_args(self, args, values)
125
+ # Host is always required
126
+ assert options.host, "--host not defined."
127
+ levels = [logging.WARNING, logging.INFO, logging.DEBUG]
128
+ logging.basicConfig(level=levels[min(options.verbose, len(levels) - 1)])
129
+ return options, args
130
+
131
+
132
+ def main(argv):
133
+ if sys.hexversion < 0x02060000:
134
+ print('\nYour python version %s is unsupported, please upgrade.\n'
135
+ % (sys.version.split(' ', 1)[0],),
136
+ file=sys.stderr)
137
+ return 2
138
+ dispatcher = subcommand.CommandDispatcher(__name__)
139
+ return dispatcher.execute(OptionParser(), argv)
140
+
141
+
142
+ if __name__ == '__main__':
143
+ # These affect sys.stdout so do it outside of main() to simplify mocks in
144
+ # unit testing.
145
+ fix_encoding.fix_encoding()
146
+ setup_color.init()
147
+ try:
148
+ sys.exit(main(sys.argv[1:]))
149
+ except KeyboardInterrupt:
150
+ sys.stderr.write('interrupted\n')
151
+ sys.exit(1)
@@ -0,0 +1,996 @@
1
+ # Copyright (c) 2013 The Chromium OS Authors. All rights reserved.
2
+ # Use of this source code is governed by a BSD-style license that can be
3
+ # found in the LICENSE file.
4
+
5
+ """
6
+ Utilities for requesting information for a Gerrit server via HTTPS.
7
+
8
+ https://gerrit-review.googlesource.com/Documentation/rest-api.html
9
+ """
10
+
11
+ from __future__ import print_function
12
+ from __future__ import unicode_literals
13
+
14
+ import base64
15
+ import contextlib
16
+ import httplib2
17
+ import json
18
+ import logging
19
+ import netrc
20
+ import os
21
+ import random
22
+ import re
23
+ import socket
24
+ import stat
25
+ import sys
26
+ import tempfile
27
+ import time
28
+ from multiprocessing.pool import ThreadPool
29
+
30
+ import auth
31
+ import gclient_utils
32
+ import metrics
33
+ import metrics_utils
34
+ import subprocess2
35
+
36
+ from third_party import six
37
+ from six.moves import urllib
38
+
39
+ if sys.version_info.major == 2:
40
+ import cookielib
41
+ from StringIO import StringIO
42
+ else:
43
+ import http.cookiejar as cookielib
44
+ from io import StringIO
45
+
46
+ LOGGER = logging.getLogger()
47
+ # With a starting sleep time of 10.0 seconds, x <= [1.8-2.2]x backoff, and five
48
+ # total tries, the sleep time between the first and last tries will be ~7 min.
49
+ TRY_LIMIT = 5
50
+ SLEEP_TIME = 10.0
51
+ MAX_BACKOFF = 2.2
52
+ MIN_BACKOFF = 1.8
53
+
54
+ # Controls the transport protocol used to communicate with Gerrit.
55
+ # This is parameterized primarily to enable GerritTestCase.
56
+ GERRIT_PROTOCOL = 'https'
57
+
58
+
59
+ def time_sleep(seconds):
60
+ # Use this so that it can be mocked in tests without interfering with python
61
+ # system machinery.
62
+ return time.sleep(seconds)
63
+
64
+
65
+ def time_time():
66
+ # Use this so that it can be mocked in tests without interfering with python
67
+ # system machinery.
68
+ return time.time()
69
+
70
+
71
+ class GerritError(Exception):
72
+ """Exception class for errors commuicating with the gerrit-on-borg service."""
73
+ def __init__(self, http_status, message, *args, **kwargs):
74
+ super(GerritError, self).__init__(*args, **kwargs)
75
+ self.http_status = http_status
76
+ self.message = '(%d) %s' % (self.http_status, message)
77
+
78
+
79
+ def _QueryString(params, first_param=None):
80
+ """Encodes query parameters in the key:val[+key:val...] format specified here:
81
+
82
+ https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-changes
83
+ """
84
+ q = [urllib.parse.quote(first_param)] if first_param else []
85
+ q.extend(['%s:%s' % (key, val) for key, val in params])
86
+ return '+'.join(q)
87
+
88
+
89
+ class Authenticator(object):
90
+ """Base authenticator class for authenticator implementations to subclass."""
91
+
92
+ def get_auth_header(self, host):
93
+ raise NotImplementedError()
94
+
95
+ @staticmethod
96
+ def get():
97
+ """Returns: (Authenticator) The identified Authenticator to use.
98
+
99
+ Probes the local system and its environment and identifies the
100
+ Authenticator instance to use.
101
+ """
102
+ # LUCI Context takes priority since it's normally present only on bots,
103
+ # which then must use it.
104
+ if LuciContextAuthenticator.is_luci():
105
+ return LuciContextAuthenticator()
106
+ # TODO(crbug.com/1059384): Automatically detect when running on cloudtop,
107
+ # and use CookiesAuthenticator instead.
108
+ if GceAuthenticator.is_gce():
109
+ return GceAuthenticator()
110
+ return CookiesAuthenticator()
111
+
112
+
113
+ class CookiesAuthenticator(Authenticator):
114
+ """Authenticator implementation that uses ".netrc" or ".gitcookies" for token.
115
+
116
+ Expected case for developer workstations.
117
+ """
118
+
119
+ _EMPTY = object()
120
+
121
+ def __init__(self):
122
+ # Credentials will be loaded lazily on first use. This ensures Authenticator
123
+ # get() can always construct an authenticator, even if something is broken.
124
+ # This allows 'creds-check' to proceed to actually checking creds later,
125
+ # rigorously (instead of blowing up with a cryptic error if they are wrong).
126
+ self._netrc = self._EMPTY
127
+ self._gitcookies = self._EMPTY
128
+
129
+ @property
130
+ def netrc(self):
131
+ if self._netrc is self._EMPTY:
132
+ self._netrc = self._get_netrc()
133
+ return self._netrc
134
+
135
+ @property
136
+ def gitcookies(self):
137
+ if self._gitcookies is self._EMPTY:
138
+ self._gitcookies = self._get_gitcookies()
139
+ return self._gitcookies
140
+
141
+ @classmethod
142
+ def get_new_password_url(cls, host):
143
+ assert not host.startswith('http')
144
+ # Assume *.googlesource.com pattern.
145
+ parts = host.split('.')
146
+ if not parts[0].endswith('-review'):
147
+ parts[0] += '-review'
148
+ return 'https://%s/new-password' % ('.'.join(parts))
149
+
150
+ @classmethod
151
+ def get_new_password_message(cls, host):
152
+ if host is None:
153
+ return ('Git host for Gerrit upload is unknown. Check your remote '
154
+ 'and the branch your branch is tracking. This tool assumes '
155
+ 'that you are using a git server at *.googlesource.com.')
156
+ url = cls.get_new_password_url(host)
157
+ return 'You can (re)generate your credentials by visiting %s' % url
158
+
159
+ @classmethod
160
+ def get_netrc_path(cls):
161
+ path = '_netrc' if sys.platform.startswith('win') else '.netrc'
162
+ return os.path.expanduser(os.path.join('~', path))
163
+
164
+ @classmethod
165
+ def _get_netrc(cls):
166
+ # Buffer the '.netrc' path. Use an empty file if it doesn't exist.
167
+ path = cls.get_netrc_path()
168
+ if not os.path.exists(path):
169
+ return netrc.netrc(os.devnull)
170
+
171
+ st = os.stat(path)
172
+ if st.st_mode & (stat.S_IRWXG | stat.S_IRWXO):
173
+ print(
174
+ 'WARNING: netrc file %s cannot be used because its file '
175
+ 'permissions are insecure. netrc file permissions should be '
176
+ '600.' % path, file=sys.stderr)
177
+ with open(path) as fd:
178
+ content = fd.read()
179
+
180
+ # Load the '.netrc' file. We strip comments from it because processing them
181
+ # can trigger a bug in Windows. See crbug.com/664664.
182
+ content = '\n'.join(l for l in content.splitlines()
183
+ if l.strip() and not l.strip().startswith('#'))
184
+ with tempdir() as tdir:
185
+ netrc_path = os.path.join(tdir, 'netrc')
186
+ with open(netrc_path, 'w') as fd:
187
+ fd.write(content)
188
+ os.chmod(netrc_path, (stat.S_IRUSR | stat.S_IWUSR))
189
+ return cls._get_netrc_from_path(netrc_path)
190
+
191
+ @classmethod
192
+ def _get_netrc_from_path(cls, path):
193
+ try:
194
+ return netrc.netrc(path)
195
+ except IOError:
196
+ print('WARNING: Could not read netrc file %s' % path, file=sys.stderr)
197
+ return netrc.netrc(os.devnull)
198
+ except netrc.NetrcParseError as e:
199
+ print('ERROR: Cannot use netrc file %s due to a parsing error: %s' %
200
+ (path, e), file=sys.stderr)
201
+ return netrc.netrc(os.devnull)
202
+
203
+ @classmethod
204
+ def get_gitcookies_path(cls):
205
+ if os.getenv('GIT_COOKIES_PATH'):
206
+ return os.getenv('GIT_COOKIES_PATH')
207
+ try:
208
+ path = subprocess2.check_output(
209
+ ['git', 'config', '--path', 'http.cookiefile'])
210
+ return path.decode('utf-8', 'ignore').strip()
211
+ except subprocess2.CalledProcessError:
212
+ return os.path.expanduser(os.path.join('~', '.gitcookies'))
213
+
214
+ @classmethod
215
+ def _get_gitcookies(cls):
216
+ gitcookies = {}
217
+ path = cls.get_gitcookies_path()
218
+ if not os.path.exists(path):
219
+ return gitcookies
220
+
221
+ try:
222
+ f = gclient_utils.FileRead(path, 'rb').splitlines()
223
+ except IOError:
224
+ return gitcookies
225
+
226
+ for line in f:
227
+ try:
228
+ fields = line.strip().split('\t')
229
+ if line.strip().startswith('#') or len(fields) != 7:
230
+ continue
231
+ domain, xpath, key, value = fields[0], fields[2], fields[5], fields[6]
232
+ if xpath == '/' and key == 'o':
233
+ if value.startswith('git-'):
234
+ login, secret_token = value.split('=', 1)
235
+ gitcookies[domain] = (login, secret_token)
236
+ else:
237
+ gitcookies[domain] = ('', value)
238
+ except (IndexError, ValueError, TypeError) as exc:
239
+ LOGGER.warning(exc)
240
+ return gitcookies
241
+
242
+ def _get_auth_for_host(self, host):
243
+ for domain, creds in self.gitcookies.items():
244
+ if cookielib.domain_match(host, domain):
245
+ return (creds[0], None, creds[1])
246
+ return self.netrc.authenticators(host)
247
+
248
+ def get_auth_header(self, host):
249
+ a = self._get_auth_for_host(host)
250
+ if a:
251
+ if a[0]:
252
+ secret = base64.b64encode(('%s:%s' % (a[0], a[2])).encode('utf-8'))
253
+ return 'Basic %s' % secret.decode('utf-8')
254
+ else:
255
+ return 'Bearer %s' % a[2]
256
+ return None
257
+
258
+ def get_auth_email(self, host):
259
+ """Best effort parsing of email to be used for auth for the given host."""
260
+ a = self._get_auth_for_host(host)
261
+ if not a:
262
+ return None
263
+ login = a[0]
264
+ # login typically looks like 'git-xxx.example.com'
265
+ if not login.startswith('git-') or '.' not in login:
266
+ return None
267
+ username, domain = login[len('git-'):].split('.', 1)
268
+ return '%s@%s' % (username, domain)
269
+
270
+
271
+ # Backwards compatibility just in case somebody imports this outside of
272
+ # depot_tools.
273
+ NetrcAuthenticator = CookiesAuthenticator
274
+
275
+
276
+ class GceAuthenticator(Authenticator):
277
+ """Authenticator implementation that uses GCE metadata service for token.
278
+ """
279
+
280
+ _INFO_URL = 'http://metadata.google.internal'
281
+ _ACQUIRE_URL = ('%s/computeMetadata/v1/instance/'
282
+ 'service-accounts/default/token' % _INFO_URL)
283
+ _ACQUIRE_HEADERS = {"Metadata-Flavor": "Google"}
284
+
285
+ _cache_is_gce = None
286
+ _token_cache = None
287
+ _token_expiration = None
288
+
289
+ @classmethod
290
+ def is_gce(cls):
291
+ if os.getenv('SKIP_GCE_AUTH_FOR_GIT'):
292
+ return False
293
+ if cls._cache_is_gce is None:
294
+ cls._cache_is_gce = cls._test_is_gce()
295
+ return cls._cache_is_gce
296
+
297
+ @classmethod
298
+ def _test_is_gce(cls):
299
+ # Based on https://cloud.google.com/compute/docs/metadata#runninggce
300
+ resp, _ = cls._get(cls._INFO_URL)
301
+ if resp is None:
302
+ return False
303
+ return resp.get('metadata-flavor') == 'Google'
304
+
305
+ @staticmethod
306
+ def _get(url, **kwargs):
307
+ next_delay_sec = 1.0
308
+ for i in range(TRY_LIMIT):
309
+ p = urllib.parse.urlparse(url)
310
+ if p.scheme not in ('http', 'https'):
311
+ raise RuntimeError(
312
+ "Don't know how to work with protocol '%s'" % protocol)
313
+ try:
314
+ resp, contents = httplib2.Http().request(url, 'GET', **kwargs)
315
+ except (socket.error, httplib2.HttpLib2Error) as e:
316
+ LOGGER.debug('GET [%s] raised %s', url, e)
317
+ return None, None
318
+ LOGGER.debug('GET [%s] #%d/%d (%d)', url, i+1, TRY_LIMIT, resp.status)
319
+ if resp.status < 500:
320
+ return (resp, contents)
321
+
322
+ # Retry server error status codes.
323
+ LOGGER.warn('Encountered server error')
324
+ if TRY_LIMIT - i > 1:
325
+ LOGGER.info('Will retry in %d seconds (%d more times)...',
326
+ next_delay_sec, TRY_LIMIT - i - 1)
327
+ time_sleep(next_delay_sec)
328
+ next_delay_sec *= random.uniform(MIN_BACKOFF, MAX_BACKOFF)
329
+ return None, None
330
+
331
+ @classmethod
332
+ def _get_token_dict(cls):
333
+ # If cached token is valid for at least 25 seconds, return it.
334
+ if cls._token_cache and time_time() + 25 < cls._token_expiration:
335
+ return cls._token_cache
336
+
337
+ resp, contents = cls._get(cls._ACQUIRE_URL, headers=cls._ACQUIRE_HEADERS)
338
+ if resp is None or resp.status != 200:
339
+ return None
340
+ cls._token_cache = json.loads(contents)
341
+ cls._token_expiration = cls._token_cache['expires_in'] + time_time()
342
+ return cls._token_cache
343
+
344
+ def get_auth_header(self, _host):
345
+ token_dict = self._get_token_dict()
346
+ if not token_dict:
347
+ return None
348
+ return '%(token_type)s %(access_token)s' % token_dict
349
+
350
+
351
+ class LuciContextAuthenticator(Authenticator):
352
+ """Authenticator implementation that uses LUCI_CONTEXT ambient local auth.
353
+ """
354
+
355
+ @staticmethod
356
+ def is_luci():
357
+ return auth.has_luci_context_local_auth()
358
+
359
+ def __init__(self):
360
+ self._authenticator = auth.Authenticator(
361
+ ' '.join([auth.OAUTH_SCOPE_EMAIL, auth.OAUTH_SCOPE_GERRIT]))
362
+
363
+ def get_auth_header(self, _host):
364
+ return 'Bearer %s' % self._authenticator.get_access_token().token
365
+
366
+
367
+ def CreateHttpConn(host, path, reqtype='GET', headers=None, body=None):
368
+ """Opens an HTTPS connection to a Gerrit service, and sends a request."""
369
+ headers = headers or {}
370
+ bare_host = host.partition(':')[0]
371
+
372
+ a = Authenticator.get()
373
+ # TODO(crbug.com/1059384): Automatically detect when running on cloudtop.
374
+ if isinstance(a, GceAuthenticator):
375
+ print('If you\'re on a cloudtop instance, export '
376
+ 'SKIP_GCE_AUTH_FOR_GIT=1 in your env.')
377
+
378
+ a = a.get_auth_header(bare_host)
379
+ if a:
380
+ headers.setdefault('Authorization', a)
381
+ else:
382
+ LOGGER.debug('No authorization found for %s.' % bare_host)
383
+
384
+ url = path
385
+ if not url.startswith('/'):
386
+ url = '/' + url
387
+ if 'Authorization' in headers and not url.startswith('/a/'):
388
+ url = '/a%s' % url
389
+
390
+ if body:
391
+ body = json.dumps(body, sort_keys=True)
392
+ headers.setdefault('Content-Type', 'application/json')
393
+ if LOGGER.isEnabledFor(logging.DEBUG):
394
+ LOGGER.debug('%s %s://%s%s' % (reqtype, GERRIT_PROTOCOL, host, url))
395
+ for key, val in headers.items():
396
+ if key == 'Authorization':
397
+ val = 'HIDDEN'
398
+ LOGGER.debug('%s: %s' % (key, val))
399
+ if body:
400
+ LOGGER.debug(body)
401
+ conn = httplib2.Http()
402
+ # HACK: httplib2.Http has no such attribute; we store req_host here for later
403
+ # use in ReadHttpResponse.
404
+ conn.req_host = host
405
+ conn.req_params = {
406
+ 'uri': urllib.parse.urljoin('%s://%s' % (GERRIT_PROTOCOL, host), url),
407
+ 'method': reqtype,
408
+ 'headers': headers,
409
+ 'body': body,
410
+ }
411
+ return conn
412
+
413
+
414
+ def ReadHttpResponse(conn, accept_statuses=frozenset([200])):
415
+ """Reads an HTTP response from a connection into a string buffer.
416
+
417
+ Args:
418
+ conn: An Http object created by CreateHttpConn above.
419
+ accept_statuses: Treat any of these statuses as success. Default: [200]
420
+ Common additions include 204, 400, and 404.
421
+ Returns: A string buffer containing the connection's reply.
422
+ """
423
+ sleep_time = SLEEP_TIME
424
+ for idx in range(TRY_LIMIT):
425
+ before_response = time.time()
426
+ response, contents = conn.request(**conn.req_params)
427
+ contents = contents.decode('utf-8', 'replace')
428
+
429
+ response_time = time.time() - before_response
430
+ metrics.collector.add_repeated(
431
+ 'http_requests',
432
+ metrics_utils.extract_http_metrics(
433
+ conn.req_params['uri'], conn.req_params['method'], response.status,
434
+ response_time))
435
+
436
+ # If response.status is an accepted status,
437
+ # or response.status < 500 then the result is final; break retry loop.
438
+ # If the response is 404/409 it might be because of replication lag,
439
+ # so keep trying anyway. If it is 429, it is generally ok to retry after
440
+ # a backoff.
441
+ if (response.status in accept_statuses
442
+ or response.status < 500 and response.status not in [404, 409, 429]):
443
+ LOGGER.debug('got response %d for %s %s', response.status,
444
+ conn.req_params['method'], conn.req_params['uri'])
445
+ # If 404 was in accept_statuses, then it's expected that the file might
446
+ # not exist, so don't return the gitiles error page because that's not
447
+ # the "content" that was actually requested.
448
+ if response.status == 404:
449
+ contents = ''
450
+ break
451
+
452
+ # A status >=500 is assumed to be a possible transient error; retry.
453
+ http_version = 'HTTP/%s' % ('1.1' if response.version == 11 else '1.0')
454
+ LOGGER.warn('A transient error occurred while querying %s:\n'
455
+ '%s %s %s\n'
456
+ '%s %d %s',
457
+ conn.req_host, conn.req_params['method'],
458
+ conn.req_params['uri'],
459
+ http_version, http_version, response.status, response.reason)
460
+
461
+ if idx < TRY_LIMIT - 1:
462
+ LOGGER.info('Will retry in %d seconds (%d more times)...',
463
+ sleep_time, TRY_LIMIT - idx - 1)
464
+ time_sleep(sleep_time)
465
+ sleep_time *= random.uniform(MIN_BACKOFF, MAX_BACKOFF)
466
+ # end of retries loop
467
+
468
+ if response.status in accept_statuses:
469
+ return StringIO(contents)
470
+
471
+ if response.status in (302, 401, 403):
472
+ www_authenticate = response.get('www-authenticate')
473
+ if not www_authenticate:
474
+ print('Your Gerrit credentials might be misconfigured.')
475
+ else:
476
+ auth_match = re.search('realm="([^"]+)"', www_authenticate, re.I)
477
+ host = auth_match.group(1) if auth_match else conn.req_host
478
+ print('Authentication failed. Please make sure your .gitcookies '
479
+ 'file has credentials for %s.' % host)
480
+ print('Try:\n git cl creds-check')
481
+
482
+ reason = '%s: %s' % (response.reason, contents)
483
+ raise GerritError(response.status, reason)
484
+
485
+
486
+ def ReadHttpJsonResponse(conn, accept_statuses=frozenset([200])):
487
+ """Parses an https response as json."""
488
+ fh = ReadHttpResponse(conn, accept_statuses)
489
+ # The first line of the response should always be: )]}'
490
+ s = fh.readline()
491
+ if s and s.rstrip() != ")]}'":
492
+ raise GerritError(200, 'Unexpected json output: %s' % s)
493
+ s = fh.read()
494
+ if not s:
495
+ return None
496
+ return json.loads(s)
497
+
498
+
499
+ def QueryChanges(host, params, first_param=None, limit=None, o_params=None,
500
+ start=None):
501
+ """
502
+ Queries a gerrit-on-borg server for changes matching query terms.
503
+
504
+ Args:
505
+ params: A list of key:value pairs for search parameters, as documented
506
+ here (e.g. ('is', 'owner') for a parameter 'is:owner'):
507
+ https://gerrit-review.googlesource.com/Documentation/user-search.html#search-operators
508
+ first_param: A change identifier
509
+ limit: Maximum number of results to return.
510
+ start: how many changes to skip (starting with the most recent)
511
+ o_params: A list of additional output specifiers, as documented here:
512
+ https://gerrit-review.googlesource.com/Documentation/rest-api-changes.html#list-changes
513
+
514
+ Returns:
515
+ A list of json-decoded query results.
516
+ """
517
+ # Note that no attempt is made to escape special characters; YMMV.
518
+ if not params and not first_param:
519
+ raise RuntimeError('QueryChanges requires search parameters')
520
+ path = 'changes/?q=%s' % _QueryString(params, first_param)
521
+ if start:
522
+ path = '%s&start=%s' % (path, start)
523
+ if limit:
524
+ path = '%s&n=%d' % (path, limit)
525
+ if o_params:
526
+ path = '%s&%s' % (path, '&'.join(['o=%s' % p for p in o_params]))
527
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
528
+
529
+
530
+ def GenerateAllChanges(host, params, first_param=None, limit=500,
531
+ o_params=None, start=None):
532
+ """Queries a gerrit-on-borg server for all the changes matching the query
533
+ terms.
534
+
535
+ WARNING: this is unreliable if a change matching the query is modified while
536
+ this function is being called.
537
+
538
+ A single query to gerrit-on-borg is limited on the number of results by the
539
+ limit parameter on the request (see QueryChanges) and the server maximum
540
+ limit.
541
+
542
+ Args:
543
+ params, first_param: Refer to QueryChanges().
544
+ limit: Maximum number of requested changes per query.
545
+ o_params: Refer to QueryChanges().
546
+ start: Refer to QueryChanges().
547
+
548
+ Returns:
549
+ A generator object to the list of returned changes.
550
+ """
551
+ already_returned = set()
552
+
553
+ def at_most_once(cls):
554
+ for cl in cls:
555
+ if cl['_number'] not in already_returned:
556
+ already_returned.add(cl['_number'])
557
+ yield cl
558
+
559
+ start = start or 0
560
+ cur_start = start
561
+ more_changes = True
562
+
563
+ while more_changes:
564
+ # This will fetch changes[start..start+limit] sorted by most recently
565
+ # updated. Since the rank of any change in this list can be changed any time
566
+ # (say user posting comment), subsequent calls may overalp like this:
567
+ # > initial order ABCDEFGH
568
+ # query[0..3] => ABC
569
+ # > E gets updated. New order: EABCDFGH
570
+ # query[3..6] => CDF # C is a dup
571
+ # query[6..9] => GH # E is missed.
572
+ page = QueryChanges(host, params, first_param, limit, o_params,
573
+ cur_start)
574
+ for cl in at_most_once(page):
575
+ yield cl
576
+
577
+ more_changes = [cl for cl in page if '_more_changes' in cl]
578
+ if len(more_changes) > 1:
579
+ raise GerritError(
580
+ 200,
581
+ 'Received %d changes with a _more_changes attribute set but should '
582
+ 'receive at most one.' % len(more_changes))
583
+ if more_changes:
584
+ cur_start += len(page)
585
+
586
+ # If we paged through, query again the first page which in most circumstances
587
+ # will fetch all changes that were modified while this function was run.
588
+ if start != cur_start:
589
+ page = QueryChanges(host, params, first_param, limit, o_params, start)
590
+ for cl in at_most_once(page):
591
+ yield cl
592
+
593
+
594
+ def MultiQueryChanges(host, params, change_list, limit=None, o_params=None,
595
+ start=None):
596
+ """Initiate a query composed of multiple sets of query parameters."""
597
+ if not change_list:
598
+ raise RuntimeError(
599
+ "MultiQueryChanges requires a list of change numbers/id's")
600
+ q = ['q=%s' % '+OR+'.join([urllib.parse.quote(str(x)) for x in change_list])]
601
+ if params:
602
+ q.append(_QueryString(params))
603
+ if limit:
604
+ q.append('n=%d' % limit)
605
+ if start:
606
+ q.append('S=%s' % start)
607
+ if o_params:
608
+ q.extend(['o=%s' % p for p in o_params])
609
+ path = 'changes/?%s' % '&'.join(q)
610
+ try:
611
+ result = ReadHttpJsonResponse(CreateHttpConn(host, path))
612
+ except GerritError as e:
613
+ msg = '%s:\n%s' % (e.message, path)
614
+ raise GerritError(e.http_status, msg)
615
+ return result
616
+
617
+
618
+ def GetGerritFetchUrl(host):
619
+ """Given a Gerrit host name returns URL of a Gerrit instance to fetch from."""
620
+ return '%s://%s/' % (GERRIT_PROTOCOL, host)
621
+
622
+
623
+ def GetCodeReviewTbrScore(host, project):
624
+ """Given a Gerrit host name and project, return the Code-Review score for TBR.
625
+ """
626
+ conn = CreateHttpConn(
627
+ host, '/projects/%s' % urllib.parse.quote(project, ''))
628
+ project = ReadHttpJsonResponse(conn)
629
+ if ('labels' not in project
630
+ or 'Code-Review' not in project['labels']
631
+ or 'values' not in project['labels']['Code-Review']):
632
+ return 1
633
+ return max([int(x) for x in project['labels']['Code-Review']['values']])
634
+
635
+
636
+ def GetChangePageUrl(host, change_number):
637
+ """Given a Gerrit host name and change number, returns change page URL."""
638
+ return '%s://%s/#/c/%d/' % (GERRIT_PROTOCOL, host, change_number)
639
+
640
+
641
+ def GetChangeUrl(host, change):
642
+ """Given a Gerrit host name and change ID, returns a URL for the change."""
643
+ return '%s://%s/a/changes/%s' % (GERRIT_PROTOCOL, host, change)
644
+
645
+
646
+ def GetChange(host, change):
647
+ """Queries a Gerrit server for information about a single change."""
648
+ path = 'changes/%s' % change
649
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
650
+
651
+
652
+ def GetChangeDetail(host, change, o_params=None):
653
+ """Queries a Gerrit server for extended information about a single change."""
654
+ path = 'changes/%s/detail' % change
655
+ if o_params:
656
+ path += '?%s' % '&'.join(['o=%s' % p for p in o_params])
657
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
658
+
659
+
660
+ def GetChangeCommit(host, change, revision='current'):
661
+ """Query a Gerrit server for a revision associated with a change."""
662
+ path = 'changes/%s/revisions/%s/commit?links' % (change, revision)
663
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
664
+
665
+
666
+ def GetChangeCurrentRevision(host, change):
667
+ """Get information about the latest revision for a given change."""
668
+ return QueryChanges(host, [], change, o_params=('CURRENT_REVISION',))
669
+
670
+
671
+ def GetChangeRevisions(host, change):
672
+ """Gets information about all revisions associated with a change."""
673
+ return QueryChanges(host, [], change, o_params=('ALL_REVISIONS',))
674
+
675
+
676
+ def GetChangeReview(host, change, revision=None):
677
+ """Gets the current review information for a change."""
678
+ if not revision:
679
+ jmsg = GetChangeRevisions(host, change)
680
+ if not jmsg:
681
+ return None
682
+ elif len(jmsg) > 1:
683
+ raise GerritError(200, 'Multiple changes found for ChangeId %s.' % change)
684
+ revision = jmsg[0]['current_revision']
685
+ path = 'changes/%s/revisions/%s/review'
686
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
687
+
688
+
689
+ def GetChangeComments(host, change):
690
+ """Get the line- and file-level comments on a change."""
691
+ path = 'changes/%s/comments' % change
692
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
693
+
694
+
695
+ def GetChangeRobotComments(host, change):
696
+ """Gets the line- and file-level robot comments on a change."""
697
+ path = 'changes/%s/robotcomments' % change
698
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
699
+
700
+
701
+ def AbandonChange(host, change, msg=''):
702
+ """Abandons a Gerrit change."""
703
+ path = 'changes/%s/abandon' % change
704
+ body = {'message': msg} if msg else {}
705
+ conn = CreateHttpConn(host, path, reqtype='POST', body=body)
706
+ return ReadHttpJsonResponse(conn)
707
+
708
+
709
+ def RestoreChange(host, change, msg=''):
710
+ """Restores a previously abandoned change."""
711
+ path = 'changes/%s/restore' % change
712
+ body = {'message': msg} if msg else {}
713
+ conn = CreateHttpConn(host, path, reqtype='POST', body=body)
714
+ return ReadHttpJsonResponse(conn)
715
+
716
+
717
+ def SubmitChange(host, change, wait_for_merge=True):
718
+ """Submits a Gerrit change via Gerrit."""
719
+ path = 'changes/%s/submit' % change
720
+ body = {'wait_for_merge': wait_for_merge}
721
+ conn = CreateHttpConn(host, path, reqtype='POST', body=body)
722
+ return ReadHttpJsonResponse(conn)
723
+
724
+
725
+ def HasPendingChangeEdit(host, change):
726
+ conn = CreateHttpConn(host, 'changes/%s/edit' % change)
727
+ try:
728
+ ReadHttpResponse(conn)
729
+ except GerritError as e:
730
+ # 204 No Content means no pending change.
731
+ if e.http_status == 204:
732
+ return False
733
+ raise
734
+ return True
735
+
736
+
737
+ def DeletePendingChangeEdit(host, change):
738
+ conn = CreateHttpConn(host, 'changes/%s/edit' % change, reqtype='DELETE')
739
+ # On success, Gerrit returns status 204; if the edit was already deleted it
740
+ # returns 404. Anything else is an error.
741
+ ReadHttpResponse(conn, accept_statuses=[204, 404])
742
+
743
+
744
+ def SetCommitMessage(host, change, description, notify='ALL'):
745
+ """Updates a commit message."""
746
+ assert notify in ('ALL', 'NONE')
747
+ path = 'changes/%s/message' % change
748
+ body = {'message': description, 'notify': notify}
749
+ conn = CreateHttpConn(host, path, reqtype='PUT', body=body)
750
+ try:
751
+ ReadHttpResponse(conn, accept_statuses=[200, 204])
752
+ except GerritError as e:
753
+ raise GerritError(
754
+ e.http_status,
755
+ 'Received unexpected http status while editing message '
756
+ 'in change %s' % change)
757
+
758
+
759
+ def GetReviewers(host, change):
760
+ """Gets information about all reviewers attached to a change."""
761
+ path = 'changes/%s/reviewers' % change
762
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
763
+
764
+
765
+ def GetReview(host, change, revision):
766
+ """Gets review information about a specific revision of a change."""
767
+ path = 'changes/%s/revisions/%s/review' % (change, revision)
768
+ return ReadHttpJsonResponse(CreateHttpConn(host, path))
769
+
770
+
771
+ def AddReviewers(host, change, reviewers=None, ccs=None, notify=True,
772
+ accept_statuses=frozenset([200, 400, 422])):
773
+ """Add reviewers to a change."""
774
+ if not reviewers and not ccs:
775
+ return None
776
+ if not change:
777
+ return None
778
+ reviewers = frozenset(reviewers or [])
779
+ ccs = frozenset(ccs or [])
780
+ path = 'changes/%s/revisions/current/review' % change
781
+
782
+ body = {
783
+ 'drafts': 'KEEP',
784
+ 'reviewers': [],
785
+ 'notify': 'ALL' if notify else 'NONE',
786
+ }
787
+ for r in sorted(reviewers | ccs):
788
+ state = 'REVIEWER' if r in reviewers else 'CC'
789
+ body['reviewers'].append({
790
+ 'reviewer': r,
791
+ 'state': state,
792
+ 'notify': 'NONE', # We handled `notify` argument above.
793
+ })
794
+
795
+ conn = CreateHttpConn(host, path, reqtype='POST', body=body)
796
+ # Gerrit will return 400 if one or more of the requested reviewers are
797
+ # unprocessable. We read the response object to see which were rejected,
798
+ # warn about them, and retry with the remainder.
799
+ resp = ReadHttpJsonResponse(conn, accept_statuses=accept_statuses)
800
+
801
+ errored = set()
802
+ for result in resp.get('reviewers', {}).values():
803
+ r = result.get('input')
804
+ state = 'REVIEWER' if r in reviewers else 'CC'
805
+ if result.get('error'):
806
+ errored.add(r)
807
+ LOGGER.warn('Note: "%s" not added as a %s' % (r, state.lower()))
808
+ if errored:
809
+ # Try again, adding only those that didn't fail, and only accepting 200.
810
+ AddReviewers(host, change, reviewers=(reviewers-errored),
811
+ ccs=(ccs-errored), notify=notify, accept_statuses=[200])
812
+
813
+
814
+ def SetReview(host, change, msg=None, labels=None, notify=None, ready=None):
815
+ """Sets labels and/or adds a message to a code review."""
816
+ if not msg and not labels:
817
+ return
818
+ path = 'changes/%s/revisions/current/review' % change
819
+ body = {'drafts': 'KEEP'}
820
+ if msg:
821
+ body['message'] = msg
822
+ if labels:
823
+ body['labels'] = labels
824
+ if notify is not None:
825
+ body['notify'] = 'ALL' if notify else 'NONE'
826
+ if ready:
827
+ body['ready'] = True
828
+ conn = CreateHttpConn(host, path, reqtype='POST', body=body)
829
+ response = ReadHttpJsonResponse(conn)
830
+ if labels:
831
+ for key, val in labels.items():
832
+ if ('labels' not in response or key not in response['labels'] or
833
+ int(response['labels'][key] != int(val))):
834
+ raise GerritError(200, 'Unable to set "%s" label on change %s.' % (
835
+ key, change))
836
+
837
+
838
+ def ResetReviewLabels(host, change, label, value='0', message=None,
839
+ notify=None):
840
+ """Resets the value of a given label for all reviewers on a change."""
841
+ # This is tricky, because we want to work on the "current revision", but
842
+ # there's always the risk that "current revision" will change in between
843
+ # API calls. So, we check "current revision" at the beginning and end; if
844
+ # it has changed, raise an exception.
845
+ jmsg = GetChangeCurrentRevision(host, change)
846
+ if not jmsg:
847
+ raise GerritError(
848
+ 200, 'Could not get review information for change "%s"' % change)
849
+ value = str(value)
850
+ revision = jmsg[0]['current_revision']
851
+ path = 'changes/%s/revisions/%s/review' % (change, revision)
852
+ message = message or (
853
+ '%s label set to %s programmatically.' % (label, value))
854
+ jmsg = GetReview(host, change, revision)
855
+ if not jmsg:
856
+ raise GerritError(200, 'Could not get review information for revision %s '
857
+ 'of change %s' % (revision, change))
858
+ for review in jmsg.get('labels', {}).get(label, {}).get('all', []):
859
+ if str(review.get('value', value)) != value:
860
+ body = {
861
+ 'drafts': 'KEEP',
862
+ 'message': message,
863
+ 'labels': {label: value},
864
+ 'on_behalf_of': review['_account_id'],
865
+ }
866
+ if notify:
867
+ body['notify'] = notify
868
+ conn = CreateHttpConn(
869
+ host, path, reqtype='POST', body=body)
870
+ response = ReadHttpJsonResponse(conn)
871
+ if str(response['labels'][label]) != value:
872
+ username = review.get('email', jmsg.get('name', ''))
873
+ raise GerritError(200, 'Unable to set %s label for user "%s"'
874
+ ' on change %s.' % (label, username, change))
875
+ jmsg = GetChangeCurrentRevision(host, change)
876
+ if not jmsg:
877
+ raise GerritError(
878
+ 200, 'Could not get review information for change "%s"' % change)
879
+ elif jmsg[0]['current_revision'] != revision:
880
+ raise GerritError(200, 'While resetting labels on change "%s", '
881
+ 'a new patchset was uploaded.' % change)
882
+
883
+
884
+ def CreateGerritBranch(host, project, branch, commit):
885
+ """Creates a new branch from given project and commit
886
+
887
+ https://gerrit-review.googlesource.com/Documentation/rest-api-projects.html#create-branch
888
+
889
+ Returns:
890
+ A JSON object with 'ref' key.
891
+ """
892
+ path = 'projects/%s/branches/%s' % (project, branch)
893
+ body = {'revision': commit}
894
+ conn = CreateHttpConn(host, path, reqtype='PUT', body=body)
895
+ response = ReadHttpJsonResponse(conn, accept_statuses=[201])
896
+ if response:
897
+ return response
898
+ raise GerritError(200, 'Unable to create gerrit branch')
899
+
900
+
901
+ def GetGerritBranch(host, project, branch):
902
+ """Gets a branch from given project and commit.
903
+
904
+ See:
905
+ https://gerrit-review.googlesource.com/Documentation/rest-api-projects.html#get-branch
906
+
907
+ Returns:
908
+ A JSON object with 'revision' key.
909
+ """
910
+ path = 'projects/%s/branches/%s' % (project, branch)
911
+ conn = CreateHttpConn(host, path, reqtype='GET')
912
+ response = ReadHttpJsonResponse(conn)
913
+ if response:
914
+ return response
915
+ raise GerritError(200, 'Unable to get gerrit branch')
916
+
917
+
918
+ def GetAccountDetails(host, account_id='self'):
919
+ """Returns details of the account.
920
+
921
+ If account_id is not given, uses magic value 'self' which corresponds to
922
+ whichever account user is authenticating as.
923
+
924
+ Documentation:
925
+ https://gerrit-review.googlesource.com/Documentation/rest-api-accounts.html#get-account
926
+
927
+ Returns None if account is not found (i.e., Gerrit returned 404).
928
+ """
929
+ conn = CreateHttpConn(host, '/accounts/%s' % account_id)
930
+ return ReadHttpJsonResponse(conn, accept_statuses=[200, 404])
931
+
932
+
933
+ def ValidAccounts(host, accounts, max_threads=10):
934
+ """Returns a mapping from valid account to its details.
935
+
936
+ Invalid accounts, either not existing or without unique match,
937
+ are not present as returned dictionary keys.
938
+ """
939
+ assert not isinstance(accounts, str), type(accounts)
940
+ accounts = list(set(accounts))
941
+ if not accounts:
942
+ return {}
943
+
944
+ def get_one(account):
945
+ try:
946
+ return account, GetAccountDetails(host, account)
947
+ except GerritError:
948
+ return None, None
949
+
950
+ valid = {}
951
+ with contextlib.closing(ThreadPool(min(max_threads, len(accounts)))) as pool:
952
+ for account, details in pool.map(get_one, accounts):
953
+ if account and details:
954
+ valid[account] = details
955
+ return valid
956
+
957
+
958
+ def PercentEncodeForGitRef(original):
959
+ """Applies percent-encoding for strings sent to Gerrit via git ref metadata.
960
+
961
+ The encoding used is based on but stricter than URL encoding (Section 2.1 of
962
+ RFC 3986). The only non-escaped characters are alphanumerics, and 'SPACE'
963
+ (U+0020) can be represented as 'LOW LINE' (U+005F) or 'PLUS SIGN' (U+002B).
964
+
965
+ For more information, see the Gerrit docs here:
966
+
967
+ https://gerrit-review.googlesource.com/Documentation/user-upload.html#message
968
+ """
969
+ safe = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 '
970
+ encoded = ''.join(c if c in safe else '%%%02X' % ord(c) for c in original)
971
+
972
+ # Spaces are not allowed in git refs; gerrit will interpret either '_' or
973
+ # '+' (or '%20') as space. Use '_' since that has been supported the longest.
974
+ return encoded.replace(' ', '_')
975
+
976
+
977
+ @contextlib.contextmanager
978
+ def tempdir():
979
+ tdir = None
980
+ try:
981
+ tdir = tempfile.mkdtemp(suffix='gerrit_util')
982
+ yield tdir
983
+ finally:
984
+ if tdir:
985
+ gclient_utils.rmtree(tdir)
986
+
987
+
988
+ def ChangeIdentifier(project, change_number):
989
+ """Returns change identifier "project~number" suitable for |change| arg of
990
+ this module API.
991
+
992
+ Such format is allows for more efficient Gerrit routing of HTTP requests,
993
+ comparing to specifying just change_number.
994
+ """
995
+ assert int(change_number)
996
+ return '%s~%s' % (urllib.parse.quote(project, ''), change_number)