rubygems-update 2.6.11 → 2.7.11

Sign up to get free protection for your applications and to get access to all the features.
Files changed (405) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +8 -22
  3. data/CONTRIBUTING.rdoc +53 -54
  4. data/History.txt +405 -0
  5. data/Manifest.txt +46 -15
  6. data/POLICIES.rdoc +3 -3
  7. data/README.md +72 -0
  8. data/Rakefile +55 -12
  9. data/appveyor.yml +29 -1
  10. data/bin/gem +1 -1
  11. data/bin/update_rubygems +2 -2
  12. data/bundler/CHANGELOG.md +412 -9
  13. data/bundler/CODE_OF_CONDUCT.md +1 -1
  14. data/bundler/CONTRIBUTING.md +10 -29
  15. data/bundler/README.md +27 -11
  16. data/bundler/bundler.gemspec +58 -0
  17. data/bundler/exe/bundle +5 -7
  18. data/bundler/exe/bundle_ruby +4 -3
  19. data/bundler/lib/bundler.rb +103 -79
  20. data/bundler/lib/bundler/build_metadata.rb +53 -0
  21. data/bundler/lib/bundler/capistrano.rb +5 -0
  22. data/bundler/lib/bundler/cli.rb +231 -66
  23. data/bundler/lib/bundler/cli/add.rb +25 -0
  24. data/bundler/lib/bundler/cli/binstubs.rb +9 -7
  25. data/bundler/lib/bundler/cli/cache.rb +5 -4
  26. data/bundler/lib/bundler/cli/check.rb +3 -5
  27. data/bundler/lib/bundler/cli/clean.rb +5 -6
  28. data/bundler/lib/bundler/cli/common.rb +18 -2
  29. data/bundler/lib/bundler/cli/config.rb +26 -7
  30. data/bundler/lib/bundler/cli/console.rb +2 -1
  31. data/bundler/lib/bundler/cli/doctor.rb +1 -0
  32. data/bundler/lib/bundler/cli/exec.rb +6 -5
  33. data/bundler/lib/bundler/cli/gem.rb +42 -18
  34. data/bundler/lib/bundler/cli/info.rb +50 -0
  35. data/bundler/lib/bundler/cli/init.rb +21 -7
  36. data/bundler/lib/bundler/cli/inject.rb +13 -4
  37. data/bundler/lib/bundler/cli/install.rb +61 -77
  38. data/bundler/lib/bundler/cli/issue.rb +40 -0
  39. data/bundler/lib/bundler/cli/list.rb +22 -0
  40. data/bundler/lib/bundler/cli/lock.rb +4 -2
  41. data/bundler/lib/bundler/cli/open.rb +2 -2
  42. data/bundler/lib/bundler/cli/outdated.rb +30 -28
  43. data/bundler/lib/bundler/cli/package.rb +9 -6
  44. data/bundler/lib/bundler/cli/platform.rb +1 -0
  45. data/bundler/lib/bundler/cli/plugin.rb +1 -0
  46. data/bundler/lib/bundler/cli/pristine.rb +43 -0
  47. data/bundler/lib/bundler/cli/show.rb +1 -1
  48. data/bundler/lib/bundler/cli/update.rb +36 -13
  49. data/bundler/lib/bundler/cli/viz.rb +5 -1
  50. data/bundler/lib/bundler/compact_index_client.rb +1 -0
  51. data/bundler/lib/bundler/compact_index_client/cache.rb +1 -2
  52. data/bundler/lib/bundler/compact_index_client/updater.rb +36 -8
  53. data/bundler/lib/bundler/compatibility_guard.rb +14 -0
  54. data/bundler/lib/bundler/constants.rb +1 -0
  55. data/bundler/lib/bundler/current_ruby.rb +16 -8
  56. data/bundler/lib/bundler/definition.rb +252 -170
  57. data/bundler/lib/bundler/dep_proxy.rb +3 -1
  58. data/bundler/lib/bundler/dependency.rb +7 -7
  59. data/bundler/lib/bundler/deployment.rb +1 -1
  60. data/bundler/lib/bundler/deprecate.rb +15 -3
  61. data/bundler/lib/bundler/dsl.rb +103 -62
  62. data/bundler/lib/bundler/endpoint_specification.rb +13 -3
  63. data/bundler/lib/bundler/env.rb +101 -38
  64. data/bundler/lib/bundler/environment_preserver.rb +27 -6
  65. data/bundler/lib/bundler/errors.rb +3 -1
  66. data/bundler/lib/bundler/feature_flag.rb +39 -4
  67. data/bundler/lib/bundler/fetcher.rb +18 -11
  68. data/bundler/lib/bundler/fetcher/base.rb +1 -0
  69. data/bundler/lib/bundler/fetcher/compact_index.rb +2 -12
  70. data/bundler/lib/bundler/fetcher/dependency.rb +2 -1
  71. data/bundler/lib/bundler/fetcher/downloader.rb +14 -7
  72. data/bundler/lib/bundler/fetcher/index.rb +3 -2
  73. data/bundler/lib/bundler/friendly_errors.rb +7 -2
  74. data/bundler/lib/bundler/gem_helper.rb +24 -10
  75. data/bundler/lib/bundler/gem_helpers.rb +1 -0
  76. data/bundler/lib/bundler/gem_remote_fetcher.rb +1 -0
  77. data/bundler/lib/bundler/gem_tasks.rb +1 -0
  78. data/bundler/lib/bundler/gem_version_promoter.rb +13 -0
  79. data/bundler/lib/bundler/gemdeps.rb +1 -0
  80. data/bundler/lib/bundler/graph.rb +1 -0
  81. data/bundler/lib/bundler/index.rb +19 -11
  82. data/bundler/lib/bundler/injector.rb +54 -30
  83. data/bundler/lib/bundler/inline.rb +10 -10
  84. data/bundler/lib/bundler/installer.rb +114 -52
  85. data/bundler/lib/bundler/installer/gem_installer.rb +14 -4
  86. data/bundler/lib/bundler/installer/parallel_installer.rb +91 -42
  87. data/bundler/lib/bundler/installer/standalone.rb +1 -0
  88. data/bundler/lib/bundler/lazy_specification.rb +17 -4
  89. data/bundler/lib/bundler/lockfile_generator.rb +95 -0
  90. data/bundler/lib/bundler/lockfile_parser.rb +49 -35
  91. data/bundler/lib/bundler/match_platform.rb +1 -0
  92. data/bundler/lib/bundler/mirror.rb +10 -5
  93. data/bundler/lib/bundler/plugin.rb +8 -3
  94. data/bundler/lib/bundler/plugin/api/source.rb +16 -3
  95. data/bundler/lib/bundler/plugin/index.rb +9 -2
  96. data/bundler/lib/bundler/plugin/installer.rb +7 -6
  97. data/bundler/lib/bundler/plugin/source_list.rb +7 -8
  98. data/bundler/lib/bundler/process_lock.rb +24 -0
  99. data/bundler/lib/bundler/psyched_yaml.rb +10 -0
  100. data/bundler/lib/bundler/remote_specification.rb +25 -1
  101. data/bundler/lib/bundler/resolver.rb +176 -193
  102. data/bundler/lib/bundler/resolver/spec_group.rb +106 -0
  103. data/bundler/lib/bundler/retry.rb +1 -0
  104. data/bundler/lib/bundler/ruby_dsl.rb +1 -0
  105. data/bundler/lib/bundler/ruby_version.rb +7 -2
  106. data/bundler/lib/bundler/rubygems_ext.rb +18 -8
  107. data/bundler/lib/bundler/rubygems_gem_installer.rb +25 -2
  108. data/bundler/lib/bundler/rubygems_integration.rb +166 -69
  109. data/bundler/lib/bundler/runtime.rb +29 -19
  110. data/bundler/lib/bundler/settings.rb +202 -87
  111. data/bundler/lib/bundler/settings/validator.rb +79 -0
  112. data/bundler/lib/bundler/setup.rb +4 -7
  113. data/bundler/lib/bundler/shared_helpers.rb +143 -27
  114. data/bundler/lib/bundler/similarity_detector.rb +1 -0
  115. data/bundler/lib/bundler/source.rb +53 -1
  116. data/bundler/lib/bundler/source/gemspec.rb +1 -0
  117. data/bundler/lib/bundler/source/git.rb +51 -22
  118. data/bundler/lib/bundler/source/git/git_proxy.rb +23 -13
  119. data/bundler/lib/bundler/source/metadata.rb +63 -0
  120. data/bundler/lib/bundler/source/path.rb +38 -17
  121. data/bundler/lib/bundler/source/path/installer.rb +4 -2
  122. data/bundler/lib/bundler/source/rubygems.rb +161 -82
  123. data/bundler/lib/bundler/source/rubygems/remote.rb +12 -2
  124. data/bundler/lib/bundler/source_list.rb +75 -15
  125. data/bundler/lib/bundler/spec_set.rb +37 -21
  126. data/bundler/lib/bundler/ssl_certs/certificate_manager.rb +2 -1
  127. data/bundler/lib/bundler/stub_specification.rb +86 -2
  128. data/bundler/lib/bundler/templates/.document +1 -0
  129. data/bundler/lib/bundler/templates/Executable +13 -1
  130. data/bundler/lib/bundler/templates/Executable.bundler +105 -0
  131. data/bundler/lib/bundler/templates/Executable.standalone +5 -5
  132. data/bundler/lib/bundler/templates/Gemfile +3 -0
  133. data/bundler/lib/bundler/templates/gems.rb +8 -0
  134. data/bundler/lib/bundler/templates/newgem/Gemfile.tt +4 -2
  135. data/bundler/lib/bundler/templates/newgem/LICENSE.txt.tt +1 -1
  136. data/bundler/lib/bundler/templates/newgem/README.md.tt +14 -8
  137. data/bundler/lib/bundler/templates/newgem/Rakefile.tt +5 -5
  138. data/bundler/lib/bundler/templates/newgem/ext/newgem/newgem.c.tt +4 -4
  139. data/bundler/lib/bundler/templates/newgem/ext/newgem/newgem.h.tt +3 -3
  140. data/bundler/lib/bundler/templates/newgem/gitignore.tt +0 -1
  141. data/bundler/lib/bundler/templates/newgem/lib/newgem.rb.tt +6 -6
  142. data/bundler/lib/bundler/templates/newgem/lib/newgem/version.rb.tt +4 -4
  143. data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +21 -12
  144. data/bundler/lib/bundler/templates/newgem/rspec.tt +1 -0
  145. data/bundler/lib/bundler/templates/newgem/spec/newgem_spec.rb.tt +0 -2
  146. data/bundler/lib/bundler/templates/newgem/spec/spec_helper.rb.tt +3 -0
  147. data/bundler/lib/bundler/templates/newgem/test/newgem_test.rb.tt +1 -1
  148. data/bundler/lib/bundler/templates/newgem/test/test_helper.rb.tt +3 -3
  149. data/bundler/lib/bundler/templates/newgem/{.travis.yml.tt → travis.yml.tt} +2 -0
  150. data/bundler/lib/bundler/ui.rb +1 -0
  151. data/bundler/lib/bundler/ui/rg_proxy.rb +1 -0
  152. data/bundler/lib/bundler/ui/shell.rb +26 -10
  153. data/bundler/lib/bundler/ui/silent.rb +12 -1
  154. data/bundler/lib/bundler/uri_credentials_filter.rb +1 -0
  155. data/bundler/lib/bundler/vendor/fileutils/lib/fileutils.rb +1638 -0
  156. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo.rb +2 -0
  157. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/compatibility.rb +26 -0
  158. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/resolution_state.rb +7 -0
  159. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +1 -0
  160. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +16 -5
  161. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/action.rb +1 -0
  162. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +10 -2
  163. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +1 -0
  164. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +1 -0
  165. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +1 -0
  166. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +1 -0
  167. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +1 -0
  168. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +1 -0
  169. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +16 -5
  170. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +75 -7
  171. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +2 -1
  172. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +1 -0
  173. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/ui.rb +3 -1
  174. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +501 -138
  175. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +1 -0
  176. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/state.rb +8 -4
  177. data/bundler/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +3 -1
  178. data/bundler/lib/bundler/vendor/thor/lib/thor.rb +46 -21
  179. data/bundler/lib/bundler/vendor/thor/lib/thor/actions.rb +24 -22
  180. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_file.rb +2 -1
  181. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_link.rb +2 -1
  182. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/directory.rb +2 -2
  183. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/empty_directory.rb +16 -8
  184. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +66 -18
  185. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +17 -15
  186. data/bundler/lib/bundler/vendor/thor/lib/thor/base.rb +55 -32
  187. data/bundler/lib/bundler/vendor/thor/lib/thor/command.rb +13 -11
  188. data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +21 -1
  189. data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/io_binary_read.rb +7 -5
  190. data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/ordered_hash.rb +94 -63
  191. data/bundler/lib/bundler/vendor/thor/lib/thor/error.rb +3 -3
  192. data/bundler/lib/bundler/vendor/thor/lib/thor/group.rb +13 -13
  193. data/bundler/lib/bundler/vendor/thor/lib/thor/invocation.rb +4 -5
  194. data/bundler/lib/bundler/vendor/thor/lib/thor/line_editor/basic.rb +2 -0
  195. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/argument.rb +4 -7
  196. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +16 -16
  197. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/option.rb +42 -21
  198. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/options.rb +13 -10
  199. data/bundler/lib/bundler/vendor/thor/lib/thor/runner.rb +31 -29
  200. data/bundler/lib/bundler/vendor/thor/lib/thor/shell.rb +1 -1
  201. data/bundler/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +49 -33
  202. data/bundler/lib/bundler/vendor/thor/lib/thor/shell/color.rb +1 -1
  203. data/bundler/lib/bundler/vendor/thor/lib/thor/shell/html.rb +4 -4
  204. data/bundler/lib/bundler/vendor/thor/lib/thor/util.rb +8 -7
  205. data/bundler/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
  206. data/bundler/lib/bundler/vendored_fileutils.rb +9 -0
  207. data/bundler/lib/bundler/vendored_molinillo.rb +1 -0
  208. data/bundler/lib/bundler/vendored_persistent.rb +35 -0
  209. data/bundler/lib/bundler/vendored_thor.rb +6 -2
  210. data/bundler/lib/bundler/version.rb +19 -2
  211. data/bundler/lib/bundler/version_ranges.rb +76 -0
  212. data/bundler/lib/bundler/vlad.rb +5 -0
  213. data/bundler/lib/bundler/worker.rb +3 -1
  214. data/bundler/lib/bundler/yaml_serializer.rb +3 -3
  215. data/bundler/man/bundle-add.ronn +29 -0
  216. data/bundler/man/bundle-binstubs.ronn +15 -1
  217. data/bundler/man/bundle-check.ronn +26 -0
  218. data/bundler/man/bundle-clean.ronn +18 -0
  219. data/bundler/man/bundle-config.ronn +193 -69
  220. data/bundler/man/bundle-doctor.ronn +33 -0
  221. data/bundler/man/bundle-exec.ronn +10 -3
  222. data/bundler/man/bundle-gem.ronn +3 -2
  223. data/bundler/man/bundle-info.ronn +17 -0
  224. data/bundler/man/bundle-init.ronn +29 -0
  225. data/bundler/man/bundle-inject.ronn +22 -0
  226. data/bundler/man/bundle-install.ronn +44 -35
  227. data/bundler/man/bundle-list.ronn +15 -0
  228. data/bundler/man/bundle-lock.ronn +1 -1
  229. data/bundler/man/bundle-open.ronn +19 -0
  230. data/bundler/man/bundle-outdated.ronn +2 -2
  231. data/bundler/man/bundle-package.ronn +7 -2
  232. data/bundler/man/bundle-pristine.ronn +34 -0
  233. data/bundler/man/bundle-show.ronn +21 -0
  234. data/bundler/man/bundle-update.ronn +24 -17
  235. data/bundler/man/bundle-viz.ronn +30 -0
  236. data/bundler/man/bundle.ronn +36 -45
  237. data/bundler/man/gemfile.5.ronn +77 -71
  238. data/lib/rubygems.rb +102 -46
  239. data/lib/rubygems/basic_specification.rb +8 -4
  240. data/lib/rubygems/bundler_version_finder.rb +99 -0
  241. data/lib/rubygems/command.rb +10 -2
  242. data/lib/rubygems/command_manager.rb +8 -4
  243. data/lib/rubygems/commands/cert_command.rb +31 -6
  244. data/lib/rubygems/commands/cleanup_command.rb +10 -3
  245. data/lib/rubygems/commands/generate_index_command.rb +1 -1
  246. data/lib/rubygems/commands/help_command.rb +1 -1
  247. data/lib/rubygems/commands/install_command.rb +7 -0
  248. data/lib/rubygems/commands/open_command.rb +1 -1
  249. data/lib/rubygems/commands/owner_command.rb +7 -2
  250. data/lib/rubygems/commands/pristine_command.rb +11 -8
  251. data/lib/rubygems/commands/push_command.rb +39 -5
  252. data/lib/rubygems/commands/query_command.rb +17 -17
  253. data/lib/rubygems/commands/setup_command.rb +174 -69
  254. data/lib/rubygems/commands/signin_command.rb +33 -0
  255. data/lib/rubygems/commands/signout_command.rb +33 -0
  256. data/lib/rubygems/commands/sources_command.rb +1 -1
  257. data/lib/rubygems/commands/uninstall_command.rb +5 -4
  258. data/lib/rubygems/commands/unpack_command.rb +19 -7
  259. data/lib/rubygems/commands/update_command.rb +1 -1
  260. data/lib/rubygems/commands/which_command.rb +1 -1
  261. data/lib/rubygems/commands/yank_command.rb +4 -11
  262. data/lib/rubygems/config_file.rb +15 -26
  263. data/lib/rubygems/core_ext/kernel_require.rb +12 -16
  264. data/lib/rubygems/dependency.rb +3 -0
  265. data/lib/rubygems/dependency_installer.rb +8 -2
  266. data/lib/rubygems/dependency_list.rb +1 -1
  267. data/lib/rubygems/errors.rb +3 -0
  268. data/lib/rubygems/exceptions.rb +11 -1
  269. data/lib/rubygems/ext/builder.rb +2 -2
  270. data/lib/rubygems/ext/ext_conf_builder.rb +2 -4
  271. data/lib/rubygems/ext/rake_builder.rb +1 -1
  272. data/lib/rubygems/gem_runner.rb +5 -1
  273. data/lib/rubygems/gemcutter_utilities.rb +5 -2
  274. data/lib/rubygems/indexer.rb +6 -5
  275. data/lib/rubygems/install_update_options.rb +6 -29
  276. data/lib/rubygems/installer.rb +60 -13
  277. data/lib/rubygems/installer_test_case.rb +6 -3
  278. data/lib/rubygems/package.rb +55 -8
  279. data/lib/rubygems/package/file_source.rb +2 -2
  280. data/lib/rubygems/package/old.rb +3 -3
  281. data/lib/rubygems/package/tar_header.rb +17 -10
  282. data/lib/rubygems/package/tar_writer.rb +4 -3
  283. data/lib/rubygems/platform.rb +1 -1
  284. data/lib/rubygems/remote_fetcher.rb +2 -2
  285. data/lib/rubygems/request.rb +1 -1
  286. data/lib/rubygems/request_set.rb +47 -19
  287. data/lib/rubygems/request_set/gem_dependency_api.rb +3 -3
  288. data/lib/rubygems/request_set/lockfile.rb +1 -1
  289. data/lib/rubygems/requirement.rb +19 -4
  290. data/lib/rubygems/resolver.rb +24 -3
  291. data/lib/rubygems/resolver/api_specification.rb +5 -0
  292. data/lib/rubygems/resolver/installer_set.rb +4 -6
  293. data/lib/rubygems/safe_yaml.rb +51 -0
  294. data/lib/rubygems/security.rb +18 -6
  295. data/lib/rubygems/security/trust_dir.rb +1 -1
  296. data/lib/rubygems/security_option.rb +43 -0
  297. data/lib/rubygems/server.rb +21 -17
  298. data/lib/rubygems/source.rb +9 -6
  299. data/lib/rubygems/source/git.rb +2 -1
  300. data/lib/rubygems/source/local.rb +38 -35
  301. data/lib/rubygems/source/lock.rb +4 -1
  302. data/lib/rubygems/source_local.rb +3 -1
  303. data/lib/rubygems/source_specific_file.rb +3 -2
  304. data/lib/rubygems/spec_fetcher.rb +7 -3
  305. data/lib/rubygems/specification.rb +315 -249
  306. data/lib/rubygems/ssl_certs/{index.rubygems.org → rubygems.org}/GlobalSignRootCA.pem +0 -0
  307. data/lib/rubygems/ssl_certs/rubygems.org/GlobalSignRootCA_R3.pem +21 -0
  308. data/lib/rubygems/stub_specification.rb +4 -3
  309. data/lib/rubygems/test_case.rb +51 -11
  310. data/lib/rubygems/test_utilities.rb +2 -2
  311. data/lib/rubygems/text.rb +14 -1
  312. data/lib/rubygems/user_interaction.rb +24 -15
  313. data/lib/rubygems/util.rb +6 -16
  314. data/lib/rubygems/util/licenses.rb +72 -4
  315. data/lib/rubygems/validator.rb +3 -3
  316. data/lib/rubygems/version.rb +24 -4
  317. data/lib/rubygems/version_option.rb +6 -1
  318. data/lib/ubygems.rb +3 -0
  319. data/setup.rb +1 -1
  320. data/test/rubygems/private3072_key.pem +40 -0
  321. data/test/rubygems/public3072_cert.pem +25 -0
  322. data/test/rubygems/test_bundled_ca.rb +7 -4
  323. data/test/rubygems/test_config.rb +1 -1
  324. data/test/rubygems/test_gem.rb +158 -39
  325. data/test/rubygems/test_gem_bundler_version_finder.rb +126 -0
  326. data/test/rubygems/test_gem_command.rb +7 -1
  327. data/test/rubygems/test_gem_command_manager.rb +2 -2
  328. data/test/rubygems/test_gem_commands_build_command.rb +29 -1
  329. data/test/rubygems/test_gem_commands_cert_command.rb +64 -0
  330. data/test/rubygems/test_gem_commands_cleanup_command.rb +44 -1
  331. data/test/rubygems/test_gem_commands_install_command.rb +73 -2
  332. data/test/rubygems/test_gem_commands_open_command.rb +2 -1
  333. data/test/rubygems/test_gem_commands_owner_command.rb +25 -0
  334. data/test/rubygems/test_gem_commands_pristine_command.rb +1 -1
  335. data/test/rubygems/test_gem_commands_push_command.rb +25 -5
  336. data/test/rubygems/test_gem_commands_query_command.rb +154 -1
  337. data/test/rubygems/test_gem_commands_setup_command.rb +140 -10
  338. data/test/rubygems/test_gem_commands_signin_command.rb +98 -0
  339. data/test/rubygems/test_gem_commands_signout_command.rb +37 -0
  340. data/test/rubygems/test_gem_commands_sources_command.rb +52 -0
  341. data/test/rubygems/test_gem_commands_uninstall_command.rb +15 -3
  342. data/test/rubygems/test_gem_commands_update_command.rb +1 -7
  343. data/test/rubygems/test_gem_commands_which_command.rb +3 -3
  344. data/test/rubygems/test_gem_dependency.rb +28 -0
  345. data/test/rubygems/test_gem_dependency_installer.rb +1 -1
  346. data/test/rubygems/test_gem_doctor.rb +2 -2
  347. data/test/rubygems/test_gem_ext_builder.rb +8 -8
  348. data/test/rubygems/test_gem_ext_configure_builder.rb +1 -1
  349. data/test/rubygems/test_gem_ext_rake_builder.rb +2 -6
  350. data/test/rubygems/test_gem_gemcutter_utilities.rb +4 -4
  351. data/test/rubygems/test_gem_indexer.rb +1 -2
  352. data/test/rubygems/test_gem_install_update_options.rb +6 -1
  353. data/test/rubygems/test_gem_installer.rb +168 -31
  354. data/test/rubygems/test_gem_package.rb +183 -26
  355. data/test/rubygems/test_gem_package_old.rb +1 -1
  356. data/test/rubygems/test_gem_package_tar_header.rb +21 -0
  357. data/test/rubygems/test_gem_rdoc.rb +2 -0
  358. data/test/rubygems/test_gem_remote_fetcher.rb +24 -5
  359. data/test/rubygems/test_gem_request.rb +5 -2
  360. data/test/rubygems/test_gem_request_connection_pools.rb +6 -7
  361. data/test/rubygems/test_gem_request_set.rb +7 -7
  362. data/test/rubygems/test_gem_request_set_gem_dependency_api.rb +3 -3
  363. data/test/rubygems/test_gem_request_set_lockfile.rb +4 -4
  364. data/test/rubygems/test_gem_request_set_lockfile_parser.rb +1 -1
  365. data/test/rubygems/test_gem_request_set_lockfile_tokenizer.rb +1 -1
  366. data/test/rubygems/test_gem_requirement.rb +12 -0
  367. data/test/rubygems/test_gem_resolver.rb +26 -0
  368. data/test/rubygems/test_gem_resolver_api_specification.rb +24 -0
  369. data/test/rubygems/test_gem_resolver_conflict.rb +1 -1
  370. data/test/rubygems/test_gem_resolver_git_specification.rb +1 -1
  371. data/test/rubygems/test_gem_resolver_installer_set.rb +1 -1
  372. data/test/rubygems/test_gem_security.rb +5 -0
  373. data/test/rubygems/test_gem_security_policy.rb +27 -27
  374. data/test/rubygems/test_gem_security_signer.rb +6 -6
  375. data/test/rubygems/test_gem_security_trust_dir.rb +2 -2
  376. data/test/rubygems/test_gem_server.rb +194 -12
  377. data/test/rubygems/test_gem_source.rb +12 -3
  378. data/test/rubygems/test_gem_source_git.rb +1 -1
  379. data/test/rubygems/test_gem_spec_fetcher.rb +20 -0
  380. data/test/rubygems/test_gem_specification.rb +180 -42
  381. data/test/rubygems/test_gem_stream_ui.rb +8 -8
  382. data/test/rubygems/test_gem_stub_specification.rb +26 -8
  383. data/test/rubygems/test_gem_text.rb +16 -0
  384. data/test/rubygems/test_gem_util.rb +26 -0
  385. data/test/rubygems/test_gem_version.rb +68 -9
  386. data/test/rubygems/test_gem_version_option.rb +15 -0
  387. data/test/rubygems/test_kernel.rb +30 -0
  388. data/test/rubygems/test_require.rb +70 -21
  389. data/util/ci +1 -0
  390. data/util/generate_spdx_license_list.rb +16 -6
  391. data/util/update_bundled_ca_certificates.rb +1 -3
  392. metadata +61 -57
  393. data/README.rdoc +0 -54
  394. data/bundler/DEVELOPMENT.md +0 -150
  395. data/bundler/ISSUES.md +0 -117
  396. data/bundler/lib/bundler/postit_trampoline.rb +0 -73
  397. data/bundler/lib/bundler/vendor/postit/lib/postit.rb +0 -15
  398. data/bundler/lib/bundler/vendor/postit/lib/postit/environment.rb +0 -44
  399. data/bundler/lib/bundler/vendor/postit/lib/postit/installer.rb +0 -28
  400. data/bundler/lib/bundler/vendor/postit/lib/postit/parser.rb +0 -21
  401. data/bundler/lib/bundler/vendor/postit/lib/postit/setup.rb +0 -12
  402. data/bundler/lib/bundler/vendor/postit/lib/postit/version.rb +0 -3
  403. data/bundler/man/index.txt +0 -8
  404. data/lib/rubygems/ssl_certs/rubygems.global.ssl.fastly.net/DigiCertHighAssuranceEVRootCA.pem +0 -23
  405. data/lib/rubygems/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem +0 -25
