rubygems-update 3.3.18 → 3.3.19
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +24 -0
- data/Manifest.txt +1 -0
- data/bin/gem +2 -2
- data/bin/update_rubygems +4 -4
- data/bundler/CHANGELOG.md +29 -0
- data/bundler/lib/bundler/build_metadata.rb +2 -2
- data/bundler/lib/bundler/cli/common.rb +1 -0
- data/bundler/lib/bundler/definition.rb +31 -12
- data/bundler/lib/bundler/dsl.rb +2 -2
- data/bundler/lib/bundler/incomplete_specification.rb +12 -0
- data/bundler/lib/bundler/index.rb +10 -12
- data/bundler/lib/bundler/lazy_specification.rb +15 -6
- data/bundler/lib/bundler/man/bundle-add.1 +1 -1
- data/bundler/lib/bundler/man/bundle-binstubs.1 +1 -1
- data/bundler/lib/bundler/man/bundle-cache.1 +1 -1
- data/bundler/lib/bundler/man/bundle-check.1 +1 -1
- data/bundler/lib/bundler/man/bundle-clean.1 +1 -1
- data/bundler/lib/bundler/man/bundle-config.1 +13 -3
- data/bundler/lib/bundler/man/bundle-config.1.ronn +9 -2
- data/bundler/lib/bundler/man/bundle-doctor.1 +1 -1
- data/bundler/lib/bundler/man/bundle-exec.1 +2 -2
- data/bundler/lib/bundler/man/bundle-exec.1.ronn +1 -1
- data/bundler/lib/bundler/man/bundle-gem.1 +1 -1
- data/bundler/lib/bundler/man/bundle-info.1 +1 -1
- data/bundler/lib/bundler/man/bundle-init.1 +1 -1
- data/bundler/lib/bundler/man/bundle-inject.1 +5 -2
- data/bundler/lib/bundler/man/bundle-inject.1.ronn +3 -1
- data/bundler/lib/bundler/man/bundle-install.1 +1 -1
- data/bundler/lib/bundler/man/bundle-list.1 +1 -1
- data/bundler/lib/bundler/man/bundle-lock.1 +1 -1
- data/bundler/lib/bundler/man/bundle-open.1 +1 -1
- data/bundler/lib/bundler/man/bundle-outdated.1 +1 -1
- data/bundler/lib/bundler/man/bundle-platform.1 +1 -1
- data/bundler/lib/bundler/man/bundle-pristine.1 +1 -1
- data/bundler/lib/bundler/man/bundle-remove.1 +1 -1
- data/bundler/lib/bundler/man/bundle-show.1 +1 -1
- data/bundler/lib/bundler/man/bundle-update.1 +1 -1
- data/bundler/lib/bundler/man/bundle-viz.1 +4 -1
- data/bundler/lib/bundler/man/bundle-viz.1.ronn +2 -0
- data/bundler/lib/bundler/man/bundle.1 +3 -3
- data/bundler/lib/bundler/man/bundle.1.ronn +2 -2
- data/bundler/lib/bundler/man/gemfile.5 +16 -10
- data/bundler/lib/bundler/man/gemfile.5.ronn +23 -16
- data/bundler/lib/bundler/remote_specification.rb +5 -4
- data/bundler/lib/bundler/resolver.rb +5 -6
- data/bundler/lib/bundler/rubygems_gem_installer.rb +19 -12
- data/bundler/lib/bundler/settings.rb +1 -0
- data/bundler/lib/bundler/spec_set.rb +29 -21
- data/bundler/lib/bundler/version.rb +1 -1
- data/bundler/lib/bundler.rb +1 -0
- data/lib/rubygems/basic_specification.rb +2 -2
- data/lib/rubygems/command.rb +19 -19
- data/lib/rubygems/command_manager.rb +9 -9
- data/lib/rubygems/commands/build_command.rb +8 -8
- data/lib/rubygems/commands/cert_command.rb +32 -32
- data/lib/rubygems/commands/check_command.rb +20 -20
- data/lib/rubygems/commands/cleanup_command.rb +16 -16
- data/lib/rubygems/commands/contents_command.rb +12 -12
- data/lib/rubygems/commands/dependency_command.rb +12 -12
- data/lib/rubygems/commands/environment_command.rb +5 -5
- data/lib/rubygems/commands/fetch_command.rb +6 -6
- data/lib/rubygems/commands/generate_index_command.rb +15 -15
- data/lib/rubygems/commands/help_command.rb +3 -3
- data/lib/rubygems/commands/info_command.rb +3 -3
- data/lib/rubygems/commands/install_command.rb +13 -13
- data/lib/rubygems/commands/list_command.rb +3 -3
- data/lib/rubygems/commands/lock_command.rb +4 -4
- data/lib/rubygems/commands/mirror_command.rb +3 -3
- data/lib/rubygems/commands/open_command.rb +9 -9
- data/lib/rubygems/commands/outdated_command.rb +5 -5
- data/lib/rubygems/commands/owner_command.rb +11 -11
- data/lib/rubygems/commands/pristine_command.rb +31 -31
- data/lib/rubygems/commands/push_command.rb +8 -8
- data/lib/rubygems/commands/query_command.rb +8 -8
- data/lib/rubygems/commands/rdoc_command.rb +17 -17
- data/lib/rubygems/commands/search_command.rb +3 -3
- data/lib/rubygems/commands/server_command.rb +3 -3
- data/lib/rubygems/commands/setup_command.rb +92 -102
- data/lib/rubygems/commands/signin_command.rb +9 -9
- data/lib/rubygems/commands/signout_command.rb +7 -7
- data/lib/rubygems/commands/sources_command.rb +19 -19
- data/lib/rubygems/commands/specification_command.rb +11 -11
- data/lib/rubygems/commands/stale_command.rb +2 -2
- data/lib/rubygems/commands/uninstall_command.rb +36 -36
- data/lib/rubygems/commands/unpack_command.rb +12 -12
- data/lib/rubygems/commands/update_command.rb +35 -51
- data/lib/rubygems/commands/which_command.rb +6 -6
- data/lib/rubygems/commands/yank_command.rb +11 -11
- data/lib/rubygems/config_file.rb +14 -14
- data/lib/rubygems/core_ext/kernel_gem.rb +1 -1
- data/lib/rubygems/core_ext/kernel_require.rb +1 -1
- data/lib/rubygems/core_ext/kernel_warn.rb +1 -1
- data/lib/rubygems/core_ext/tcpsocket_init.rb +1 -1
- data/lib/rubygems/defaults.rb +15 -15
- data/lib/rubygems/dependency.rb +4 -4
- data/lib/rubygems/dependency_installer.rb +8 -8
- data/lib/rubygems/dependency_list.rb +2 -2
- data/lib/rubygems/doctor.rb +16 -16
- data/lib/rubygems/errors.rb +2 -2
- data/lib/rubygems/exceptions.rb +4 -4
- data/lib/rubygems/ext/build_error.rb +1 -1
- data/lib/rubygems/ext/builder.rb +16 -16
- data/lib/rubygems/ext/cargo_builder.rb +7 -7
- data/lib/rubygems/ext/cmake_builder.rb +2 -2
- data/lib/rubygems/ext/configure_builder.rb +1 -1
- data/lib/rubygems/ext/ext_conf_builder.rb +6 -6
- data/lib/rubygems/ext/rake_builder.rb +3 -3
- data/lib/rubygems/ext.rb +7 -7
- data/lib/rubygems/gem_runner.rb +5 -5
- data/lib/rubygems/gemcutter_utilities.rb +30 -27
- data/lib/rubygems/indexer.rb +24 -24
- data/lib/rubygems/install_default_message.rb +2 -2
- data/lib/rubygems/install_message.rb +2 -2
- data/lib/rubygems/install_update_options.rb +55 -55
- data/lib/rubygems/installer.rb +27 -27
- data/lib/rubygems/installer_uninstaller_utils.rb +2 -2
- data/lib/rubygems/local_remote_options.rb +18 -20
- data/lib/rubygems/mock_gem_ui.rb +2 -2
- data/lib/rubygems/name_tuple.rb +1 -1
- data/lib/rubygems/optparse.rb +1 -1
- data/lib/rubygems/package/file_source.rb +2 -2
- data/lib/rubygems/package/old.rb +8 -8
- data/lib/rubygems/package/tar_header.rb +33 -33
- data/lib/rubygems/package/tar_reader/entry.rb +2 -2
- data/lib/rubygems/package/tar_reader.rb +1 -1
- data/lib/rubygems/package/tar_writer.rb +6 -6
- data/lib/rubygems/package.rb +35 -35
- data/lib/rubygems/package_task.rb +4 -4
- data/lib/rubygems/platform.rb +42 -42
- data/lib/rubygems/psych_tree.rb +1 -1
- data/lib/rubygems/query_utils.rb +27 -27
- data/lib/rubygems/rdoc.rb +2 -2
- data/lib/rubygems/remote_fetcher.rb +19 -19
- data/lib/rubygems/request/connection_pools.rb +2 -2
- data/lib/rubygems/request.rb +21 -21
- data/lib/rubygems/request_set/gem_dependency_api.rb +15 -15
- data/lib/rubygems/request_set/lockfile/parser.rb +14 -14
- data/lib/rubygems/request_set/lockfile/tokenizer.rb +2 -2
- data/lib/rubygems/request_set/lockfile.rb +5 -5
- data/lib/rubygems/request_set.rb +14 -14
- data/lib/rubygems/requirement.rb +5 -5
- data/lib/rubygems/resolver/activation_request.rb +3 -3
- data/lib/rubygems/resolver/api_set.rb +4 -4
- data/lib/rubygems/resolver/api_specification.rb +2 -2
- data/lib/rubygems/resolver/best_set.rb +2 -2
- data/lib/rubygems/resolver/conflict.rb +7 -7
- data/lib/rubygems/resolver/dependency_request.rb +2 -2
- data/lib/rubygems/resolver/git_set.rb +2 -2
- data/lib/rubygems/resolver/git_specification.rb +3 -3
- data/lib/rubygems/resolver/index_set.rb +3 -3
- data/lib/rubygems/resolver/index_specification.rb +3 -3
- data/lib/rubygems/resolver/installed_specification.rb +2 -2
- data/lib/rubygems/resolver/installer_set.rb +4 -4
- data/lib/rubygems/resolver/local_specification.rb +2 -2
- data/lib/rubygems/resolver/lock_set.rb +3 -3
- data/lib/rubygems/resolver/lock_specification.rb +3 -3
- data/lib/rubygems/resolver/molinillo.rb +1 -1
- data/lib/rubygems/resolver/specification.rb +1 -1
- data/lib/rubygems/resolver/vendor_set.rb +1 -1
- data/lib/rubygems/resolver.rb +35 -35
- data/lib/rubygems/s3_uri_signer.rb +6 -6
- data/lib/rubygems/safe_yaml.rb +2 -2
- data/lib/rubygems/security/policies.rb +11 -11
- data/lib/rubygems/security/policy.rb +12 -12
- data/lib/rubygems/security/signer.rb +4 -4
- data/lib/rubygems/security/trust_dir.rb +3 -3
- data/lib/rubygems/security.rb +27 -27
- data/lib/rubygems/security_option.rb +5 -5
- data/lib/rubygems/source/git.rb +17 -17
- data/lib/rubygems/source/installed.rb +1 -1
- data/lib/rubygems/source/local.rb +2 -2
- data/lib/rubygems/source/specific_file.rb +1 -1
- data/lib/rubygems/source.rb +15 -15
- data/lib/rubygems/spec_fetcher.rb +8 -8
- data/lib/rubygems/specification.rb +37 -38
- data/lib/rubygems/specification_policy.rb +13 -13
- data/lib/rubygems/stub_specification.rb +5 -5
- data/lib/rubygems/tsort.rb +1 -1
- data/lib/rubygems/uninstaller.rb +14 -14
- data/lib/rubygems/uri.rb +4 -4
- data/lib/rubygems/uri_formatter.rb +1 -1
- data/lib/rubygems/user_interaction.rb +31 -17
- data/lib/rubygems/util/licenses.rb +3 -3
- data/lib/rubygems/util.rb +10 -10
- data/lib/rubygems/validator.rb +5 -5
- data/lib/rubygems/version.rb +3 -5
- data/lib/rubygems/version_option.rb +3 -3
- data/lib/rubygems.rb +59 -58
- data/rubygems-update.gemspec +2 -2
- data/setup.rb +9 -9
- data/test/rubygems/helper.rb +127 -127
- data/test/rubygems/installer_test_case.rb +13 -13
- data/test/rubygems/package/tar_test_case.rb +2 -2
- data/test/rubygems/plugin/exception/rubygems_plugin.rb +1 -1
- data/test/rubygems/plugin/standarderror/rubygems_plugin.rb +1 -1
- data/test/rubygems/rubygems_plugin.rb +2 -2
- data/test/rubygems/specifications/rubyforge-0.0.1.gemspec +4 -4
- data/test/rubygems/test_bundled_ca.rb +10 -10
- data/test/rubygems/test_config.rb +3 -3
- data/test/rubygems/test_deprecate.rb +3 -3
- data/test/rubygems/test_exit.rb +2 -2
- data/test/rubygems/test_gem.rb +342 -342
- data/test/rubygems/test_gem_available_set.rb +21 -21
- data/test/rubygems/test_gem_bundler_version_finder.rb +1 -1
- data/test/rubygems/test_gem_command.rb +44 -44
- data/test/rubygems/test_gem_command_manager.rb +29 -29
- data/test/rubygems/test_gem_commands_build_command.rb +63 -63
- data/test/rubygems/test_gem_commands_cert_command.rb +97 -99
- data/test/rubygems/test_gem_commands_check_command.rb +4 -4
- data/test/rubygems/test_gem_commands_cleanup_command.rb +40 -40
- data/test/rubygems/test_gem_commands_contents_command.rb +27 -27
- data/test/rubygems/test_gem_commands_dependency_command.rb +36 -36
- data/test/rubygems/test_gem_commands_environment_command.rb +16 -16
- data/test/rubygems/test_gem_commands_fetch_command.rb +37 -37
- data/test/rubygems/test_gem_commands_generate_index_command.rb +7 -7
- data/test/rubygems/test_gem_commands_help_command.rb +13 -13
- data/test/rubygems/test_gem_commands_info_command.rb +2 -2
- data/test/rubygems/test_gem_commands_install_command.rb +131 -131
- data/test/rubygems/test_gem_commands_list_command.rb +4 -4
- data/test/rubygems/test_gem_commands_lock_command.rb +10 -10
- data/test/rubygems/test_gem_commands_mirror.rb +2 -2
- data/test/rubygems/test_gem_commands_open_command.rb +4 -4
- data/test/rubygems/test_gem_commands_outdated_command.rb +9 -9
- data/test/rubygems/test_gem_commands_owner_command.rb +41 -41
- data/test/rubygems/test_gem_commands_pristine_command.rb +92 -92
- data/test/rubygems/test_gem_commands_push_command.rb +54 -54
- data/test/rubygems/test_gem_commands_query_command.rb +73 -73
- data/test/rubygems/test_gem_commands_search_command.rb +2 -2
- data/test/rubygems/test_gem_commands_server_command.rb +2 -2
- data/test/rubygems/test_gem_commands_setup_command.rb +119 -85
- data/test/rubygems/test_gem_commands_signin_command.rb +45 -31
- data/test/rubygems/test_gem_commands_signout_command.rb +3 -3
- data/test/rubygems/test_gem_commands_sources_command.rb +28 -29
- data/test/rubygems/test_gem_commands_specification_command.rb +32 -32
- data/test/rubygems/test_gem_commands_stale_command.rb +4 -4
- data/test/rubygems/test_gem_commands_uninstall_command.rb +75 -75
- data/test/rubygems/test_gem_commands_unpack_command.rb +31 -31
- data/test/rubygems/test_gem_commands_update_command.rb +89 -89
- data/test/rubygems/test_gem_commands_which_command.rb +6 -6
- data/test/rubygems/test_gem_commands_yank_command.rb +40 -40
- data/test/rubygems/test_gem_config_file.rb +77 -77
- data/test/rubygems/test_gem_dependency.rb +73 -73
- data/test/rubygems/test_gem_dependency_installer.rb +165 -165
- data/test/rubygems/test_gem_dependency_list.rb +47 -47
- data/test/rubygems/test_gem_dependency_resolution_error.rb +4 -4
- data/test/rubygems/test_gem_doctor.rb +26 -26
- data/test/rubygems/test_gem_ext_builder.rb +59 -59
- data/test/rubygems/test_gem_ext_cargo_builder/custom_name/Cargo.lock +6 -6
- data/test/rubygems/test_gem_ext_cargo_builder/custom_name/Cargo.toml +1 -1
- data/test/rubygems/test_gem_ext_cargo_builder/custom_name/build.rb +8 -8
- data/test/rubygems/test_gem_ext_cargo_builder/custom_name/custom_name.gemspec +1 -1
- data/test/rubygems/test_gem_ext_cargo_builder/rust_ruby_example/Cargo.lock +6 -6
- data/test/rubygems/test_gem_ext_cargo_builder/rust_ruby_example/Cargo.toml +1 -1
- data/test/rubygems/test_gem_ext_cargo_builder/rust_ruby_example/build.rb +8 -8
- data/test/rubygems/test_gem_ext_cargo_builder.rb +26 -26
- data/test/rubygems/test_gem_ext_cargo_builder_link_flag_converter.rb +3 -3
- data/test/rubygems/test_gem_ext_cargo_builder_unit.rb +23 -23
- data/test/rubygems/test_gem_ext_cmake_builder.rb +15 -15
- data/test/rubygems/test_gem_ext_configure_builder.rb +13 -13
- data/test/rubygems/test_gem_ext_ext_conf_builder.rb +51 -52
- data/test/rubygems/test_gem_ext_rake_builder.rb +15 -15
- data/test/rubygems/test_gem_gem_runner.rb +7 -7
- data/test/rubygems/test_gem_gemcutter_utilities.rb +66 -66
- data/test/rubygems/test_gem_impossible_dependencies_error.rb +4 -4
- data/test/rubygems/test_gem_indexer.rb +48 -48
- data/test/rubygems/test_gem_install_update_options.rb +16 -16
- data/test/rubygems/test_gem_installer.rb +297 -297
- data/test/rubygems/test_gem_local_remote_options.rb +10 -10
- data/test/rubygems/test_gem_name_tuple.rb +4 -4
- data/test/rubygems/test_gem_package.rb +206 -206
- data/test/rubygems/test_gem_package_old.rb +13 -13
- data/test/rubygems/test_gem_package_tar_header.rb +42 -42
- data/test/rubygems/test_gem_package_tar_reader.rb +7 -7
- data/test/rubygems/test_gem_package_tar_reader_entry.rb +10 -10
- data/test/rubygems/test_gem_package_tar_writer.rb +76 -76
- data/test/rubygems/test_gem_package_task.rb +18 -18
- data/test/rubygems/test_gem_path_support.rb +14 -14
- data/test/rubygems/test_gem_platform.rb +227 -227
- data/test/rubygems/test_gem_rdoc.rb +14 -14
- data/test/rubygems/test_gem_remote_fetcher.rb +149 -149
- data/test/rubygems/test_gem_request.rb +55 -55
- data/test/rubygems/test_gem_request_connection_pools.rb +29 -29
- data/test/rubygems/test_gem_request_set.rb +99 -99
- data/test/rubygems/test_gem_request_set_gem_dependency_api.rb +204 -206
- data/test/rubygems/test_gem_request_set_lockfile.rb +86 -86
- data/test/rubygems/test_gem_request_set_lockfile_parser.rb +56 -56
- data/test/rubygems/test_gem_request_set_lockfile_tokenizer.rb +62 -62
- data/test/rubygems/test_gem_requirement.rb +38 -38
- data/test/rubygems/test_gem_resolver.rb +98 -98
- data/test/rubygems/test_gem_resolver_activation_request.rb +6 -6
- data/test/rubygems/test_gem_resolver_api_set.rb +33 -33
- data/test/rubygems/test_gem_resolver_api_specification.rb +47 -47
- data/test/rubygems/test_gem_resolver_best_set.rb +22 -22
- data/test/rubygems/test_gem_resolver_composed_set.rb +1 -1
- data/test/rubygems/test_gem_resolver_conflict.rb +12 -12
- data/test/rubygems/test_gem_resolver_dependency_request.rb +15 -15
- data/test/rubygems/test_gem_resolver_git_set.rb +21 -21
- data/test/rubygems/test_gem_resolver_git_specification.rb +21 -21
- data/test/rubygems/test_gem_resolver_index_set.rb +12 -12
- data/test/rubygems/test_gem_resolver_index_specification.rb +15 -15
- data/test/rubygems/test_gem_resolver_installed_specification.rb +5 -5
- data/test/rubygems/test_gem_resolver_installer_set.rb +34 -34
- data/test/rubygems/test_gem_resolver_local_specification.rb +7 -7
- data/test/rubygems/test_gem_resolver_lock_set.rb +12 -12
- data/test/rubygems/test_gem_resolver_lock_specification.rb +17 -17
- data/test/rubygems/test_gem_resolver_requirement_list.rb +1 -1
- data/test/rubygems/test_gem_resolver_specification.rb +8 -8
- data/test/rubygems/test_gem_resolver_vendor_set.rb +6 -6
- data/test/rubygems/test_gem_resolver_vendor_specification.rb +10 -10
- data/test/rubygems/test_gem_security.rb +67 -67
- data/test/rubygems/test_gem_security_policy.rb +62 -62
- data/test/rubygems/test_gem_security_signer.rb +28 -28
- data/test/rubygems/test_gem_security_trust_dir.rb +4 -4
- data/test/rubygems/test_gem_silent_ui.rb +38 -32
- data/test/rubygems/test_gem_source.rb +44 -44
- data/test/rubygems/test_gem_source_fetch_problem.rb +9 -9
- data/test/rubygems/test_gem_source_git.rb +59 -59
- data/test/rubygems/test_gem_source_installed.rb +16 -16
- data/test/rubygems/test_gem_source_list.rb +5 -5
- data/test/rubygems/test_gem_source_local.rb +14 -14
- data/test/rubygems/test_gem_source_lock.rb +31 -31
- data/test/rubygems/test_gem_source_specific_file.rb +17 -17
- data/test/rubygems/test_gem_source_subpath_problem.rb +7 -7
- data/test/rubygems/test_gem_source_vendor.rb +13 -13
- data/test/rubygems/test_gem_spec_fetcher.rb +72 -72
- data/test/rubygems/test_gem_specification.rb +434 -435
- data/test/rubygems/test_gem_stream_ui.rb +19 -19
- data/test/rubygems/test_gem_stub_specification.rb +32 -32
- data/test/rubygems/test_gem_text.rb +1 -1
- data/test/rubygems/test_gem_uninstaller.rb +112 -112
- data/test/rubygems/test_gem_unsatisfiable_dependency_error.rb +3 -3
- data/test/rubygems/test_gem_uri.rb +4 -4
- data/test/rubygems/test_gem_uri_formatter.rb +14 -14
- data/test/rubygems/test_gem_util.rb +23 -23
- data/test/rubygems/test_gem_validator.rb +8 -8
- data/test/rubygems/test_gem_version.rb +13 -13
- data/test/rubygems/test_gem_version_option.rb +15 -15
- data/test/rubygems/test_kernel.rb +31 -31
- data/test/rubygems/test_project_sanity.rb +1 -1
- data/test/rubygems/test_remote_fetch_error.rb +6 -6
- data/test/rubygems/test_require.rb +42 -42
- data/test/rubygems/test_rubygems.rb +8 -8
- data/test/rubygems/utilities.rb +17 -17
- metadata +4 -3
@@ -1,14 +1,14 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require_relative
|
4
|
-
require
|
3
|
+
require_relative "package/tar_test_case"
|
4
|
+
require "rubygems/openssl"
|
5
5
|
|
6
6
|
class TestGemPackage < Gem::Package::TarTestCase
|
7
7
|
def setup
|
8
8
|
super
|
9
9
|
|
10
|
-
@spec = quick_gem
|
11
|
-
s.description =
|
10
|
+
@spec = quick_gem "a" do |s|
|
11
|
+
s.description = "π"
|
12
12
|
s.files = %w[lib/code.rb]
|
13
13
|
end
|
14
14
|
|
@@ -16,7 +16,7 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
16
16
|
|
17
17
|
@gem = @spec.cache_file
|
18
18
|
|
19
|
-
@destination = File.join @tempdir,
|
19
|
+
@destination = File.join @tempdir, "extract"
|
20
20
|
|
21
21
|
FileUtils.mkdir_p @destination
|
22
22
|
end
|
@@ -24,11 +24,11 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
24
24
|
def test_class_new_old_format
|
25
25
|
pend "jruby can't require the simple_gem file" if Gem.java_platform?
|
26
26
|
require_relative "simple_gem"
|
27
|
-
File.open
|
27
|
+
File.open "old_format.gem", "wb" do |io|
|
28
28
|
io.write SIMPLE_GEM
|
29
29
|
end
|
30
30
|
|
31
|
-
package = Gem::Package.new
|
31
|
+
package = Gem::Package.new "old_format.gem"
|
32
32
|
|
33
33
|
assert package.spec
|
34
34
|
end
|
@@ -36,17 +36,17 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
36
36
|
def test_add_checksums
|
37
37
|
gem_io = StringIO.new
|
38
38
|
|
39
|
-
spec = Gem::Specification.new
|
40
|
-
spec.summary =
|
41
|
-
spec.authors =
|
42
|
-
spec.files = [
|
39
|
+
spec = Gem::Specification.new "build", "1"
|
40
|
+
spec.summary = "build"
|
41
|
+
spec.authors = "build"
|
42
|
+
spec.files = ["lib/code.rb"]
|
43
43
|
spec.date = Time.at 0
|
44
|
-
spec.rubygems_version = Gem::Version.new
|
44
|
+
spec.rubygems_version = Gem::Version.new "0"
|
45
45
|
|
46
|
-
FileUtils.mkdir
|
46
|
+
FileUtils.mkdir "lib"
|
47
47
|
|
48
|
-
File.open
|
49
|
-
io.write
|
48
|
+
File.open "lib/code.rb", "w" do |io|
|
49
|
+
io.write "# lib/code.rb"
|
50
50
|
end
|
51
51
|
|
52
52
|
package = Gem::Package.new spec.file_name
|
@@ -69,11 +69,11 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
69
69
|
|
70
70
|
reader.each_entry do |entry|
|
71
71
|
case entry.full_name
|
72
|
-
when
|
72
|
+
when "checksums.yaml.gz" then
|
73
73
|
Zlib::GzipReader.wrap entry do |io|
|
74
74
|
checksums = io.read
|
75
75
|
end
|
76
|
-
when
|
76
|
+
when "data.tar.gz" then
|
77
77
|
tar = entry.read
|
78
78
|
end
|
79
79
|
end
|
@@ -88,13 +88,13 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
88
88
|
metadata_sha512 = OpenSSL::Digest::SHA512.hexdigest s.string
|
89
89
|
|
90
90
|
expected = {
|
91
|
-
|
92
|
-
|
93
|
-
|
91
|
+
"SHA512" => {
|
92
|
+
"metadata.gz" => metadata_sha512,
|
93
|
+
"data.tar.gz" => OpenSSL::Digest::SHA512.hexdigest(tar),
|
94
94
|
},
|
95
|
-
|
96
|
-
|
97
|
-
|
95
|
+
"SHA256" => {
|
96
|
+
"metadata.gz" => metadata_sha256,
|
97
|
+
"data.tar.gz" => OpenSSL::Digest::SHA256.hexdigest(tar),
|
98
98
|
},
|
99
99
|
}
|
100
100
|
|
@@ -105,12 +105,12 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
105
105
|
epoch = ENV["SOURCE_DATE_EPOCH"]
|
106
106
|
ENV["SOURCE_DATE_EPOCH"] = "123456789"
|
107
107
|
|
108
|
-
spec = Gem::Specification.new
|
109
|
-
spec.summary =
|
110
|
-
spec.authors =
|
111
|
-
spec.files = [
|
108
|
+
spec = Gem::Specification.new "build", "1"
|
109
|
+
spec.summary = "build"
|
110
|
+
spec.authors = "build"
|
111
|
+
spec.files = ["lib/code.rb"]
|
112
112
|
spec.date = Time.at 0
|
113
|
-
spec.rubygems_version = Gem::Version.new
|
113
|
+
spec.rubygems_version = Gem::Version.new "0"
|
114
114
|
|
115
115
|
package = Gem::Package.new spec.file_name
|
116
116
|
|
@@ -123,11 +123,11 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
123
123
|
epoch = ENV["SOURCE_DATE_EPOCH"]
|
124
124
|
ENV["SOURCE_DATE_EPOCH"] = nil
|
125
125
|
|
126
|
-
spec = Gem::Specification.new
|
127
|
-
spec.summary =
|
128
|
-
spec.authors =
|
129
|
-
spec.files = [
|
130
|
-
spec.rubygems_version = Gem::Version.new
|
126
|
+
spec = Gem::Specification.new "build", "1"
|
127
|
+
spec.summary = "build"
|
128
|
+
spec.authors = "build"
|
129
|
+
spec.files = ["lib/code.rb"]
|
130
|
+
spec.rubygems_version = Gem::Version.new "0"
|
131
131
|
|
132
132
|
package = Gem::Package.new spec.file_name
|
133
133
|
|
@@ -144,17 +144,17 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
144
144
|
spec = Gem::Specification.new
|
145
145
|
spec.files = %w[lib/code.rb lib/empty]
|
146
146
|
|
147
|
-
FileUtils.mkdir_p
|
147
|
+
FileUtils.mkdir_p "lib/empty"
|
148
148
|
|
149
|
-
File.open
|
150
|
-
io.write
|
149
|
+
File.open "lib/code.rb", "w" do |io|
|
150
|
+
io.write "# lib/code.rb"
|
151
151
|
end
|
152
152
|
|
153
|
-
File.open
|
154
|
-
io.write
|
153
|
+
File.open "lib/extra.rb", "w" do |io|
|
154
|
+
io.write "# lib/extra.rb"
|
155
155
|
end
|
156
156
|
|
157
|
-
package = Gem::Package.new
|
157
|
+
package = Gem::Package.new "bogus.gem"
|
158
158
|
package.spec = spec
|
159
159
|
|
160
160
|
tar = util_tar do |tar_io|
|
@@ -178,16 +178,16 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
178
178
|
spec = Gem::Specification.new
|
179
179
|
spec.files = %w[lib/code.rb lib/code_sym.rb lib/code_sym2.rb]
|
180
180
|
|
181
|
-
FileUtils.mkdir_p
|
181
|
+
FileUtils.mkdir_p "lib"
|
182
182
|
|
183
|
-
File.open
|
184
|
-
io.write
|
183
|
+
File.open "lib/code.rb", "w" do |io|
|
184
|
+
io.write "# lib/code.rb"
|
185
185
|
end
|
186
186
|
|
187
187
|
# NOTE: 'code.rb' is correct, because it's relative to lib/code_sym.rb
|
188
188
|
begin
|
189
|
-
File.symlink(
|
190
|
-
File.symlink(
|
189
|
+
File.symlink("code.rb", "lib/code_sym.rb")
|
190
|
+
File.symlink("../lib/code.rb", "lib/code_sym2.rb")
|
191
191
|
rescue Errno::EACCES => e
|
192
192
|
if win_platform?
|
193
193
|
pend "symlink - must be admin with no UAC on Windows"
|
@@ -196,7 +196,7 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
196
196
|
end
|
197
197
|
end
|
198
198
|
|
199
|
-
package = Gem::Package.new
|
199
|
+
package = Gem::Package.new "bogus.gem"
|
200
200
|
package.spec = spec
|
201
201
|
|
202
202
|
tar = util_tar do |tar_io|
|
@@ -218,20 +218,20 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
218
218
|
end
|
219
219
|
|
220
220
|
assert_equal %w[lib/code.rb], files
|
221
|
-
assert_equal [{
|
221
|
+
assert_equal [{ "lib/code_sym.rb" => "code.rb" }, { "lib/code_sym2.rb" => "../lib/code.rb" }], symlinks
|
222
222
|
end
|
223
223
|
|
224
224
|
def test_build
|
225
|
-
spec = Gem::Specification.new
|
226
|
-
spec.summary =
|
227
|
-
spec.authors =
|
228
|
-
spec.files = [
|
225
|
+
spec = Gem::Specification.new "build", "1"
|
226
|
+
spec.summary = "build"
|
227
|
+
spec.authors = "build"
|
228
|
+
spec.files = ["lib/code.rb"]
|
229
229
|
spec.rubygems_version = :junk
|
230
230
|
|
231
|
-
FileUtils.mkdir
|
231
|
+
FileUtils.mkdir "lib"
|
232
232
|
|
233
|
-
File.open
|
234
|
-
io.write
|
233
|
+
File.open "lib/code.rb", "w" do |io|
|
234
|
+
io.write "# lib/code.rb"
|
235
235
|
end
|
236
236
|
|
237
237
|
package = Gem::Package.new spec.file_name
|
@@ -252,25 +252,25 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
252
252
|
end
|
253
253
|
|
254
254
|
def test_build_auto_signed
|
255
|
-
pend
|
255
|
+
pend "openssl is missing" unless Gem::HAVE_OPENSSL
|
256
256
|
|
257
|
-
FileUtils.mkdir_p File.join(Gem.user_home,
|
257
|
+
FileUtils.mkdir_p File.join(Gem.user_home, ".gem")
|
258
258
|
|
259
|
-
private_key_path = File.join Gem.user_home,
|
259
|
+
private_key_path = File.join Gem.user_home, ".gem", "gem-private_key.pem"
|
260
260
|
Gem::Security.write PRIVATE_KEY, private_key_path
|
261
261
|
|
262
|
-
public_cert_path = File.join Gem.user_home,
|
262
|
+
public_cert_path = File.join Gem.user_home, ".gem", "gem-public_cert.pem"
|
263
263
|
FileUtils.cp PUBLIC_CERT_PATH, public_cert_path
|
264
264
|
|
265
|
-
spec = Gem::Specification.new
|
266
|
-
spec.summary =
|
267
|
-
spec.authors =
|
268
|
-
spec.files = [
|
265
|
+
spec = Gem::Specification.new "build", "1"
|
266
|
+
spec.summary = "build"
|
267
|
+
spec.authors = "build"
|
268
|
+
spec.files = ["lib/code.rb"]
|
269
269
|
|
270
|
-
FileUtils.mkdir
|
270
|
+
FileUtils.mkdir "lib"
|
271
271
|
|
272
|
-
File.open
|
273
|
-
io.write
|
272
|
+
File.open "lib/code.rb", "w" do |io|
|
273
|
+
io.write "# lib/code.rb"
|
274
274
|
end
|
275
275
|
|
276
276
|
package = Gem::Package.new spec.file_name
|
@@ -295,25 +295,25 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
295
295
|
end
|
296
296
|
|
297
297
|
def test_build_auto_signed_encrypted_key
|
298
|
-
pend
|
298
|
+
pend "openssl is missing" unless Gem::HAVE_OPENSSL
|
299
299
|
|
300
|
-
FileUtils.mkdir_p File.join(Gem.user_home,
|
300
|
+
FileUtils.mkdir_p File.join(Gem.user_home, ".gem")
|
301
301
|
|
302
|
-
private_key_path = File.join Gem.user_home,
|
302
|
+
private_key_path = File.join Gem.user_home, ".gem", "gem-private_key.pem"
|
303
303
|
FileUtils.cp ENCRYPTED_PRIVATE_KEY_PATH, private_key_path
|
304
304
|
|
305
|
-
public_cert_path = File.join Gem.user_home,
|
305
|
+
public_cert_path = File.join Gem.user_home, ".gem", "gem-public_cert.pem"
|
306
306
|
Gem::Security.write PUBLIC_CERT, public_cert_path
|
307
307
|
|
308
|
-
spec = Gem::Specification.new
|
309
|
-
spec.summary =
|
310
|
-
spec.authors =
|
311
|
-
spec.files = [
|
308
|
+
spec = Gem::Specification.new "build", "1"
|
309
|
+
spec.summary = "build"
|
310
|
+
spec.authors = "build"
|
311
|
+
spec.files = ["lib/code.rb"]
|
312
312
|
|
313
|
-
FileUtils.mkdir
|
313
|
+
FileUtils.mkdir "lib"
|
314
314
|
|
315
|
-
File.open
|
316
|
-
io.write
|
315
|
+
File.open "lib/code.rb", "w" do |io|
|
316
|
+
io.write "# lib/code.rb"
|
317
317
|
end
|
318
318
|
|
319
319
|
package = Gem::Package.new spec.file_name
|
@@ -338,7 +338,7 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
338
338
|
end
|
339
339
|
|
340
340
|
def test_build_invalid
|
341
|
-
spec = Gem::Specification.new
|
341
|
+
spec = Gem::Specification.new "build", "1"
|
342
342
|
|
343
343
|
package = Gem::Package.new spec.file_name
|
344
344
|
package.spec = spec
|
@@ -347,11 +347,11 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
347
347
|
package.build
|
348
348
|
end
|
349
349
|
|
350
|
-
assert_equal
|
350
|
+
assert_equal "missing value for attribute summary", e.message
|
351
351
|
end
|
352
352
|
|
353
353
|
def test_build_invalid_arguments
|
354
|
-
spec = Gem::Specification.new
|
354
|
+
spec = Gem::Specification.new "build", "1"
|
355
355
|
|
356
356
|
package = Gem::Package.new spec.file_name
|
357
357
|
package.spec = spec
|
@@ -364,19 +364,19 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
364
364
|
end
|
365
365
|
|
366
366
|
def test_build_signed
|
367
|
-
pend
|
367
|
+
pend "openssl is missing" unless Gem::HAVE_OPENSSL
|
368
368
|
|
369
|
-
spec = Gem::Specification.new
|
370
|
-
spec.summary =
|
371
|
-
spec.authors =
|
372
|
-
spec.files = [
|
369
|
+
spec = Gem::Specification.new "build", "1"
|
370
|
+
spec.summary = "build"
|
371
|
+
spec.authors = "build"
|
372
|
+
spec.files = ["lib/code.rb"]
|
373
373
|
spec.cert_chain = [PUBLIC_CERT.to_pem]
|
374
374
|
spec.signing_key = PRIVATE_KEY
|
375
375
|
|
376
|
-
FileUtils.mkdir
|
376
|
+
FileUtils.mkdir "lib"
|
377
377
|
|
378
|
-
File.open
|
379
|
-
io.write
|
378
|
+
File.open "lib/code.rb", "w" do |io|
|
379
|
+
io.write "# lib/code.rb"
|
380
380
|
end
|
381
381
|
|
382
382
|
package = Gem::Package.new spec.file_name
|
@@ -401,19 +401,19 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
401
401
|
end
|
402
402
|
|
403
403
|
def test_build_signed_encrypted_key
|
404
|
-
pend
|
404
|
+
pend "openssl is missing" unless Gem::HAVE_OPENSSL
|
405
405
|
|
406
|
-
spec = Gem::Specification.new
|
407
|
-
spec.summary =
|
408
|
-
spec.authors =
|
409
|
-
spec.files = [
|
406
|
+
spec = Gem::Specification.new "build", "1"
|
407
|
+
spec.summary = "build"
|
408
|
+
spec.authors = "build"
|
409
|
+
spec.files = ["lib/code.rb"]
|
410
410
|
spec.cert_chain = [PUBLIC_CERT.to_pem]
|
411
411
|
spec.signing_key = ENCRYPTED_PRIVATE_KEY
|
412
412
|
|
413
|
-
FileUtils.mkdir
|
413
|
+
FileUtils.mkdir "lib"
|
414
414
|
|
415
|
-
File.open
|
416
|
-
io.write
|
415
|
+
File.open "lib/code.rb", "w" do |io|
|
416
|
+
io.write "# lib/code.rb"
|
417
417
|
end
|
418
418
|
|
419
419
|
package = Gem::Package.new spec.file_name
|
@@ -441,11 +441,11 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
441
441
|
data_tgz = util_tar_gz {}
|
442
442
|
|
443
443
|
gem = util_tar do |tar|
|
444
|
-
tar.add_file
|
444
|
+
tar.add_file "data.tar.gz", 0644 do |io|
|
445
445
|
io.write data_tgz.string
|
446
446
|
end
|
447
447
|
|
448
|
-
tar.add_file
|
448
|
+
tar.add_file "metadata.gz", 0644 do |io|
|
449
449
|
Zlib::GzipWriter.wrap io do |gzio|
|
450
450
|
gzio.write @spec.to_yaml
|
451
451
|
end
|
@@ -475,7 +475,7 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
475
475
|
|
476
476
|
package.extract_files @destination
|
477
477
|
|
478
|
-
extracted = File.join @destination,
|
478
|
+
extracted = File.join @destination, "lib/code.rb"
|
479
479
|
assert_path_exist extracted
|
480
480
|
|
481
481
|
mask = 0100666 & (~File.umask)
|
@@ -488,22 +488,22 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
488
488
|
data_tgz = util_tar_gz {}
|
489
489
|
|
490
490
|
gem = util_tar do |tar|
|
491
|
-
tar.add_file
|
491
|
+
tar.add_file "data.tar.gz", 0644 do |io|
|
492
492
|
io.write data_tgz.string
|
493
493
|
end
|
494
494
|
|
495
|
-
tar.add_file
|
495
|
+
tar.add_file "metadata.gz", 0644 do |io|
|
496
496
|
Zlib::GzipWriter.wrap io do |gzio|
|
497
497
|
gzio.write @spec.to_yaml
|
498
498
|
end
|
499
499
|
end
|
500
500
|
end
|
501
501
|
|
502
|
-
File.open
|
502
|
+
File.open "empty.gem", "wb" do |io|
|
503
503
|
io.write gem.string
|
504
504
|
end
|
505
505
|
|
506
|
-
package = Gem::Package.new
|
506
|
+
package = Gem::Package.new "empty.gem"
|
507
507
|
|
508
508
|
package.extract_files @destination
|
509
509
|
|
@@ -514,8 +514,8 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
514
514
|
package = Gem::Package.new @gem
|
515
515
|
|
516
516
|
tgz_io = util_tar_gz do |tar|
|
517
|
-
tar.add_file
|
518
|
-
io.write
|
517
|
+
tar.add_file "/absolute.rb", 0644 do |io|
|
518
|
+
io.write "hi"
|
519
519
|
end
|
520
520
|
end
|
521
521
|
|
@@ -531,12 +531,12 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
531
531
|
package = Gem::Package.new @gem
|
532
532
|
|
533
533
|
tgz_io = util_tar_gz do |tar|
|
534
|
-
tar.add_file
|
535
|
-
io.write
|
534
|
+
tar.add_file "relative.rb", 0644 do |io|
|
535
|
+
io.write "hi"
|
536
536
|
end
|
537
537
|
|
538
|
-
tar.mkdir
|
539
|
-
tar.add_symlink
|
538
|
+
tar.mkdir "lib", 0755
|
539
|
+
tar.add_symlink "lib/foo.rb", "../relative.rb", 0644
|
540
540
|
end
|
541
541
|
|
542
542
|
begin
|
@@ -549,11 +549,11 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
549
549
|
end
|
550
550
|
end
|
551
551
|
|
552
|
-
extracted = File.join @destination,
|
552
|
+
extracted = File.join @destination, "lib/foo.rb"
|
553
553
|
assert_path_exist extracted
|
554
|
-
assert_equal
|
554
|
+
assert_equal "../relative.rb",
|
555
555
|
File.readlink(extracted)
|
556
|
-
assert_equal
|
556
|
+
assert_equal "hi",
|
557
557
|
File.read(extracted)
|
558
558
|
end
|
559
559
|
|
@@ -561,17 +561,17 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
561
561
|
package = Gem::Package.new @gem
|
562
562
|
|
563
563
|
tgz_io = util_tar_gz do |tar|
|
564
|
-
tar.mkdir
|
565
|
-
tar.add_symlink
|
566
|
-
tar.add_file
|
567
|
-
io.write
|
564
|
+
tar.mkdir "lib", 0755
|
565
|
+
tar.add_symlink "lib/link", "../..", 0644
|
566
|
+
tar.add_file "lib/link/outside.txt", 0644 do |io|
|
567
|
+
io.write "hi"
|
568
568
|
end
|
569
569
|
end
|
570
570
|
|
571
571
|
# Extract into a subdirectory of @destination; if this test fails it writes
|
572
572
|
# a file outside destination_subdir, but we want the file to remain inside
|
573
573
|
# @destination so it will be cleaned up.
|
574
|
-
destination_subdir = File.join @destination,
|
574
|
+
destination_subdir = File.join @destination, "subdir"
|
575
575
|
FileUtils.mkdir_p destination_subdir
|
576
576
|
|
577
577
|
expected_exceptions = win_platform? ? [Gem::Package::SymlinkError, Errno::EACCES] : [Gem::Package::SymlinkError]
|
@@ -595,18 +595,18 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
595
595
|
# Extract into a subdirectory of @destination; if this test fails it writes
|
596
596
|
# a file outside destination_subdir, but we want the file to remain inside
|
597
597
|
# @destination so it will be cleaned up.
|
598
|
-
destination_subdir = File.join @destination,
|
598
|
+
destination_subdir = File.join @destination, "subdir"
|
599
599
|
FileUtils.mkdir_p destination_subdir
|
600
600
|
|
601
|
-
destination_user_dir = File.join @destination,
|
602
|
-
destination_user_subdir = File.join destination_user_dir,
|
601
|
+
destination_user_dir = File.join @destination, "user"
|
602
|
+
destination_user_subdir = File.join destination_user_dir, "dir"
|
603
603
|
FileUtils.mkdir_p destination_user_subdir
|
604
604
|
|
605
605
|
pend "TMPDIR seems too long to add it as symlink into tar" if destination_user_dir.size > 90
|
606
606
|
|
607
607
|
tgz_io = util_tar_gz do |tar|
|
608
|
-
tar.add_symlink
|
609
|
-
tar.add_symlink
|
608
|
+
tar.add_symlink "link", destination_user_dir, 16877
|
609
|
+
tar.add_symlink "link/dir", ".", 16877
|
610
610
|
end
|
611
611
|
|
612
612
|
expected_exceptions = win_platform? ? [Gem::Package::SymlinkError, Errno::EACCES] : [Gem::Package::SymlinkError]
|
@@ -629,19 +629,19 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
629
629
|
package = Gem::Package.new @gem
|
630
630
|
|
631
631
|
tgz_io = util_tar_gz do |tar|
|
632
|
-
tar.mkdir
|
633
|
-
tar.add_file
|
634
|
-
io.write
|
632
|
+
tar.mkdir "lib", 0755
|
633
|
+
tar.add_file "lib/foo.rb", 0644 do |io|
|
634
|
+
io.write "hi"
|
635
635
|
end
|
636
|
-
tar.mkdir
|
636
|
+
tar.mkdir "lib/foo", 0755
|
637
637
|
end
|
638
638
|
|
639
639
|
package.extract_tar_gz tgz_io, @destination
|
640
640
|
|
641
|
-
extracted = File.join @destination,
|
641
|
+
extracted = File.join @destination, "lib/foo.rb"
|
642
642
|
assert_path_exist extracted
|
643
643
|
|
644
|
-
extracted = File.join @destination,
|
644
|
+
extracted = File.join @destination, "lib/foo"
|
645
645
|
assert_path_exist extracted
|
646
646
|
end
|
647
647
|
|
@@ -649,14 +649,14 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
649
649
|
package = Gem::Package.new @gem
|
650
650
|
|
651
651
|
tgz_io = util_tar_gz do |tar|
|
652
|
-
tar.add_file
|
653
|
-
io.write
|
652
|
+
tar.add_file "./dot_slash.rb", 0644 do |io|
|
653
|
+
io.write "hi"
|
654
654
|
end
|
655
655
|
end
|
656
656
|
|
657
657
|
package.extract_tar_gz tgz_io, @destination
|
658
658
|
|
659
|
-
extracted = File.join @destination,
|
659
|
+
extracted = File.join @destination, "dot_slash.rb"
|
660
660
|
assert_path_exist extracted
|
661
661
|
end
|
662
662
|
|
@@ -664,14 +664,14 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
664
664
|
package = Gem::Package.new @gem
|
665
665
|
|
666
666
|
tgz_io = util_tar_gz do |tar|
|
667
|
-
tar.add_file
|
668
|
-
io.write
|
667
|
+
tar.add_file ".dot_file.rb", 0644 do |io|
|
668
|
+
io.write "hi"
|
669
669
|
end
|
670
670
|
end
|
671
671
|
|
672
672
|
package.extract_tar_gz tgz_io, @destination
|
673
673
|
|
674
|
-
extracted = File.join @destination,
|
674
|
+
extracted = File.join @destination, ".dot_file.rb"
|
675
675
|
assert_path_exist extracted
|
676
676
|
end
|
677
677
|
|
@@ -680,14 +680,14 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
680
680
|
package = Gem::Package.new @gem
|
681
681
|
|
682
682
|
tgz_io = util_tar_gz do |tar|
|
683
|
-
tar.add_file
|
684
|
-
io.write
|
683
|
+
tar.add_file "foo/file.rb", 0644 do |io|
|
684
|
+
io.write "hi"
|
685
685
|
end
|
686
686
|
end
|
687
687
|
|
688
688
|
package.extract_tar_gz tgz_io, @destination.upcase
|
689
689
|
|
690
|
-
extracted = File.join @destination,
|
690
|
+
extracted = File.join @destination, "foo/file.rb"
|
691
691
|
assert_path_exist extracted
|
692
692
|
end
|
693
693
|
end
|
@@ -695,20 +695,20 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
695
695
|
def test_install_location
|
696
696
|
package = Gem::Package.new @gem
|
697
697
|
|
698
|
-
file =
|
699
|
-
file.taint if RUBY_VERSION <
|
698
|
+
file = "file.rb".dup
|
699
|
+
file.taint if RUBY_VERSION < "2.7"
|
700
700
|
|
701
701
|
destination = package.install_location file, @destination
|
702
702
|
|
703
|
-
assert_equal File.join(@destination,
|
704
|
-
refute destination.tainted? if RUBY_VERSION <
|
703
|
+
assert_equal File.join(@destination, "file.rb"), destination
|
704
|
+
refute destination.tainted? if RUBY_VERSION < "2.7"
|
705
705
|
end
|
706
706
|
|
707
707
|
def test_install_location_absolute
|
708
708
|
package = Gem::Package.new @gem
|
709
709
|
|
710
710
|
e = assert_raise Gem::Package::PathError do
|
711
|
-
package.install_location
|
711
|
+
package.install_location "/absolute.rb", @destination
|
712
712
|
end
|
713
713
|
|
714
714
|
assert_equal("installing into parent path /absolute.rb of " +
|
@@ -718,36 +718,36 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
718
718
|
def test_install_location_dots
|
719
719
|
package = Gem::Package.new @gem
|
720
720
|
|
721
|
-
file =
|
721
|
+
file = "file.rb"
|
722
722
|
|
723
|
-
destination = File.join @destination,
|
723
|
+
destination = File.join @destination, "foo", "..", "bar"
|
724
724
|
|
725
|
-
FileUtils.mkdir_p File.join @destination,
|
725
|
+
FileUtils.mkdir_p File.join @destination, "foo"
|
726
726
|
FileUtils.mkdir_p File.expand_path destination
|
727
727
|
|
728
728
|
destination = package.install_location file, destination
|
729
729
|
|
730
730
|
# this test only fails on ruby missing File.realpath
|
731
|
-
assert_equal File.join(@destination,
|
731
|
+
assert_equal File.join(@destination, "bar", "file.rb"), destination
|
732
732
|
end
|
733
733
|
|
734
734
|
def test_install_location_extra_slash
|
735
735
|
package = Gem::Package.new @gem
|
736
736
|
|
737
|
-
file =
|
738
|
-
file.taint if RUBY_VERSION <
|
737
|
+
file = "foo//file.rb".dup
|
738
|
+
file.taint if RUBY_VERSION < "2.7"
|
739
739
|
|
740
740
|
destination = package.install_location file, @destination
|
741
741
|
|
742
|
-
assert_equal File.join(@destination,
|
743
|
-
refute destination.tainted? if RUBY_VERSION <
|
742
|
+
assert_equal File.join(@destination, "foo", "file.rb"), destination
|
743
|
+
refute destination.tainted? if RUBY_VERSION < "2.7"
|
744
744
|
end
|
745
745
|
|
746
746
|
def test_install_location_relative
|
747
747
|
package = Gem::Package.new @gem
|
748
748
|
|
749
749
|
e = assert_raise Gem::Package::PathError do
|
750
|
-
package.install_location
|
750
|
+
package.install_location "../relative.rb", @destination
|
751
751
|
end
|
752
752
|
|
753
753
|
parent = File.expand_path File.join @destination, "../relative.rb"
|
@@ -773,9 +773,9 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
773
773
|
|
774
774
|
def test_load_spec
|
775
775
|
entry = StringIO.new Gem::Util.gzip @spec.to_yaml
|
776
|
-
def entry.full_name()
|
776
|
+
def entry.full_name() "metadata.gz" end
|
777
777
|
|
778
|
-
package = Gem::Package.new
|
778
|
+
package = Gem::Package.new "nonexistent.gem"
|
779
779
|
|
780
780
|
spec = package.load_spec entry
|
781
781
|
|
@@ -794,8 +794,8 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
794
794
|
|
795
795
|
def test_verify_checksum_bad
|
796
796
|
data_tgz = util_tar_gz do |tar|
|
797
|
-
tar.add_file
|
798
|
-
io.write
|
797
|
+
tar.add_file "lib/code.rb", 0444 do |io|
|
798
|
+
io.write "# lib/code.rb"
|
799
799
|
end
|
800
800
|
end
|
801
801
|
|
@@ -804,45 +804,45 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
804
804
|
gem = util_tar do |tar|
|
805
805
|
metadata_gz = Gem::Util.gzip @spec.to_yaml
|
806
806
|
|
807
|
-
tar.add_file
|
807
|
+
tar.add_file "metadata.gz", 0444 do |io|
|
808
808
|
io.write metadata_gz
|
809
809
|
end
|
810
810
|
|
811
|
-
tar.add_file
|
811
|
+
tar.add_file "data.tar.gz", 0444 do |io|
|
812
812
|
io.write data_tgz
|
813
813
|
end
|
814
814
|
|
815
815
|
bogus_checksums = {
|
816
|
-
|
817
|
-
|
818
|
-
|
816
|
+
"SHA1" => {
|
817
|
+
"data.tar.gz" => "bogus",
|
818
|
+
"metadata.gz" => "bogus",
|
819
819
|
},
|
820
820
|
}
|
821
|
-
tar.add_file
|
821
|
+
tar.add_file "checksums.yaml.gz", 0444 do |io|
|
822
822
|
Zlib::GzipWriter.wrap io do |gz_io|
|
823
823
|
gz_io.write Psych.dump bogus_checksums
|
824
824
|
end
|
825
825
|
end
|
826
826
|
end
|
827
827
|
|
828
|
-
File.open
|
828
|
+
File.open "mismatch.gem", "wb" do |io|
|
829
829
|
io.write gem.string
|
830
830
|
end
|
831
831
|
|
832
|
-
package = Gem::Package.new
|
832
|
+
package = Gem::Package.new "mismatch.gem"
|
833
833
|
|
834
834
|
e = assert_raise Gem::Package::FormatError do
|
835
835
|
package.verify
|
836
836
|
end
|
837
837
|
|
838
|
-
assert_equal
|
838
|
+
assert_equal "SHA1 checksum mismatch for data.tar.gz in mismatch.gem",
|
839
839
|
e.message
|
840
840
|
end
|
841
841
|
|
842
842
|
def test_verify_checksum_missing
|
843
843
|
data_tgz = util_tar_gz do |tar|
|
844
|
-
tar.add_file
|
845
|
-
io.write
|
844
|
+
tar.add_file "lib/code.rb", 0444 do |io|
|
845
|
+
io.write "# lib/code.rb"
|
846
846
|
end
|
847
847
|
end
|
848
848
|
|
@@ -851,7 +851,7 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
851
851
|
gem = util_tar do |tar|
|
852
852
|
metadata_gz = Gem::Util.gzip @spec.to_yaml
|
853
853
|
|
854
|
-
tar.add_file
|
854
|
+
tar.add_file "metadata.gz", 0444 do |io|
|
855
855
|
io.write metadata_gz
|
856
856
|
end
|
857
857
|
|
@@ -859,37 +859,37 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
859
859
|
digest << metadata_gz
|
860
860
|
|
861
861
|
checksums = {
|
862
|
-
|
863
|
-
|
862
|
+
"SHA1" => {
|
863
|
+
"metadata.gz" => digest.hexdigest,
|
864
864
|
},
|
865
865
|
}
|
866
866
|
|
867
|
-
tar.add_file
|
867
|
+
tar.add_file "checksums.yaml.gz", 0444 do |io|
|
868
868
|
Zlib::GzipWriter.wrap io do |gz_io|
|
869
869
|
gz_io.write Psych.dump checksums
|
870
870
|
end
|
871
871
|
end
|
872
872
|
|
873
|
-
tar.add_file
|
873
|
+
tar.add_file "data.tar.gz", 0444 do |io|
|
874
874
|
io.write data_tgz
|
875
875
|
end
|
876
876
|
end
|
877
877
|
|
878
|
-
File.open
|
878
|
+
File.open "data_checksum_missing.gem", "wb" do |io|
|
879
879
|
io.write gem.string
|
880
880
|
end
|
881
881
|
|
882
|
-
package = Gem::Package.new
|
882
|
+
package = Gem::Package.new "data_checksum_missing.gem"
|
883
883
|
|
884
884
|
assert package.verify
|
885
885
|
end
|
886
886
|
|
887
887
|
def test_verify_corrupt
|
888
888
|
pend "jruby strips the null byte and does not think it's corrupt" if Gem.java_platform?
|
889
|
-
tf = Tempfile.open
|
890
|
-
data = Gem::Util.gzip
|
889
|
+
tf = Tempfile.open "corrupt" do |io|
|
890
|
+
data = Gem::Util.gzip "a" * 10
|
891
891
|
io.write \
|
892
|
-
tar_file_header(
|
892
|
+
tar_file_header("metadata.gz", "\000x", 0644, data.length, Time.now)
|
893
893
|
io.write data
|
894
894
|
io.rewind
|
895
895
|
|
@@ -907,19 +907,19 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
907
907
|
end
|
908
908
|
|
909
909
|
def test_verify_empty
|
910
|
-
FileUtils.touch
|
910
|
+
FileUtils.touch "empty.gem"
|
911
911
|
|
912
|
-
package = Gem::Package.new
|
912
|
+
package = Gem::Package.new "empty.gem"
|
913
913
|
|
914
914
|
e = assert_raise Gem::Package::FormatError do
|
915
915
|
package.verify
|
916
916
|
end
|
917
917
|
|
918
|
-
assert_equal
|
918
|
+
assert_equal "package metadata is missing in empty.gem", e.message
|
919
919
|
end
|
920
920
|
|
921
921
|
def test_verify_nonexistent
|
922
|
-
package = Gem::Package.new
|
922
|
+
package = Gem::Package.new "nonexistent.gem"
|
923
923
|
|
924
924
|
e = assert_raise Gem::Package::FormatError do
|
925
925
|
package.verify
|
@@ -930,19 +930,19 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
930
930
|
end
|
931
931
|
|
932
932
|
def test_verify_duplicate_file
|
933
|
-
FileUtils.mkdir_p
|
934
|
-
FileUtils.touch
|
933
|
+
FileUtils.mkdir_p "lib"
|
934
|
+
FileUtils.touch "lib/code.rb"
|
935
935
|
|
936
936
|
build = Gem::Package.new @gem
|
937
937
|
build.spec = @spec
|
938
938
|
build.setup_signer
|
939
|
-
File.open @gem,
|
939
|
+
File.open @gem, "wb" do |gem_io|
|
940
940
|
Gem::Package::TarWriter.new gem_io do |gem|
|
941
941
|
build.add_metadata gem
|
942
942
|
build.add_contents gem
|
943
943
|
|
944
|
-
gem.add_file_simple
|
945
|
-
gem.add_file_simple
|
944
|
+
gem.add_file_simple "a.sig", 0444, 0
|
945
|
+
gem.add_file_simple "a.sig", 0444, 0
|
946
946
|
end
|
947
947
|
end
|
948
948
|
|
@@ -956,7 +956,7 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
956
956
|
end
|
957
957
|
|
958
958
|
def test_verify_security_policy
|
959
|
-
pend
|
959
|
+
pend "openssl is missing" unless Gem::HAVE_OPENSSL
|
960
960
|
|
961
961
|
package = Gem::Package.new @gem
|
962
962
|
package.security_policy = Gem::Security::HighSecurity
|
@@ -965,21 +965,21 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
965
965
|
package.verify
|
966
966
|
end
|
967
967
|
|
968
|
-
assert_equal
|
968
|
+
assert_equal "unsigned gems are not allowed by the High Security policy",
|
969
969
|
e.message
|
970
970
|
|
971
|
-
refute package.instance_variable_get(:@spec),
|
972
|
-
assert_empty package.instance_variable_get(:@files),
|
971
|
+
refute package.instance_variable_get(:@spec), "@spec must not be loaded"
|
972
|
+
assert_empty package.instance_variable_get(:@files), "@files must empty"
|
973
973
|
end
|
974
974
|
|
975
975
|
def test_verify_security_policy_low_security
|
976
|
-
pend
|
976
|
+
pend "openssl is missing" unless Gem::HAVE_OPENSSL
|
977
977
|
|
978
978
|
@spec.cert_chain = [PUBLIC_CERT.to_pem]
|
979
979
|
@spec.signing_key = PRIVATE_KEY
|
980
980
|
|
981
|
-
FileUtils.mkdir_p
|
982
|
-
FileUtils.touch
|
981
|
+
FileUtils.mkdir_p "lib"
|
982
|
+
FileUtils.touch "lib/code.rb"
|
983
983
|
|
984
984
|
build = Gem::Package.new @gem
|
985
985
|
build.spec = @spec
|
@@ -993,7 +993,7 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
993
993
|
end
|
994
994
|
|
995
995
|
def test_verify_security_policy_checksum_missing
|
996
|
-
pend
|
996
|
+
pend "openssl is missing" unless Gem::HAVE_OPENSSL
|
997
997
|
|
998
998
|
@spec.cert_chain = [PUBLIC_CERT.to_pem]
|
999
999
|
@spec.signing_key = PRIVATE_KEY
|
@@ -1002,23 +1002,23 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
1002
1002
|
build.spec = @spec
|
1003
1003
|
build.setup_signer
|
1004
1004
|
|
1005
|
-
FileUtils.mkdir
|
1006
|
-
FileUtils.touch
|
1005
|
+
FileUtils.mkdir "lib"
|
1006
|
+
FileUtils.touch "lib/code.rb"
|
1007
1007
|
|
1008
|
-
File.open @gem,
|
1008
|
+
File.open @gem, "wb" do |gem_io|
|
1009
1009
|
Gem::Package::TarWriter.new gem_io do |gem|
|
1010
1010
|
build.add_metadata gem
|
1011
1011
|
build.add_contents gem
|
1012
1012
|
|
1013
1013
|
# write bogus data.tar.gz to foil signature
|
1014
|
-
bogus_data = Gem::Util.gzip
|
1014
|
+
bogus_data = Gem::Util.gzip "hello"
|
1015
1015
|
fake_signer = Class.new do
|
1016
|
-
def digest_name;
|
1016
|
+
def digest_name; "SHA512"; end
|
1017
1017
|
def digest_algorithm; OpenSSL::Digest(:SHA512).new; end
|
1018
|
-
def key;
|
1019
|
-
def sign(*);
|
1018
|
+
def key; "key"; end
|
1019
|
+
def sign(*); "fake_sig"; end
|
1020
1020
|
end
|
1021
|
-
gem.add_file_signed
|
1021
|
+
gem.add_file_signed "data2.tar.gz", 0444, fake_signer.new do |io|
|
1022
1022
|
io.write bogus_data
|
1023
1023
|
end
|
1024
1024
|
|
@@ -1035,24 +1035,24 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
1035
1035
|
package.verify
|
1036
1036
|
end
|
1037
1037
|
|
1038
|
-
assert_equal
|
1038
|
+
assert_equal "invalid signature", e.message
|
1039
1039
|
|
1040
|
-
refute package.instance_variable_get(:@spec),
|
1041
|
-
assert_empty package.instance_variable_get(:@files),
|
1040
|
+
refute package.instance_variable_get(:@spec), "@spec must not be loaded"
|
1041
|
+
assert_empty package.instance_variable_get(:@files), "@files must empty"
|
1042
1042
|
end
|
1043
1043
|
|
1044
1044
|
def test_verify_truncate
|
1045
|
-
File.open
|
1045
|
+
File.open "bad.gem", "wb" do |io|
|
1046
1046
|
io.write File.read(@gem, 1024) # don't care about newlines
|
1047
1047
|
end
|
1048
1048
|
|
1049
|
-
package = Gem::Package.new
|
1049
|
+
package = Gem::Package.new "bad.gem"
|
1050
1050
|
|
1051
1051
|
e = assert_raise Gem::Package::FormatError do
|
1052
1052
|
package.verify
|
1053
1053
|
end
|
1054
1054
|
|
1055
|
-
assert_equal
|
1055
|
+
assert_equal "package content (data.tar.gz) is missing in bad.gem",
|
1056
1056
|
e.message
|
1057
1057
|
end
|
1058
1058
|
|
@@ -1060,7 +1060,7 @@ class TestGemPackage < Gem::Package::TarTestCase
|
|
1060
1060
|
|
1061
1061
|
def test_verify_entry
|
1062
1062
|
entry = Object.new
|
1063
|
-
def entry.full_name() raise ArgumentError,
|
1063
|
+
def entry.full_name() raise ArgumentError, "whatever" end
|
1064
1064
|
|
1065
1065
|
package = Gem::Package.new @gem
|
1066
1066
|
|