OXIESEC PANEL
- Current Dir:
/
/
usr
/
lib
/
ruby
/
2.5.0
/
rubygems
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
available_set.rb
3.02 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
basic_specification.rb
7.36 KB
10/20/2017 09:03:37 AM
rw-r--r--
📄
bundler_version_finder.rb
3.09 KB
10/08/2017 01:32:22 AM
rw-r--r--
📄
command.rb
13.98 KB
12/25/2017 05:54:27 AM
rw-r--r--
📄
command_manager.rb
4.77 KB
05/15/2023 11:41:43 AM
rw-r--r--
📁
commands
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
compatibility.rb
1.66 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
config_file.rb
12.51 KB
03/19/2018 08:27:04 AM
rw-r--r--
📁
core_ext
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
defaults.rb
4.46 KB
06/24/2016 04:13:11 AM
rw-r--r--
📄
dependency.rb
8.38 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
dependency_installer.rb
14.17 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
dependency_list.rb
5.55 KB
05/01/2017 11:40:46 AM
rw-r--r--
📄
deprecate.rb
1.73 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
doctor.rb
3.06 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
errors.rb
4.62 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
exceptions.rb
6.39 KB
10/08/2017 01:32:18 AM
rw-r--r--
📁
ext
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
ext.rb
461 bytes
02/01/2016 12:43:26 PM
rw-r--r--
📄
gem_runner.rb
2.18 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
gemcutter_utilities.rb
4.37 KB
05/15/2023 11:41:43 AM
rw-r--r--
📄
indexer.rb
11.06 KB
03/19/2018 08:27:04 AM
rw-r--r--
📄
install_default_message.rb
337 bytes
02/01/2016 12:43:26 PM
rw-r--r--
📄
install_message.rb
311 bytes
02/01/2016 12:43:26 PM
rw-r--r--
📄
install_update_options.rb
6.89 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
installer.rb
25.11 KB
05/15/2023 11:41:43 AM
rw-r--r--
📄
installer_test_case.rb
4.41 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
local_remote_options.rb
3.4 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
mock_gem_ui.rb
1.38 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
name_tuple.rb
2.41 KB
02/01/2016 12:43:26 PM
rw-r--r--
📁
package
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
package.rb
16.47 KB
05/15/2023 11:41:43 AM
rw-r--r--
📄
package_task.rb
3.8 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
path_support.rb
1.72 KB
03/04/2016 12:29:40 AM
rw-r--r--
📄
platform.rb
6.25 KB
05/01/2017 11:40:46 AM
rw-r--r--
📄
psych_additions.rb
300 bytes
02/01/2016 12:43:26 PM
rw-r--r--
📄
psych_tree.rb
793 bytes
02/01/2016 12:43:26 PM
rw-r--r--
📄
rdoc.rb
7.74 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
remote_fetcher.rb
11.65 KB
08/28/2017 08:31:28 AM
rw-r--r--
📁
request
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
request.rb
8.66 KB
10/08/2017 01:32:18 AM
rw-r--r--
📁
request_set
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
request_set.rb
10.77 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
requirement.rb
6.59 KB
10/08/2017 01:32:18 AM
rw-r--r--
📁
resolver
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
resolver.rb
9.53 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
safe_yaml.rb
1.15 KB
11/02/2017 04:25:37 AM
rw-r--r--
📁
security
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
security.rb
21.13 KB
03/19/2018 08:27:04 AM
rw-r--r--
📄
security_option.rb
1.06 KB
10/08/2017 01:32:22 AM
rw-r--r--
📄
server.rb
22.72 KB
03/19/2018 08:27:04 AM
rw-r--r--
📁
source
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
source.rb
5.42 KB
03/19/2018 08:27:04 AM
rw-r--r--
📄
source_list.rb
2.53 KB
03/04/2016 12:29:40 AM
rw-r--r--
📄
source_local.rb
275 bytes
10/08/2017 01:32:18 AM
rw-r--r--
📄
source_specific_file.rb
272 bytes
10/08/2017 01:32:18 AM
rw-r--r--
📄
spec_fetcher.rb
6.47 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
specification.rb
82.65 KB
05/15/2023 11:41:43 AM
rw-r--r--
📁
ssl_certs
-
11/26/2019 12:32:04 PM
rwxr-xr-x
📄
stub_specification.rb
4.86 KB
03/19/2018 08:27:04 AM
rw-r--r--
📄
syck_hack.rb
2.12 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
test_case.rb
40.33 KB
03/19/2018 08:27:04 AM
rw-r--r--
📄
test_utilities.rb
8.63 KB
03/19/2018 08:27:04 AM
rw-r--r--
📄
text.rb
1.88 KB
08/28/2017 08:31:28 AM
rw-r--r--
📄
uninstaller.rb
8.74 KB
02/01/2016 12:43:26 PM
rw-r--r--
📄
uri_formatter.rb
792 bytes
02/01/2016 12:43:26 PM
rw-r--r--
📄
user_interaction.rb
14.54 KB
05/15/2023 11:41:43 AM
rw-r--r--
📁
util
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
util.rb
2.57 KB
03/19/2018 08:27:04 AM
rw-r--r--
📄
validator.rb
4.23 KB
03/19/2018 08:27:04 AM
rw-r--r--
📄
version.rb
11.97 KB
10/08/2017 01:32:18 AM
rw-r--r--
📄
version_option.rb
2.03 KB
10/08/2017 01:32:18 AM
rw-r--r--
Editing: test_utilities.rb
Close
# frozen_string_literal: true require 'tempfile' require 'rubygems' require 'rubygems/remote_fetcher' ## # A fake Gem::RemoteFetcher for use in tests or to avoid real live HTTP # requests when testing code that uses RubyGems. # # Example: # # @fetcher = Gem::FakeFetcher.new # @fetcher.data['http://gems.example.com/yaml'] = source_index.to_yaml # Gem::RemoteFetcher.fetcher = @fetcher # # # invoke RubyGems code # # paths = @fetcher.paths # assert_equal 'http://gems.example.com/yaml', paths.shift # assert paths.empty?, paths.join(', ') # # See RubyGems' tests for more examples of FakeFetcher. class Gem::FakeFetcher attr_reader :data attr_reader :last_request attr_reader :api_endpoints attr_accessor :paths def initialize @data = {} @paths = [] @api_endpoints = {} end def api_endpoint(uri) @api_endpoints[uri] || uri end def find_data(path) return File.read path.path if URI === path and 'file' == path.scheme if URI === path and "URI::#{path.scheme.upcase}" != path.class.name then raise ArgumentError, "mismatch for scheme #{path.scheme} and class #{path.class}" end path = path.to_s @paths << path raise ArgumentError, 'need full URI' unless path =~ %r'^https?://' unless @data.key? path then raise Gem::RemoteFetcher::FetchError.new("no data for #{path}", path) end @data[path] end def fetch_path path, mtime = nil, head = false data = find_data(path) if data.respond_to?(:call) then data.call else if path.to_s =~ /gz$/ and not data.nil? and not data.empty? then data = Gem.gunzip data end data end end def cache_update_path uri, path = nil, update = true if data = fetch_path(uri) open(path, 'wb') { |io| io.write data } if path and update data else Gem.read_binary(path) if path end end # Thanks, FakeWeb! def open_uri_or_path(path) data = find_data(path) body, code, msg = data response = Net::HTTPResponse.send(:response_class, code.to_s).new("1.0", code.to_s, msg) response.instance_variable_set(:@body, body) response.instance_variable_set(:@read, true) response end def request(uri, request_class, last_modified = nil) data = find_data(uri) body, code, msg = data @last_request = request_class.new uri.request_uri yield @last_request if block_given? response = Net::HTTPResponse.send(:response_class, code.to_s).new("1.0", code.to_s, msg) response.instance_variable_set(:@body, body) response.instance_variable_set(:@read, true) response end def pretty_print q # :nodoc: q.group 2, '[FakeFetcher', ']' do q.breakable q.text 'URIs:' q.breakable q.pp @data.keys unless @api_endpoints.empty? then q.breakable q.text 'API endpoints:' q.breakable q.pp @api_endpoints.keys end end end def fetch_size(path) path = path.to_s @paths << path raise ArgumentError, 'need full URI' unless path =~ %r'^http://' unless @data.key? path then raise Gem::RemoteFetcher::FetchError.new("no data for #{path}", path) end data = @data[path] data.respond_to?(:call) ? data.call : data.length end def download spec, source_uri, install_dir = Gem.dir name = File.basename spec.cache_file path = if Dir.pwd == install_dir then # see fetch_command install_dir else File.join install_dir, "cache" end path = File.join path, name if source_uri =~ /^http/ then File.open(path, "wb") do |f| f.write fetch_path(File.join(source_uri, "gems", name)) end else FileUtils.cp source_uri, path end path end def download_to_cache dependency found, _ = Gem::SpecFetcher.fetcher.spec_for_dependency dependency return if found.empty? spec, source = found.first download spec, source.uri.to_s end end # :stopdoc: class Gem::RemoteFetcher def self.fetcher=(fetcher) @fetcher = fetcher end end # :startdoc: ## # The SpecFetcherSetup allows easy setup of a remote source in RubyGems tests: # # spec_fetcher do |f| # f.gem 'a', 1 # f.spec 'a', 2 # f.gem 'b', 1' 'a' => '~> 1.0' # end # # The above declaration creates two gems, a-1 and b-1, with a dependency from # b to a. The declaration creates an additional spec a-2, but no gem for it # (so it cannot be installed). # # After the gems are created they are removed from Gem.dir. class Gem::TestCase::SpecFetcherSetup ## # Executes a SpecFetcher setup block. Yields an instance then creates the # gems and specifications defined in the instance. def self.declare test, repository setup = new test, repository yield setup setup.execute end def initialize test, repository # :nodoc: @test = test @repository = repository @gems = {} @downloaded = [] @installed = [] @operations = [] end ## # Returns a Hash of created Specification full names and the corresponding # Specification. def created_specs created = {} @gems.keys.each do |spec| created[spec.full_name] = spec end created end ## # Creates any defined gems or specifications def execute # :nodoc: execute_operations setup_fetcher created_specs end def execute_operations # :nodoc: @operations.each do |operation, *arguments| case operation when :gem then spec, gem = @test.util_gem(*arguments, &arguments.pop) write_spec spec @gems[spec] = gem @installed << spec when :download then spec, gem = @test.util_gem(*arguments, &arguments.pop) @gems[spec] = gem @downloaded << spec when :spec then spec = @test.util_spec(*arguments, &arguments.pop) write_spec spec @gems[spec] = nil @installed << spec end end end ## # Creates a gem with +name+, +version+ and +deps+. The created gem can be # downloaded and installed. # # The specification will be yielded before gem creation for customization, # but only the block or the dependencies may be set, not both. def gem name, version, dependencies = nil, &block @operations << [:gem, name, version, dependencies, block] end ## # Creates a gem with +name+, +version+ and +deps+. The created gem is # downloaded in to the cache directory but is not installed # # The specification will be yielded before gem creation for customization, # but only the block or the dependencies may be set, not both. def download name, version, dependencies = nil, &block @operations << [:download, name, version, dependencies, block] end ## # Creates a legacy platform spec with the name 'pl' and version 1 def legacy_platform spec 'pl', 1 do |s| s.platform = Gem::Platform.new 'i386-linux' s.instance_variable_set :@original_platform, 'i386-linux' end end def setup_fetcher # :nodoc: require 'zlib' require 'socket' require 'rubygems/remote_fetcher' unless @test.fetcher then @test.fetcher = Gem::FakeFetcher.new Gem::RemoteFetcher.fetcher = @test.fetcher end Gem::Specification.reset begin gem_repo, @test.gem_repo = @test.gem_repo, @repository @test.uri = URI @repository @test.util_setup_spec_fetcher(*@downloaded) ensure @test.gem_repo = gem_repo @test.uri = URI gem_repo end @gems.each do |spec, gem| next unless gem @test.fetcher.data["#{@repository}gems/#{spec.file_name}"] = Gem.read_binary(gem) FileUtils.cp gem, spec.cache_file end end ## # Creates a spec with +name+, +version+ and +deps+. The created gem can be # downloaded and installed. # # The specification will be yielded before creation for customization, # but only the block or the dependencies may be set, not both. def spec name, version, dependencies = nil, &block @operations << [:spec, name, version, dependencies, block] end def write_spec spec # :nodoc: File.open spec.spec_file, 'w' do |io| io.write spec.to_ruby_for_cache end end end ## # A StringIO duck-typed class that uses Tempfile instead of String as the # backing store. # # This is available when rubygems/test_utilities is required. #-- # This class was added to flush out problems in Rubinius' IO implementation. class TempIO < Tempfile ## # Creates a new TempIO that will be initialized to contain +string+. def initialize(string = '') super "TempIO" binmode write string rewind end ## # The content of the TempIO as a String. def string flush Gem.read_binary path end end