@@ -31,7 +31,7 @@ class TestGemGemcutterUtilities < Gem::TestCase
31
31
 
32
32
  FileUtils.mkdir_p File.dirname Gem.configuration.credentials_path
33
33
 
34
- open Gem.configuration.credentials_path, 'w' do |f|
34
+ File.open Gem.configuration.credentials_path, 'w' do |f|
35
35
  f.write keys.to_yaml
36
36
  end
37
37
 
@@ -46,7 +46,7 @@ class TestGemGemcutterUtilities < Gem::TestCase
46
46
  keys = { :rubygems_api_key => 'KEY' }
47
47
  FileUtils.mkdir_p File.dirname Gem.configuration.credentials_path
48
48
 
49
- open Gem.configuration.credentials_path, 'w' do |f|
49
+ File.open Gem.configuration.credentials_path, 'w' do |f|
50
50
  f.write keys.to_yaml
51
51
  end
52
52
 
@@ -59,7 +59,7 @@ class TestGemGemcutterUtilities < Gem::TestCase
59
59
  keys = { :rubygems_api_key => 'KEY', :other => 'OTHER' }
60
60
  FileUtils.mkdir_p File.dirname Gem.configuration.credentials_path
61
61
 
62
- open Gem.configuration.credentials_path, 'w' do |f|
62
+ File.open Gem.configuration.credentials_path, 'w' do |f|
63
63
  f.write keys.to_yaml
