rubygems-update 2.6.4 → 2.6.5
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of rubygems-update might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/.travis.yml +18 -24
- data/CODE_OF_CONDUCT.md +2 -2
- data/CONTRIBUTING.rdoc +1 -1
- data/History.txt +30 -1
- data/Manifest.txt +233 -3
- data/Rakefile +30 -1
- data/appveyor.yml +0 -2
- data/bundler/CHANGELOG.md +2407 -0
- data/bundler/CODE_OF_CONDUCT.md +42 -0
- data/bundler/CONTRIBUTING.md +36 -0
- data/bundler/DEVELOPMENT.md +148 -0
- data/bundler/ISSUES.md +100 -0
- data/bundler/LICENSE.md +23 -0
- data/bundler/README.md +40 -0
- data/bundler/exe/bundle +35 -0
- data/bundler/exe/bundle_ruby +61 -0
- data/bundler/exe/bundler +22 -0
- data/bundler/lib/bundler.rb +455 -0
- data/bundler/lib/bundler/capistrano.rb +17 -0
- data/bundler/lib/bundler/cli.rb +497 -0
- data/bundler/lib/bundler/cli/binstubs.rb +40 -0
- data/bundler/lib/bundler/cli/cache.rb +35 -0
- data/bundler/lib/bundler/cli/check.rb +40 -0
- data/bundler/lib/bundler/cli/clean.rb +26 -0
- data/bundler/lib/bundler/cli/common.rb +56 -0
- data/bundler/lib/bundler/cli/config.rb +100 -0
- data/bundler/lib/bundler/cli/console.rb +39 -0
- data/bundler/lib/bundler/cli/exec.rb +82 -0
- data/bundler/lib/bundler/cli/gem.rb +214 -0
- data/bundler/lib/bundler/cli/init.rb +33 -0
- data/bundler/lib/bundler/cli/inject.rb +33 -0
- data/bundler/lib/bundler/cli/install.rb +225 -0
- data/bundler/lib/bundler/cli/lock.rb +48 -0
- data/bundler/lib/bundler/cli/open.rb +25 -0
- data/bundler/lib/bundler/cli/outdated.rb +151 -0
- data/bundler/lib/bundler/cli/package.rb +46 -0
- data/bundler/lib/bundler/cli/platform.rb +45 -0
- data/bundler/lib/bundler/cli/plugin.rb +23 -0
- data/bundler/lib/bundler/cli/show.rb +75 -0
- data/bundler/lib/bundler/cli/update.rb +72 -0
- data/bundler/lib/bundler/cli/viz.rb +27 -0
- data/bundler/lib/bundler/constants.rb +6 -0
- data/bundler/lib/bundler/current_ruby.rb +84 -0
- data/bundler/lib/bundler/definition.rb +744 -0
- data/bundler/lib/bundler/dep_proxy.rb +46 -0
- data/bundler/lib/bundler/dependency.rb +127 -0
- data/bundler/lib/bundler/deployment.rb +63 -0
- data/bundler/lib/bundler/deprecate.rb +16 -0
- data/bundler/lib/bundler/dsl.rb +512 -0
- data/bundler/lib/bundler/endpoint_specification.rb +129 -0
- data/bundler/lib/bundler/env.rb +83 -0
- data/bundler/lib/bundler/environment.rb +42 -0
- data/bundler/lib/bundler/environment_preserver.rb +38 -0
- data/bundler/lib/bundler/errors.rb +124 -0
- data/bundler/lib/bundler/fetcher.rb +304 -0
- data/bundler/lib/bundler/fetcher/base.rb +41 -0
- data/bundler/lib/bundler/fetcher/compact_index.rb +103 -0
- data/bundler/lib/bundler/fetcher/dependency.rb +92 -0
- data/bundler/lib/bundler/fetcher/downloader.rb +66 -0
- data/bundler/lib/bundler/fetcher/index.rb +51 -0
- data/bundler/lib/bundler/friendly_errors.rb +103 -0
- data/bundler/lib/bundler/gem_helper.rb +188 -0
- data/bundler/lib/bundler/gem_helpers.rb +32 -0
- data/bundler/lib/bundler/gem_remote_fetcher.rb +42 -0
- data/bundler/lib/bundler/gem_tasks.rb +6 -0
- data/bundler/lib/bundler/graph.rb +172 -0
- data/bundler/lib/bundler/index.rb +191 -0
- data/bundler/lib/bundler/injector.rb +63 -0
- data/bundler/lib/bundler/inline.rb +74 -0
- data/bundler/lib/bundler/installer.rb +217 -0
- data/bundler/lib/bundler/installer/gem_installer.rb +77 -0
- data/bundler/lib/bundler/installer/parallel_installer.rb +126 -0
- data/bundler/lib/bundler/installer/standalone.rb +52 -0
- data/bundler/lib/bundler/lazy_specification.rb +85 -0
- data/bundler/lib/bundler/lockfile_parser.rb +233 -0
- data/bundler/lib/bundler/match_platform.rb +14 -0
- data/bundler/lib/bundler/mirror.rb +218 -0
- data/bundler/lib/bundler/plugin.rb +156 -0
- data/bundler/lib/bundler/plugin/api.rb +56 -0
- data/bundler/lib/bundler/plugin/dsl.rb +29 -0
- data/bundler/lib/bundler/plugin/index.rb +88 -0
- data/bundler/lib/bundler/plugin/installer.rb +99 -0
- data/bundler/lib/bundler/plugin/installer/git.rb +38 -0
- data/bundler/lib/bundler/plugin/installer/rubygems.rb +27 -0
- data/bundler/lib/bundler/plugin/source_list.rb +24 -0
- data/bundler/lib/bundler/postit_trampoline.rb +57 -0
- data/bundler/lib/bundler/psyched_yaml.rb +27 -0
- data/bundler/lib/bundler/remote_specification.rb +85 -0
- data/bundler/lib/bundler/resolver.rb +368 -0
- data/bundler/lib/bundler/retry.rb +61 -0
- data/bundler/lib/bundler/ruby_dsl.rb +17 -0
- data/bundler/lib/bundler/ruby_version.rb +140 -0
- data/bundler/lib/bundler/rubygems_ext.rb +178 -0
- data/bundler/lib/bundler/rubygems_gem_installer.rb +10 -0
- data/bundler/lib/bundler/rubygems_integration.rb +710 -0
- data/bundler/lib/bundler/runtime.rb +282 -0
- data/bundler/lib/bundler/settings.rb +259 -0
- data/bundler/lib/bundler/setup.rb +28 -0
- data/bundler/lib/bundler/shared_helpers.rb +212 -0
- data/bundler/lib/bundler/similarity_detector.rb +62 -0
- data/bundler/lib/bundler/source.rb +37 -0
- data/bundler/lib/bundler/source/gemspec.rb +13 -0
- data/bundler/lib/bundler/source/git.rb +297 -0
- data/bundler/lib/bundler/source/git/git_proxy.rb +218 -0
- data/bundler/lib/bundler/source/path.rb +245 -0
- data/bundler/lib/bundler/source/path/installer.rb +44 -0
- data/bundler/lib/bundler/source/rubygems.rb +450 -0
- data/bundler/lib/bundler/source/rubygems/remote.rb +59 -0
- data/bundler/lib/bundler/source_list.rb +106 -0
- data/bundler/lib/bundler/spec_set.rb +157 -0
- data/bundler/lib/bundler/ssl_certs/.document +1 -0
- data/bundler/lib/bundler/ssl_certs/certificate_manager.rb +65 -0
- data/bundler/lib/bundler/ssl_certs/index.rubygems.org/GlobalSignRootCA.pem +21 -0
- data/bundler/lib/bundler/ssl_certs/rubygems.global.ssl.fastly.net/DigiCertHighAssuranceEVRootCA.pem +23 -0
- data/{lib/rubygems/ssl_certs/rubygems.org/AddTrustExternalCARoot-2048.pem → bundler/lib/bundler/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem} +0 -0
- data/bundler/lib/bundler/stub_specification.rb +24 -0
- data/bundler/lib/bundler/templates/Executable +17 -0
- data/bundler/lib/bundler/templates/Executable.standalone +12 -0
- data/bundler/lib/bundler/templates/Gemfile +5 -0
- data/bundler/lib/bundler/templates/newgem/.travis.yml.tt +5 -0
- data/bundler/lib/bundler/templates/newgem/CODE_OF_CONDUCT.md.tt +74 -0
- data/bundler/lib/bundler/templates/newgem/Gemfile.tt +4 -0
- data/bundler/lib/bundler/templates/newgem/LICENSE.txt.tt +21 -0
- data/bundler/lib/bundler/templates/newgem/README.md.tt +41 -0
- data/bundler/lib/bundler/templates/newgem/Rakefile.tt +29 -0
- data/bundler/lib/bundler/templates/newgem/bin/console.tt +14 -0
- data/bundler/lib/bundler/templates/newgem/bin/setup.tt +8 -0
- data/bundler/lib/bundler/templates/newgem/exe/newgem.tt +3 -0
- data/bundler/lib/bundler/templates/newgem/ext/newgem/extconf.rb.tt +3 -0
- data/bundler/lib/bundler/templates/newgem/ext/newgem/newgem.c.tt +9 -0
- data/bundler/lib/bundler/templates/newgem/ext/newgem/newgem.h.tt +6 -0
- data/bundler/lib/bundler/templates/newgem/gitignore.tt +16 -0
- data/bundler/lib/bundler/templates/newgem/lib/newgem.rb.tt +12 -0
- data/bundler/lib/bundler/templates/newgem/lib/newgem/version.rb.tt +7 -0
- data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +46 -0
- data/bundler/lib/bundler/templates/newgem/rspec.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/spec/newgem_spec.rb.tt +11 -0
- data/bundler/lib/bundler/templates/newgem/spec/spec_helper.rb.tt +2 -0
- data/bundler/lib/bundler/templates/newgem/test/newgem_test.rb.tt +11 -0
- data/bundler/lib/bundler/templates/newgem/test/test_helper.rb.tt +4 -0
- data/bundler/lib/bundler/ui.rb +8 -0
- data/bundler/lib/bundler/ui/rg_proxy.rb +18 -0
- data/bundler/lib/bundler/ui/shell.rb +114 -0
- data/bundler/lib/bundler/ui/silent.rb +48 -0
- data/bundler/lib/bundler/uri_credentials_filter.rb +36 -0
- data/bundler/lib/bundler/vendor/compact_index_client/lib/compact_index_client.rb +79 -0
- data/bundler/lib/bundler/vendor/compact_index_client/lib/compact_index_client/cache.rb +98 -0
- data/bundler/lib/bundler/vendor/compact_index_client/lib/compact_index_client/updater.rb +80 -0
- data/bundler/lib/bundler/vendor/compact_index_client/lib/compact_index_client/version.rb +4 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo.rb +10 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/resolution_state.rb +50 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +80 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +203 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/action.rb +35 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +58 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +61 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +53 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +114 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +45 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +35 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +123 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +75 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +5 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +100 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/ui.rb +65 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +460 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +45 -0
- data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/state.rb +54 -0
- data/bundler/lib/bundler/vendor/net/http/faster.rb +26 -0
- data/bundler/lib/bundler/vendor/net/http/persistent.rb +1230 -0
- data/bundler/lib/bundler/vendor/net/http/persistent/ssl_reuse.rb +128 -0
- data/bundler/lib/bundler/vendor/postit/lib/postit.rb +15 -0
- data/bundler/lib/bundler/vendor/postit/lib/postit/environment.rb +44 -0
- data/bundler/lib/bundler/vendor/postit/lib/postit/installer.rb +28 -0
- data/bundler/lib/bundler/vendor/postit/lib/postit/parser.rb +21 -0
- data/bundler/lib/bundler/vendor/postit/lib/postit/setup.rb +12 -0
- data/bundler/lib/bundler/vendor/postit/lib/postit/version.rb +3 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor.rb +484 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions.rb +319 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_file.rb +103 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_link.rb +59 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/directory.rb +118 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/empty_directory.rb +135 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +316 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +107 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/base.rb +656 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/command.rb +133 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +77 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/io_binary_read.rb +10 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/ordered_hash.rb +98 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/error.rb +32 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/group.rb +281 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/invocation.rb +178 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/line_editor.rb +17 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/line_editor/basic.rb +35 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/line_editor/readline.rb +88 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser.rb +4 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser/argument.rb +73 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +175 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser/option.rb +125 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/parser/options.rb +218 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/rake_compat.rb +71 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/runner.rb +322 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell.rb +81 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +421 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell/color.rb +149 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/shell/html.rb +126 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/util.rb +267 -0
- data/bundler/lib/bundler/vendor/thor/lib/thor/version.rb +3 -0
- data/bundler/lib/bundler/vendored_molinillo.rb +3 -0
- data/bundler/lib/bundler/vendored_persistent.rb +12 -0
- data/bundler/lib/bundler/vendored_thor.rb +4 -0
- data/bundler/lib/bundler/version.rb +11 -0
- data/bundler/lib/bundler/vlad.rb +12 -0
- data/bundler/lib/bundler/worker.rb +82 -0
- data/bundler/lib/bundler/yaml_serializer.rb +67 -0
- data/bundler/man/bundle-config.ronn +193 -0
- data/bundler/man/bundle-exec.ronn +136 -0
- data/bundler/man/bundle-gem.ronn +77 -0
- data/bundler/man/bundle-install.ronn +404 -0
- data/bundler/man/bundle-lock.ronn +47 -0
- data/bundler/man/bundle-package.ronn +67 -0
- data/bundler/man/bundle-platform.ronn +42 -0
- data/bundler/man/bundle-update.ronn +194 -0
- data/bundler/man/bundle.ronn +98 -0
- data/bundler/man/gemfile.5.ronn +499 -0
- data/bundler/man/index.txt +8 -0
- data/lib/rubygems.rb +42 -2
- data/lib/rubygems/config_file.rb +1 -1
- data/lib/rubygems/defaults.rb +18 -0
- data/lib/rubygems/installer.rb +1 -0
- data/lib/rubygems/package.rb +3 -1
- data/lib/rubygems/package/tar_writer.rb +10 -16
- data/lib/rubygems/remote_fetcher.rb +1 -15
- data/lib/rubygems/resolver/molinillo/lib/molinillo/delegates/resolution_state.rb +50 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/delegates/specification_provider.rb +80 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph.rb +57 -145
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/action.rb +35 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +58 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +61 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +53 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/log.rb +114 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/set_payload.rb +45 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/tag.rb +35 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/vertex.rb +123 -0
- data/lib/rubygems/resolver/molinillo/lib/molinillo/errors.rb +1 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/gem_metadata.rb +1 -1
- data/lib/rubygems/resolver/molinillo/lib/molinillo/resolution.rb +55 -54
- data/lib/rubygems/resolver/molinillo/lib/molinillo/state.rb +4 -2
- data/lib/rubygems/security/signer.rb +2 -0
- data/lib/rubygems/specification.rb +4 -4
- data/lib/rubygems/ssl_certs/index.rubygems.org/GlobalSignRootCA.pem +21 -0
- data/lib/rubygems/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem +25 -0
- data/test/rubygems/alternate_cert.pem +10 -9
- data/test/rubygems/alternate_cert_32.pem +10 -9
- data/test/rubygems/child_cert.pem +11 -9
- data/test/rubygems/child_cert_32.pem +11 -9
- data/test/rubygems/encrypted_private_key.pem +26 -26
- data/test/rubygems/expired_cert.pem +9 -8
- data/test/rubygems/future_cert.pem +9 -8
- data/test/rubygems/future_cert_32.pem +9 -8
- data/test/rubygems/grandchild_cert.pem +11 -9
- data/test/rubygems/grandchild_cert_32.pem +11 -9
- data/test/rubygems/invalid_issuer_cert.pem +11 -9
- data/test/rubygems/invalid_issuer_cert_32.pem +11 -9
- data/test/rubygems/invalid_signer_cert.pem +10 -9
- data/test/rubygems/invalid_signer_cert_32.pem +10 -9
- data/test/rubygems/invalidchild_cert.pem +11 -9
- data/test/rubygems/invalidchild_cert_32.pem +11 -9
- data/test/rubygems/public_cert.pem +11 -9
- data/test/rubygems/public_cert_32.pem +10 -9
- data/test/rubygems/test_bundled_ca.rb +1 -1
- data/test/rubygems/test_gem.rb +7 -0
- data/test/rubygems/test_gem_installer.rb +119 -0
- data/test/rubygems/test_gem_package.rb +9 -3
- data/test/rubygems/test_gem_package_tar_writer.rb +24 -0
- data/test/rubygems/test_gem_remote_fetcher.rb +0 -12
- data/test/rubygems/test_gem_security_signer.rb +8 -0
- data/test/rubygems/test_gem_specification.rb +1 -1
- data/test/rubygems/wrong_key_cert.pem +10 -9
- data/test/rubygems/wrong_key_cert_32.pem +10 -9
- data/util/ci +73 -0
- data/util/create_certs.rb +64 -49
- data/util/update_bundled_ca_certificates.rb +23 -2
- metadata +257 -19
- data/lib/gauntlet_rubygems.rb +0 -51
- data/lib/rubygems/ssl_certs/index.rubygems.org/GlobalSignRoot.pem +0 -18
@@ -141,7 +141,9 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
141
141
|
|
142
142
|
FileUtils.mkdir_p 'lib'
|
143
143
|
open 'lib/code.rb', 'w' do |io| io.write '# lib/code.rb' end
|
144
|
-
|
144
|
+
|
145
|
+
# NOTE: 'code.rb' is correct, because it's relative to lib/code_sym.rb
|
146
|
+
File.symlink('code.rb', 'lib/code_sym.rb')
|
145
147
|
|
146
148
|
package = Gem::Package.new 'bogus.gem'
|
147
149
|
package.spec = spec
|
@@ -156,12 +158,16 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
156
158
|
|
157
159
|
Gem::Package::TarReader.new tar do |tar_io|
|
158
160
|
tar_io.each_entry do |entry|
|
159
|
-
|
161
|
+
if entry.symlink?
|
162
|
+
symlinks << { entry.full_name => entry.header.linkname }
|
163
|
+
else
|
164
|
+
files << entry.full_name
|
165
|
+
end
|
160
166
|
end
|
161
167
|
end
|
162
168
|
|
163
169
|
assert_equal %w[lib/code.rb], files
|
164
|
-
assert_equal
|
170
|
+
assert_equal [{'lib/code_sym.rb' => 'lib/code.rb'}], symlinks
|
165
171
|
end
|
166
172
|
|
167
173
|
def test_build
|
@@ -229,6 +229,22 @@ class TestGemPackageTarWriter < Gem::Package::TarTestCase
|
|
229
229
|
|
230
230
|
assert_equal ["#{'qwer/' * 19}bla", 'a' * 151],
|
231
231
|
@tar_writer.split_name("#{'a' * 151}/#{'qwer/' * 19}bla")
|
232
|
+
names = [
|
233
|
+
([''] + ['123456789'] * 9 + ['1234567890']).join('/'), # 101 bytes (several pieces)
|
234
|
+
(['123456789'] * 9 + ['1234567890'] + ['']).join('/'), # 101 bytes (several pieces)
|
235
|
+
'/' * 99,
|
236
|
+
'/' * 100,
|
237
|
+
'/' * 101,
|
238
|
+
'/' * 102,
|
239
|
+
]
|
240
|
+
names.each do |name|
|
241
|
+
newname, prefix = @tar_writer.split_name(name)
|
242
|
+
assert(!(newname.empty?), "split_name() returned empty name")
|
243
|
+
assert(newname.bytesize <= 100, "split_name() returned name longer than 100 bytes: '#{newname}' for '#{name}'")
|
244
|
+
assert(prefix.bytesize <= 155, "split_name() returned prefix longer than 155 bytes: '#{prefix}' for '#{name}'")
|
245
|
+
newname = [prefix, newname].join('/') unless prefix.empty?
|
246
|
+
assert_equal name, newname
|
247
|
+
end
|
232
248
|
end
|
233
249
|
|
234
250
|
def test_split_name_too_long_name
|
@@ -240,6 +256,14 @@ class TestGemPackageTarWriter < Gem::Package::TarTestCase
|
|
240
256
|
@tar_writer.split_name name
|
241
257
|
end
|
242
258
|
assert_includes exception.message, name
|
259
|
+
|
260
|
+
# note, GNU tar 1.28 is unable to handle this case too,
|
261
|
+
# tested with "tar --format=ustar -cPf /tmp/foo.tartar -- /aaaaaa....a"
|
262
|
+
name = '/' + 'a' * 100
|
263
|
+
exception = assert_raises Gem::Package::TooLongFileName do
|
264
|
+
@tar_writer.split_name name
|
265
|
+
end
|
266
|
+
assert_includes exception.message, name
|
243
267
|
end
|
244
268
|
|
245
269
|
def test_split_name_too_long_prefix
|
@@ -81,7 +81,6 @@ gems:
|
|
81
81
|
# Generated via:
|
82
82
|
# x = OpenSSL::PKey::DH.new(2048) # wait a while...
|
83
83
|
# x.to_s => pem
|
84
|
-
# x.priv_key.to_s => hex for OpenSSL::BN.new
|
85
84
|
TEST_KEY_DH2048 = OpenSSL::PKey::DH.new <<-_end_of_pem_
|
86
85
|
-----BEGIN DH PARAMETERS-----
|
87
86
|
MIIBCAKCAQEA3Ze2EHSfYkZLUn557torAmjBgPsqzbodaRaGZtgK1gEU+9nNJaFV
|
@@ -93,17 +92,6 @@ PeIQQkFng2VVot/WAQbv3ePqWq07g1BBcwIBAg==
|
|
93
92
|
-----END DH PARAMETERS-----
|
94
93
|
_end_of_pem_
|
95
94
|
|
96
|
-
TEST_KEY_DH2048.priv_key = OpenSSL::BN.new("108911488509734781344423639" \
|
97
|
-
"5585749502236089033416160524030987005037540379474123441273555416835" \
|
98
|
-
"4725688238369352738266590757370603937618499698665047757588998555345" \
|
99
|
-
"3446251978586372525530219375408331096098220027413238477359960428372" \
|
100
|
-
"0195464393332338164504352015535549496585792320286513563739305843396" \
|
101
|
-
"9294344974028713065472959376197728193162272314514335882399554394661" \
|
102
|
-
"5306385003430991221886779612878793446851681835397455333989268503748" \
|
103
|
-
"7862488679178398716189205737442996155432191656080664090596502674943" \
|
104
|
-
"7902481557157485795980326766117882761941455140582265347052939604724" \
|
105
|
-
"964857770053363840471912215799994973597613931991572884", 16)
|
106
|
-
|
107
95
|
def setup
|
108
96
|
@proxies = %w[https_proxy http_proxy HTTP_PROXY http_proxy_user HTTP_PROXY_USER http_proxy_pass HTTP_PROXY_PASS no_proxy NO_PROXY]
|
109
97
|
@old_proxies = @proxies.map {|k| ENV[k] }
|
@@ -205,5 +205,13 @@ c7NM7KZZjj7G++SXjYTEI1PHSA7aFQ/i/+qSUvx+Pg==
|
|
205
205
|
end
|
206
206
|
end
|
207
207
|
|
208
|
+
def test_sign_no_certs
|
209
|
+
signer = Gem::Security::Signer.new ALTERNATE_KEY, []
|
210
|
+
|
211
|
+
assert_raises Gem::Security::Exception do
|
212
|
+
signer.sign 'hello'
|
213
|
+
end
|
214
|
+
end
|
215
|
+
|
208
216
|
end if defined?(OpenSSL::SSL)
|
209
217
|
|
@@ -3080,7 +3080,7 @@ Did you mean 'Ruby'?
|
|
3080
3080
|
end
|
3081
3081
|
end
|
3082
3082
|
|
3083
|
-
err = 'specification_version must be a
|
3083
|
+
err = 'specification_version must be a Integer (did you mean version?)'
|
3084
3084
|
assert_equal err, e.message
|
3085
3085
|
end
|
3086
3086
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
-----BEGIN CERTIFICATE-----
|
2
|
-
|
3
|
-
ZHkxFzAVBgoJkiaJk/
|
2
|
+
MIIDDTCCAfWgAwIBAgIBEjANBgkqhkiG9w0BAQUFADAqMQ8wDQYDVQQDDAZub2Jv
|
3
|
+
ZHkxFzAVBgoJkiaJk/IsZAEZFgdleGFtcGxlMCAXDTEyMDEwMTAwMDAwMFoYDzk5
|
4
4
|
OTkxMjMxMjM1OTU5WjAqMQ8wDQYDVQQDDAZub2JvZHkxFzAVBgoJkiaJk/IsZAEZ
|
5
5
|
FgdleGFtcGxlMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAvZQipBa1
|
6
6
|
xH3M9OonkrUYhGZeX9UHAcJhe6jJbUr/uHXkh1Tu2ERWNnblm85upqBfjyZEnKer
|
@@ -8,11 +8,12 @@ xH3M9OonkrUYhGZeX9UHAcJhe6jJbUr/uHXkh1Tu2ERWNnblm85upqBfjyZEnKer
|
|
8
8
|
kNyXUmLLGoZ3id2K0eK5C/AJ0j+p84OqPnVhylsjrZmXfIZrh7lkHhgCIrzPefjE
|
9
9
|
3pOloi/tz6fh2ktb0FYKQMfweT3Ba2TMeflG13PEOW80AD5w0THxDutGG0zPNCDy
|
10
10
|
DEoT7UU1a3B3RMHYuUxEk1GUEYWq9L6a6SMpZISWTSpCp0Ww1QB55PONiCCn+o6v
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
11
|
+
cIy46jI71dATAQIDAQABozwwOjAZBgNVHREEEjAQgQ5ub2JvZHlAZXhhbXBsZTAd
|
12
|
+
BgNVHQ4EFgQUyvn/FwcZnA7AkzPjmoooB4/tKgcwDQYJKoZIhvcNAQEFBQADggEB
|
13
|
+
ABswixv3veo8S0Omyhbch3t19xAd/I4ZAx/lq6a/Ubl+X33hRbZQ7ulXja6Y5ZCs
|
14
|
+
iIkezGcpc182e7hZdHuEGGnJ1fJwxz3rbFWvs+MrtRSaCC73HbbxF1x0mQY6Kc7W
|
15
|
+
PahB2v+Dx5n3dIN6ah5p+STUHmzhKGr3bsQswtSHrFn74wt6mBu/hyCz+t6UaQ7b
|
16
|
+
rpRpzDFO1q3tZB8MeIHg57Lk2bu0LtfaHdkGDghNa3t7oZfV5A6pruiTy/EdQvFL
|
17
|
+
ZJpvDgHCyUsDmukMMjz6U4ts+nx7kZ9JoIH9K2lMJo3SGw4iZ8rB+HTfsbUdRfBj
|
18
|
+
UlyNcLqCW+FPlUHgHgNugFA=
|
18
19
|
-----END CERTIFICATE-----
|
@@ -1,6 +1,6 @@
|
|
1
1
|
-----BEGIN CERTIFICATE-----
|
2
|
-
|
3
|
-
ZHkxFzAVBgoJkiaJk/
|
2
|
+
MIIDCzCCAfOgAwIBAgIBEzANBgkqhkiG9w0BAQUFADAqMQ8wDQYDVQQDDAZub2Jv
|
3
|
+
ZHkxFzAVBgoJkiaJk/IsZAEZFgdleGFtcGxlMB4XDTEyMDEwMTAwMDAwMFoXDTM4
|
4
4
|
MDExOTAzMTQwN1owKjEPMA0GA1UEAwwGbm9ib2R5MRcwFQYKCZImiZPyLGQBGRYH
|
5
5
|
ZXhhbXBsZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL2UIqQWtcR9
|
6
6
|
zPTqJ5K1GIRmXl/VBwHCYXuoyW1K/7h15IdU7thEVjZ25ZvObqagX48mRJynq+7g
|
@@ -8,11 +8,12 @@ XMMJJL5orFYAvLgRAsprAcbhCMNK34imBJy7tAekolhWM93WD0vdmwSu1ZLNv5Dc
|
|
8
8
|
l1JiyxqGd4nditHiuQvwCdI/qfODqj51YcpbI62Zl3yGa4e5ZB4YAiK8z3n4xN6T
|
9
9
|
paIv7c+n4dpLW9BWCkDH8Hk9wWtkzHn5RtdzxDlvNAA+cNEx8Q7rRhtMzzQg8gxK
|
10
10
|
E+1FNWtwd0TB2LlMRJNRlBGFqvS+mukjKWSElk0qQqdFsNUAeeTzjYggp/qOr3CM
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
11
|
+
uOoyO9XQEwECAwEAAaM8MDowGQYDVR0RBBIwEIEObm9ib2R5QGV4YW1wbGUwHQYD
|
12
|
+
VR0OBBYEFMr5/xcHGZwOwJMz45qKKAeP7SoHMA0GCSqGSIb3DQEBBQUAA4IBAQCU
|
13
|
+
VkESWkNeiJ1L3MfkMl2ybP2QPWP5nlhz+NOqwOCJSmEXF86Dq2XTY/GgSu1iPp4s
|
14
|
+
pPm1RSpnjujtiV7gjCziNif/XqAxeSjU2deApvq4mknyk958N0IS8c86dUXms1DQ
|
15
|
+
Rncmb3pxxvzP1d6Is35Uwoc5KqheJWR3aDwE8ejaFfO8pq/ncUDB25bc7OyslHMJ
|
16
|
+
7Ah+2YlFjvHYuPvN8bP44UMYyAPZCCJnjIPn7m7giyQiIo6SA9aiLQ8F7+NN3SU4
|
17
|
+
7I9ED0F7RTDxNYISr1sLZ7aNtnXkTAnZclwKohuGfZD3OGAOshLZZXIB2pIRr/Kj
|
18
|
+
6zxTef39tli6orheYQXp
|
18
19
|
-----END CERTIFICATE-----
|
data/util/ci
ADDED
@@ -0,0 +1,73 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
class Tool
|
4
|
+
def initialize(name)
|
5
|
+
@name = name
|
6
|
+
end
|
7
|
+
|
8
|
+
def bundler?
|
9
|
+
@name == 'bundler'
|
10
|
+
end
|
11
|
+
|
12
|
+
def rubygems?
|
13
|
+
@name == 'rubygems'
|
14
|
+
end
|
15
|
+
|
16
|
+
def dir
|
17
|
+
if rubygems?
|
18
|
+
File.expand_path('../..', __FILE__)
|
19
|
+
else
|
20
|
+
File.expand_path('../../bundler', __FILE__)
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
TOOL = Tool.new(ENV.fetch("TEST_TOOL") { abort "must specify a TEST_TOOL" })
|
26
|
+
|
27
|
+
def run(command, args = [])
|
28
|
+
Dir.chdir(TOOL.dir) do
|
29
|
+
unless system(command, *args)
|
30
|
+
abort "running `#{command} #{args.join(" ")}` failed"
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
def with_retries(attempts = 3)
|
36
|
+
yield
|
37
|
+
rescue
|
38
|
+
attempts -= 1
|
39
|
+
if attempts > 0
|
40
|
+
warn "Command failed. Retrying #{attempts -= 1} more times."
|
41
|
+
retry
|
42
|
+
else
|
43
|
+
raise
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
case ARGV
|
48
|
+
when %w(before_script)
|
49
|
+
if TOOL.rubygems?
|
50
|
+
run('gem', %W(uninstall executable-hooks gem-wrappers -x --force -i #{`gem env home`.strip}@global))
|
51
|
+
run('gem', %W(install rake -v #{'~> 10.5'} --no-document))
|
52
|
+
run('gem', %W(install hoe -v #{'3.15.0'} --no-document))
|
53
|
+
run('gem', %w(install hoe-travis --no-document))
|
54
|
+
run('gem', %W(install minitest -v #{'~> 4.7'} --no-document))
|
55
|
+
run('rake', %w(travis:before -t))
|
56
|
+
run('gem', %w(list --details))
|
57
|
+
run('gem', %w(env))
|
58
|
+
else
|
59
|
+
with_retries { run('rake', %w(spec:travis:deps)) }
|
60
|
+
end
|
61
|
+
when %w(after_script)
|
62
|
+
if TOOL.rubygems?
|
63
|
+
run('rake', %w(travis:after -t))
|
64
|
+
end
|
65
|
+
when %w(script)
|
66
|
+
if TOOL.rubygems?
|
67
|
+
run('rake', %w(travis))
|
68
|
+
else
|
69
|
+
run('rake', %w(spec:travis -t))
|
70
|
+
end
|
71
|
+
else
|
72
|
+
abort "unknown args #{ARGV.inspect}"
|
73
|
+
end
|
data/util/create_certs.rb
CHANGED
@@ -4,37 +4,41 @@ require 'time'
|
|
4
4
|
|
5
5
|
class CertificateBuilder
|
6
6
|
|
7
|
-
attr_reader :
|
7
|
+
attr_reader :start
|
8
8
|
|
9
9
|
def initialize key_size = 2048
|
10
|
-
|
11
|
-
@today = Time.utc today.year, today.month, today.day
|
10
|
+
@start = Time.utc 2012, 01, 01, 00, 00, 00
|
12
11
|
@end_of_time = Time.utc 9999, 12, 31, 23, 59, 59
|
13
12
|
@end_of_time_32 = Time.utc 2038, 01, 19, 03, 14, 07
|
14
13
|
|
14
|
+
@key_size = key_size
|
15
15
|
@serial = 0
|
16
16
|
end
|
17
17
|
|
18
|
-
def create_certificates(key, subject, issuer_key = key,
|
19
|
-
not_before: @
|
18
|
+
def create_certificates(key, subject, issuer_key = key, issuer_cert = nil,
|
19
|
+
not_before: @start, not_after: :end_of_time,
|
20
|
+
is_ca: false)
|
20
21
|
certificates = []
|
21
22
|
|
22
23
|
not_before, not_before_32 = validity_for not_before
|
23
24
|
not_after, not_after_32 = validity_for not_after
|
25
|
+
issuer_cert, issuer_cert_32 = issuer_cert
|
24
26
|
|
25
27
|
certificates <<
|
26
|
-
create_certificate(key, subject, issuer_key,
|
27
|
-
not_before, not_after)
|
28
|
+
create_certificate(key, subject, issuer_key, issuer_cert,
|
29
|
+
not_before, not_after, is_ca)
|
28
30
|
certificates <<
|
29
|
-
create_certificate(key, subject, issuer_key,
|
30
|
-
not_before_32, not_after_32)
|
31
|
+
create_certificate(key, subject, issuer_key, issuer_cert_32,
|
32
|
+
not_before_32, not_after_32, is_ca)
|
31
33
|
|
32
34
|
certificates
|
33
35
|
end
|
34
36
|
|
35
|
-
def create_certificate
|
36
|
-
|
37
|
+
def create_certificate(key, subject, issuer_key, issuer_cert,
|
38
|
+
not_before, not_after, is_ca)
|
37
39
|
cert = OpenSSL::X509::Certificate.new
|
40
|
+
issuer_cert ||= cert # if not specified, create self signing cert
|
41
|
+
|
38
42
|
cert.version = 2
|
39
43
|
cert.serial = 0
|
40
44
|
|
@@ -45,25 +49,34 @@ class CertificateBuilder
|
|
45
49
|
|
46
50
|
cert.public_key = key.public_key
|
47
51
|
|
48
|
-
cert.subject =
|
49
|
-
|
50
|
-
cert.issuer =
|
51
|
-
OpenSSL::X509::Name.new [%W[CN #{issuer}], %w[DC example]]
|
52
|
+
cert.subject = OpenSSL::X509::Name.new [%W[CN #{subject}], %w[DC example]]
|
53
|
+
cert.issuer = issuer_cert.subject
|
52
54
|
|
53
|
-
ef = OpenSSL::X509::ExtensionFactory.new
|
55
|
+
ef = OpenSSL::X509::ExtensionFactory.new issuer_cert, cert
|
54
56
|
|
55
57
|
cert.extensions = [
|
56
|
-
ef.create_extension('subjectAltName', "email:#{subject}@example")
|
58
|
+
ef.create_extension('subjectAltName', "email:#{subject}@example"),
|
59
|
+
ef.create_extension('subjectKeyIdentifier', 'hash')
|
57
60
|
]
|
58
61
|
|
62
|
+
if cert != issuer_cert then # not self-signed cert
|
63
|
+
cert.add_extension ef.create_extension('authorityKeyIdentifier', 'keyid:always')
|
64
|
+
end
|
65
|
+
|
66
|
+
if is_ca then
|
67
|
+
cert.add_extension ef.create_extension('basicConstraints', 'CA:TRUE', true)
|
68
|
+
cert.add_extension ef.create_extension('keyUsage', 'keyCertSign', true)
|
69
|
+
end
|
70
|
+
|
59
71
|
cert.sign issuer_key, OpenSSL::Digest::SHA1.new
|
60
72
|
|
73
|
+
puts "created cert - subject: #{cert.subject}, issuer: #{cert.issuer}"
|
61
74
|
cert
|
62
75
|
end
|
63
76
|
|
64
77
|
def create_key
|
65
78
|
puts "creating key"
|
66
|
-
OpenSSL::PKey::RSA.new
|
79
|
+
OpenSSL::PKey::RSA.new @key_size
|
67
80
|
end
|
68
81
|
|
69
82
|
def create_keys names
|
@@ -108,37 +121,39 @@ keys = cb.create_keys [
|
|
108
121
|
|
109
122
|
keys[:public] = keys[:private].public_key
|
110
123
|
|
111
|
-
certs = {
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
124
|
+
certs = {}
|
125
|
+
certs[:public] =
|
126
|
+
cb.create_certificates(keys[:private], 'nobody',
|
127
|
+
is_ca: true)
|
128
|
+
certs[:child] =
|
129
|
+
cb.create_certificates(keys[:child], 'child',
|
130
|
+
keys[:private], certs[:public],
|
131
|
+
is_ca: true)
|
132
|
+
certs[:alternate] =
|
133
|
+
cb.create_certificates(keys[:alternate], 'alternate')
|
134
|
+
certs[:expired] =
|
135
|
+
cb.create_certificates(keys[:private], 'nobody',
|
136
|
+
not_before: Time.at(0),
|
137
|
+
not_after: Time.at(0))
|
138
|
+
certs[:future] =
|
139
|
+
cb.create_certificates(keys[:private], 'nobody',
|
140
|
+
not_before: :end_of_time,
|
141
|
+
not_after: :end_of_time)
|
142
|
+
certs[:invalid_issuer] =
|
143
|
+
cb.create_certificates(keys[:invalid], 'invalid',
|
144
|
+
keys[:invalid], certs[:public],
|
145
|
+
is_ca: true)
|
146
|
+
certs[:grandchild] =
|
147
|
+
cb.create_certificates(keys[:grandchild], 'grandchild',
|
148
|
+
keys[:child], certs[:child])
|
149
|
+
certs[:invalid_signer] =
|
150
|
+
cb.create_certificates(keys[:invalid], 'invalid',
|
151
|
+
keys[:private], certs[:invalid])
|
152
|
+
certs[:invalidchild] =
|
153
|
+
cb.create_certificates(keys[:invalidchild], 'invalidchild',
|
154
|
+
keys[:invalid], certs[:child])
|
155
|
+
certs[:wrong_key] =
|
156
|
+
cb.create_certificates(keys[:alternate], 'nobody')
|
142
157
|
|
143
158
|
base_dir = 'test/rubygems'
|
144
159
|
|
@@ -1,6 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
require 'net/http'
|
3
3
|
require 'openssl'
|
4
|
+
require 'fileutils'
|
4
5
|
|
5
6
|
URIS = [
|
6
7
|
URI('https://rubygems.org'),
|
@@ -10,6 +11,12 @@ URIS = [
|
|
10
11
|
URI('https://rubygems.global.ssl.fastly.net'),
|
11
12
|
]
|
12
13
|
|
14
|
+
HOSTNAMES_TO_MAP = [
|
15
|
+
'rubygems.global.ssl.fastly.net',
|
16
|
+
'rubygems.org',
|
17
|
+
'index.rubygems.org'
|
18
|
+
]
|
19
|
+
|
13
20
|
def connect_to uri, store
|
14
21
|
# None of the URIs are IPv6, so URI::Generic#hostname(ruby 1.9.3+) isn't needed
|
15
22
|
http = Net::HTTP.new uri.host, uri.port
|
@@ -79,13 +86,27 @@ def test_uri uri, certificates
|
|
79
86
|
nil
|
80
87
|
end
|
81
88
|
|
89
|
+
def hostname_certificate_mapping certificates
|
90
|
+
mapping = {}
|
91
|
+
HOSTNAMES_TO_MAP.each do |hostname|
|
92
|
+
uri = URI("https://#{hostname}")
|
93
|
+
certificates.each do |cert|
|
94
|
+
match = test_uri uri, [cert]
|
95
|
+
mapping[hostname] = cert if match && !mapping.values.include?(cert)
|
96
|
+
end
|
97
|
+
end
|
98
|
+
mapping
|
99
|
+
end
|
100
|
+
|
82
101
|
def write_certificates certificates
|
83
|
-
|
102
|
+
mapping = hostname_certificate_mapping(certificates)
|
103
|
+
mapping.each do |hostname, certificate|
|
84
104
|
subject = certificate.subject.to_a
|
85
105
|
name = (subject.assoc('CN') || subject.assoc('OU'))[1]
|
86
106
|
name = name.delete ' .-'
|
87
107
|
|
88
|
-
|
108
|
+
FileUtils.mkdir_p("lib/rubygems/ssl_certs/#{hostname}")
|
109
|
+
destination = "lib/rubygems/ssl_certs/#{hostname}/#{name}.pem"
|
89
110
|
|
90
111
|
warn "overwriting certificate #{name}" if File.exist? destination
|
91
112
|
|