64
64
  end
65
65
 
@@ -163,7 +163,7 @@ class TestGemGemcutterUtilities < Gem::TestCase
163
163
  other_api_key = 'f46dbb18bb6a9c97cdc61b5b85c186a17403cdcbf'
164
164
 
165
165
  FileUtils.mkdir_p File.dirname(Gem.configuration.credentials_path)
166
- open Gem.configuration.credentials_path, 'w' do |f|
166
+ File.open Gem.configuration.credentials_path, 'w' do |f|
167
167
  f.write Hash[:other_api_key, other_api_key].to_yaml
168
168
  end
169
169
  util_sign_in [api_key, 200, 'OK']
@@ -39,8 +39,7 @@ class TestGemIndexer < Gem::TestCase
39
39
 
40
40
  def test_initialize
41
41
  assert_equal @tempdir, @indexer.dest_directory
42
- assert_equal File.join(Dir.tmpdir, "gem_generate_index_#{$$}"),
43
- @indexer.directory
42
+ assert_match %r{#{Dir.mktmpdir('gem_generate_index').match(/.*-/)}}, @indexer.directory
44
43
 
45
44
  indexer = Gem::Indexer.new @tempdir
46
45
  assert indexer.build_modern
@@ -119,11 +119,14 @@ class TestGemInstallUpdateOptions < Gem::InstallerTestCase
119
119
  end
120
120
 
121
121
  def test_security_policy_unknown
122
+ skip 'openssl is missing' unless defined?(OpenSSL::SSL)
123
+
122
124
  @cmd.add_install_update_options
123
125
 
124
- assert_raises OptionParser::InvalidArgument do
126
+ e = assert_raises OptionParser::InvalidArgument do
125
127
  @cmd.handle_options %w[-P UnknownSecurity]
126
128
  end
129
+ assert_includes e.message, "UnknownSecurity"
127
130
  end
128
131
 
129
132
  def test_user_install_enabled
@@ -140,6 +143,8 @@ class TestGemInstallUpdateOptions < Gem::InstallerTestCase
140
143
  def test_user_install_disabled_read_only
141
144
  if win_platform?
142
145
  skip('test_user_install_disabled_read_only test skipped on MS Windows')
146
+ elsif Process.uid.zero?
147
+ skip('test_user_install_disabled_read_only test skipped in root privilege')
143
148
  else
144
149
  @cmd.handle_options %w[--no-user-install]
145
150
 
@@ -21,7 +21,7 @@ class TestGemInstaller < Gem::InstallerTestCase
21
21
  super
22
22
  common_installer_setup
23
23
 
24
- if __name__ =~ /^test_install(_|$)/ then
24
+ if (self.class.method_defined?(:__name__) ? __name__ : name) =~ /\Atest_install(_|\Z)/
25
25
  FileUtils.rm_r @spec.gem_dir
26
26
  FileUtils.rm_r @user_spec.gem_dir
27
27
  end
@@ -34,7 +34,7 @@ class TestGemInstaller < Gem::InstallerTestCase
34
34
 
35
35
  super
36
36
 
37
- Gem.configuration = @config
37
+ Gem.configuration = instance_variable_defined?(:@config) ? @config : nil
38
38
  end
39
39
 
40
40
  def test_app_script_text
@@ -62,7 +62,12 @@ if ARGV.first
62
62
  end
63
63
  end
64
64
 
65
+ if Gem.respond_to?(:activate_bin_path)
65
66
  load Gem.activate_bin_path('a', 'executable', version)
67
+ else
68
+ gem "a", version
69
+ load Gem.bin_path("a", "executable", version)
70
+ end
66
71
  EOF
67
72
 
68
73
  wrapper = @installer.app_script_text 'executable'
@@ -82,7 +87,7 @@ load Gem.activate_bin_path('a', 'executable', version)
82
87
  end
83
88
 
84
89
  util_make_exec
85
- @installer.gem_dir = util_gem_dir @spec
90
+ @installer.gem_dir = @spec.gem_dir
86
91
  @installer.wrappers = true
87
92
  @installer.generate_bin
88
93
 
@@ -135,7 +140,7 @@ load Gem.activate_bin_path('a', 'executable', version)
135
140
  s.require_path = 'lib'
136
141
  end
137
142
 
138
- open File.join(util_inst_bindir, 'executable'), 'w' do |io|
143
+ File.open File.join(util_inst_bindir, 'executable'), 'w' do |io|
139
144
  io.write <<-EXEC
140
145
  #!/usr/local/bin/ruby
141
146
  #
@@ -299,7 +304,7 @@ gem 'other', version
299
304
  def test_extract_files
300
305
  @installer.extract_files
301
306
 
302
- assert_path_exists File.join util_gem_dir, 'bin/executable'
307
+ assert_path_exists File.join @spec.gem_dir, 'bin/executable'
303
308
  end
304
309
 
305
310
  def test_generate_bin_bindir
@@ -309,12 +314,12 @@ gem 'other', version
309
314
  @spec.bindir = '.'
310
315
 
311
316
  exec_file = @installer.formatted_program_filename 'executable'
312
- exec_path = File.join util_gem_dir(@spec), exec_file
317
+ exec_path = File.join @spec.gem_dir, exec_file
313
318
  File.open exec_path, 'w' do |f|
314
319
  f.puts '#!/usr/bin/ruby'
315
320
  end
316
321
 
317
- @installer.gem_dir = util_gem_dir
322
+ @installer.gem_dir = @spec.gem_dir
318
323
 
319
324
  @installer.generate_bin
320
325
 
@@ -350,7 +355,7 @@ gem 'other', version
350
355
  def test_generate_bin_script
351
356
  @installer.wrappers = true
352
357
  util_make_exec
353
- @installer.gem_dir = util_gem_dir
358
+ @installer.gem_dir = @spec.gem_dir
354
359
 
355
360
  @installer.generate_bin
356
361
  assert File.directory? util_inst_bindir
@@ -366,7 +371,7 @@ gem 'other', version
366
371
  @installer.format_executable = true
367
372
  @installer.wrappers = true
368
373
  util_make_exec
369
- @installer.gem_dir = util_gem_dir
374
+ @installer.gem_dir = @spec.gem_dir
370
375
 
371
376
  Gem::Installer.exec_format = 'foo-%s-bar'
372
377
  @installer.generate_bin
@@ -380,7 +385,7 @@ gem 'other', version
380
385
  def test_generate_bin_script_format_disabled
381
386
  @installer.wrappers = true
382
387
  util_make_exec
383
- @installer.gem_dir = util_gem_dir
388
+ @installer.gem_dir = @spec.gem_dir
384
389
 
385
390
  Gem::Installer.exec_format = 'foo-%s-bar'
386
391
  @installer.generate_bin
@@ -432,6 +437,8 @@ gem 'other', version
432
437
 
433
438
  if win_platform?
434
439
  skip('test_generate_bin_script_no_perms skipped on MS Windows')
440
+ elsif Process.uid.zero?
441
+ skip('test_generate_bin_script_no_perms skipped in root privilege')
435
442
  else
436
443
  FileUtils.chmod 0000, util_inst_bindir
437
444
 
@@ -469,10 +476,10 @@ gem 'other', version
469
476
  def test_generate_bin_script_wrappers
470
477
  @installer.wrappers = true
471
478
  util_make_exec
472
- @installer.gem_dir = util_gem_dir
479
+ @installer.gem_dir = @spec.gem_dir
473
480
  installed_exec = File.join(util_inst_bindir, 'executable')
474
481
 
475
- real_exec = File.join util_gem_dir, 'bin', 'executable'
482
+ real_exec = File.join @spec.gem_dir, 'bin', 'executable'
476
483
 
477
484
  # fake --no-wrappers for previous install
478
485
  unless Gem.win_platform? then
@@ -496,13 +503,13 @@ gem 'other', version
496
503
 
497
504
  @installer.wrappers = false
498
505
  util_make_exec
499
- @installer.gem_dir = util_gem_dir
506
+ @installer.gem_dir = @spec.gem_dir
500
507
 
501
508
  @installer.generate_bin
502
509
  assert_equal true, File.directory?(util_inst_bindir)
503
510
  installed_exec = File.join util_inst_bindir, 'executable'
504
511
  assert_equal true, File.symlink?(installed_exec)
505
- assert_equal(File.join(util_gem_dir, 'bin', 'executable'),
512
+ assert_equal(File.join(@spec.gem_dir, 'bin', 'executable'),
506
513
  File.readlink(installed_exec))
507
514
  end
508
515
 
@@ -518,12 +525,14 @@ gem 'other', version
518
525
  def test_generate_bin_symlink_no_perms
519
526
  @installer.wrappers = false
520
527
  util_make_exec
521
- @installer.gem_dir = util_gem_dir
528
+ @installer.gem_dir = @spec.gem_dir
522
529
 
523
530
  Dir.mkdir util_inst_bindir
524
531
 
525
532
  if win_platform?
526
533
  skip('test_generate_bin_symlink_no_perms skipped on MS Windows')
534
+ elsif Process.uid.zero?
535
+ skip('test_user_install_disabled_read_only test skipped in root privilege')
527
536
  else
528
537
  FileUtils.chmod 0000, util_inst_bindir
529
538
 
@@ -540,11 +549,11 @@ gem 'other', version
540
549
 
541
550
  @installer.wrappers = false
542
551
  util_make_exec
543
- @installer.gem_dir = util_gem_dir
552
+ @installer.gem_dir = @spec.gem_dir
544
553
 
545
554
  @installer.generate_bin
546
555
  installed_exec = File.join(util_inst_bindir, 'executable')
547
- assert_equal(File.join(util_gem_dir, 'bin', 'executable'),
556
+ assert_equal(File.join(@spec.gem_dir, 'bin', 'executable'),
548
557
  File.readlink(installed_exec))
549
558
 
550
559
  @spec = Gem::Specification.new do |s|
@@ -557,7 +566,7 @@ gem 'other', version
557
566
  end
558
567
 
559
568
  util_make_exec
560
- @installer.gem_dir = util_gem_dir @spec
569
+ @installer.gem_dir = @spec.gem_dir
561
570
  @installer.generate_bin
562
571
  installed_exec = File.join(util_inst_bindir, 'executable')
563
572
  assert_equal(@spec.bin_file('executable'),
@@ -570,11 +579,11 @@ gem 'other', version
570
579
 
571
580
  @installer.wrappers = false
572
581
  util_make_exec
573
- @installer.gem_dir = util_gem_dir
582
+ @installer.gem_dir = @spec.gem_dir
574
583
 
575
584
  @installer.generate_bin
576
585
  installed_exec = File.join(util_inst_bindir, 'executable')
577
- assert_equal(File.join(util_gem_dir, 'bin', 'executable'),
586
+ assert_equal(File.join(@spec.gem_dir, 'bin', 'executable'),
578
587
  File.readlink(installed_exec))
579
588
 
580
589
  spec = Gem::Specification.new do |s|
@@ -590,12 +599,12 @@ gem 'other', version
590
599
  one = @spec.dup
591
600
  one.version = 1
592
601
  @installer = Gem::Installer.for_spec spec
593
- @installer.gem_dir = util_gem_dir one
602
+ @installer.gem_dir = one.gem_dir
594
603
 
595
604
  @installer.generate_bin
596
605
 
597
606
  installed_exec = File.join util_inst_bindir, 'executable'
598
- expected = File.join util_gem_dir, 'bin', 'executable'
607
+ expected = File.join @spec.gem_dir, 'bin', 'executable'
599
608
  assert_equal(expected,
600
609
  File.readlink(installed_exec),
601
610
  "Ensure symlink not moved")
@@ -606,7 +615,7 @@ gem 'other', version
606
615
 
607
616
  @installer.wrappers = true
608
617
  util_make_exec
609
- @installer.gem_dir = util_gem_dir
618
+ @installer.gem_dir = @spec.gem_dir
610
619
 
611
620
  @installer.generate_bin
612
621
 
@@ -625,7 +634,7 @@ gem 'other', version
625
634
 
626
635
  util_installer @spec, @gemhome
627
636
  @installer.wrappers = false
628
- @installer.gem_dir = util_gem_dir
637
+ @installer.gem_dir = @spec.gem_dir
629
638
 
630
639
  @installer.generate_bin
631
640
 
@@ -643,7 +652,7 @@ gem 'other', version
643
652
  File.const_set(:ALT_SEPARATOR, '\\')
644
653
  @installer.wrappers = false
645
654
  util_make_exec
646
- @installer.gem_dir = util_gem_dir
655
+ @installer.gem_dir = @spec.gem_dir
647
656
 
648
657
  use_ui @ui do
649
658
  @installer.generate_bin
@@ -654,7 +663,7 @@ gem 'other', version
654
663
  assert_path_exists installed_exec
655
664
 
656
665
  if symlink_supported?
657
- assert_send([File, :symlink?, installed_exec])
666
+ assert File.symlink?(installed_exec)
658
667
  return
659
668
  end
660
669
 
@@ -1416,10 +1425,11 @@ gem 'other', version
1416
1425
  def test_pre_install_checks_ruby_version
1417
1426
  use_ui @ui do
1418
1427
  installer = Gem::Installer.at old_ruby_required
1419
- e = assert_raises Gem::InstallError do
1428
+ e = assert_raises Gem::RuntimeRequirementNotMetError do
1420
1429
  installer.pre_install_checks
1421
1430
  end
1422
- assert_equal 'old_ruby_required requires Ruby version = 1.4.6.',
1431
+ rv = Gem.ruby_api_version
1432
+ assert_equal "old_ruby_required requires Ruby version = 1.4.6. The current ruby version is #{rv}.",
1423
1433
  e.message
1424
1434
  end
1425
1435
  end
@@ -1435,14 +1445,141 @@ gem 'other', version
1435
1445
 
1436
1446
  use_ui @ui do
1437
1447
  @installer = Gem::Installer.at gem
1438
- e = assert_raises Gem::InstallError do
1448
+ e = assert_raises Gem::RuntimeRequirementNotMetError do
1439
1449
  @installer.pre_install_checks
1440
1450
  end
1441
- assert_equal 'old_rubygems_required requires RubyGems version < 0. ' +
1451
+ rgv = Gem::VERSION
1452
+ assert_equal "old_rubygems_required requires RubyGems version < 0. The current RubyGems version is #{rgv}. " +
1442
1453
  "Try 'gem update --system' to update RubyGems itself.", e.message
1443
1454
  end
1444
1455
  end
1445
1456
 
1457
+ def test_pre_install_checks_malicious_name
1458
+ spec = util_spec '../malicious', '1'
1459
+ def spec.full_name # so the spec is buildable
1460
+ "malicious-1"
1461
+ end
1462
+ def spec.validate; end
1463
+
1464
+ util_build_gem spec
1465
+
1466
+ gem = File.join(@gemhome, 'cache', spec.file_name)
1467
+
1468
+ use_ui @ui do
1469
+ @installer = Gem::Installer.at gem
1470
+ e = assert_raises Gem::InstallError do
1471
+ @installer.pre_install_checks
1472
+ end
1473
+ assert_equal '#<Gem::Specification name=../malicious version=1> has an invalid name', e.message
1474
+ end
1475
+ end
1476
+
1477
+ def test_pre_install_checks_malicious_name_before_eval
1478
+ spec = util_spec "malicious\n::Object.const_set(:FROM_EVAL, true)#", '1'
1479
+ def spec.full_name # so the spec is buildable
1480
+ "malicious-1"
1481
+ end
1482
+ def spec.validate(*args); end
1483
+
1484
+ util_build_gem spec
1485
+
1486
+ gem = File.join(@gemhome, 'cache', spec.file_name)
1487
+
1488
+ use_ui @ui do
1489
+ @installer = Gem::Installer.at gem
1490
+ e = assert_raises Gem::InstallError do
1491
+ @installer.pre_install_checks
1492
+ end
1493
+ assert_equal "#<Gem::Specification name=malicious\n::Object.const_set(:FROM_EVAL, true)# version=1> has an invalid name", e.message
1494
+ end
1495
+ refute defined?(::Object::FROM_EVAL)
1496
+ end
1497
+
1498
+ def test_pre_install_checks_malicious_require_paths_before_eval
1499
+ spec = util_spec "malicious", '1'
1500
+ def spec.full_name # so the spec is buildable
1501
+ "malicious-1"
1502
+ end
1503
+ def spec.validate(*args); end
1504
+ spec.require_paths = ["malicious\n``"]
1505
+
1506
+ util_build_gem spec
1507
+
1508
+ gem = File.join(@gemhome, 'cache', spec.file_name)
1509
+
1510
+ use_ui @ui do
1511
+ @installer = Gem::Installer.at gem
1512
+ e = assert_raises Gem::InstallError do
1513
+ @installer.pre_install_checks
1514
+ end
1515
+ assert_equal "#<Gem::Specification name=malicious version=1> has an invalid require_paths", e.message
1516
+ end
1517
+ end
1518
+
1519
+ def test_pre_install_checks_malicious_extensions_before_eval
1520
+ spec = util_spec "malicious", '1'
1521
+ def spec.full_name # so the spec is buildable
1522
+ "malicious-1"
1523
+ end
1524
+ def spec.validate(*args); end
1525
+ spec.extensions = ["malicious\n``"]
1526
+
1527
+ util_build_gem spec
1528
+
1529
+ gem = File.join(@gemhome, 'cache', spec.file_name)
1530
+
1531
+ use_ui @ui do
1532
+ @installer = Gem::Installer.at gem
1533
+ e = assert_raises Gem::InstallError do
1534
+ @installer.pre_install_checks
1535
+ end
1536
+ assert_equal "#<Gem::Specification name=malicious version=1> has an invalid extensions", e.message
1537
+ end
1538
+ end
1539
+
1540
+ def test_pre_install_checks_malicious_specification_version_before_eval
1541
+ spec = util_spec "malicious", '1'
1542
+ def spec.full_name # so the spec is buildable
1543
+ "malicious-1"
1544
+ end
1545
+ def spec.validate(*args); end
1546
+ spec.specification_version = "malicious\n``"
1547
+
1548
+ util_build_gem spec
1549
+
1550
+ gem = File.join(@gemhome, 'cache', spec.file_name)
1551
+
1552
+ use_ui @ui do
1553
+ @installer = Gem::Installer.at gem
1554
+ e = assert_raises Gem::InstallError do
1555
+ @installer.pre_install_checks
1556
+ end
1557
+ assert_equal "#<Gem::Specification name=malicious version=1> has an invalid specification_version", e.message
1558
+ end
1559
+ end
1560
+
1561
+ def test_pre_install_checks_malicious_dependencies_before_eval
1562
+ spec = util_spec "malicious", '1'
1563
+ def spec.full_name # so the spec is buildable
1564
+ "malicious-1"
1565
+ end
1566
+ def spec.validate(*args); end
1567
+ spec.add_dependency "b\nfoo", '> 5'
1568
+
1569
+ util_build_gem spec
1570
+
1571
+ gem = File.join(@gemhome, 'cache', spec.file_name)
1572
+
1573
+ use_ui @ui do
1574
+ @installer = Gem::Installer.at gem
1575
+ @installer.ignore_dependencies = true
1576
+ e = assert_raises Gem::InstallError do
1577
+ @installer.pre_install_checks
1578
+ end
1579
+ assert_equal "#<Gem::Specification name=malicious version=1> has an invalid dependencies", e.message
1580
+ end
1581
+ end
1582
+
1446
1583
  def test_shebang
1447
1584
  util_make_exec @spec, "#!/usr/bin/ruby"
1448
1585
 
@@ -1714,7 +1851,7 @@ gem 'other', version
1714
1851
 
1715
1852
  @installer.wrappers = true
1716
1853
  @installer.options[:install_as_default] = true
1717
- @installer.gem_dir = util_gem_dir @spec
1854
+ @installer.gem_dir = @spec.gem_dir
1718
1855
  @installer.generate_bin
1719
1856
 
1720
1857
  use_ui @ui do