mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
b957c3dbcb
This changes "test/rubygems/test_case.rb" to "test/rubygems/helper.rb",
and "test/rubygems/test_utilities.rb" to "test/rubygems/utilities.rb".
The two files are a helper for tests, not test files. However, a file
starting with "test_" prefix is handled as a test file directly loaded
by test-unit because Rakefile specifies:
```
t.test_files = FileList['test/**/test_*.rb']
```
Directly loading test/rubygems/test_utilities.rb caused "uninitialized
constant Gem::TestCase". This issue was fixed by
59c6820971
, but the fix caused a
"circular require" warning because test_utilities.rb and test_case.rb
are now requiring each other.
Anyway, adding "test_" prefix to a test helper file is confusing, so
this changeset reverts the fix and solve the issue by renaming them.
https://github.com/rubygems/rubygems/commit/6460e018df
209 lines
4.7 KiB
Ruby
209 lines
4.7 KiB
Ruby
# frozen_string_literal: true
|
|
require_relative 'helper'
|
|
|
|
class TestGemResolverAPISet < Gem::TestCase
|
|
def setup
|
|
super
|
|
|
|
@DR = Gem::Resolver
|
|
@dep_uri = URI "#{@gem_repo}info/"
|
|
end
|
|
|
|
def test_initialize
|
|
set = @DR::APISet.new
|
|
|
|
assert_equal URI('https://index.rubygems.org/info/'), set.dep_uri
|
|
assert_equal URI('https://index.rubygems.org/'), set.uri
|
|
assert_equal Gem::Source.new(URI('https://index.rubygems.org')), set.source
|
|
end
|
|
|
|
def test_initialize_deeper_uri
|
|
set = @DR::APISet.new 'https://rubygemsserver.com/mygems/info'
|
|
|
|
assert_equal URI('https://rubygemsserver.com/mygems/info'), set.dep_uri
|
|
assert_equal URI('https://rubygemsserver.com/'), set.uri
|
|
assert_equal Gem::Source.new(URI('https://rubygemsserver.com/')), set.source
|
|
end
|
|
|
|
def test_initialize_uri
|
|
set = @DR::APISet.new @dep_uri
|
|
|
|
assert_equal URI("#{@gem_repo}info/"), set.dep_uri
|
|
assert_equal URI("#{@gem_repo}"), set.uri
|
|
end
|
|
|
|
def test_find_all
|
|
spec_fetcher
|
|
|
|
data = [
|
|
{ :name => 'a',
|
|
:number => '1',
|
|
:platform => 'ruby',
|
|
:dependencies => [] },
|
|
]
|
|
|
|
@fetcher.data["#{@dep_uri}a"] = "---\n1 "
|
|
|
|
set = @DR::APISet.new @dep_uri
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
|
|
expected = [
|
|
@DR::APISpecification.new(set, data.first),
|
|
]
|
|
|
|
assert_equal expected, set.find_all(a_dep)
|
|
end
|
|
|
|
def test_find_all_prereleases
|
|
spec_fetcher
|
|
|
|
data = [
|
|
{ :name => 'a',
|
|
:number => '1',
|
|
:platform => 'ruby',
|
|
:dependencies => [] },
|
|
{ :name => 'a',
|
|
:number => '2.a',
|
|
:platform => 'ruby',
|
|
:dependencies => [] },
|
|
]
|
|
|
|
@fetcher.data["#{@dep_uri}a"] = "---\n1\n2.a"
|
|
|
|
set = @DR::APISet.new @dep_uri
|
|
set.prerelease = true
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
|
|
expected = [
|
|
@DR::APISpecification.new(set, data.first),
|
|
@DR::APISpecification.new(set, data.last),
|
|
]
|
|
|
|
assert_equal expected, set.find_all(a_dep)
|
|
end
|
|
|
|
def test_find_all_cache
|
|
spec_fetcher
|
|
|
|
data = [
|
|
{ :name => 'a',
|
|
:number => '1',
|
|
:platform => 'ruby',
|
|
:dependencies => [] },
|
|
]
|
|
|
|
@fetcher.data["#{@dep_uri}a"] = "---\n1 "
|
|
|
|
set = @DR::APISet.new @dep_uri
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
|
|
set.prefetch [a_dep]
|
|
|
|
expected = [
|
|
@DR::APISpecification.new(set, data.first),
|
|
]
|
|
|
|
assert_equal expected, set.find_all(a_dep)
|
|
|
|
@fetcher.data.delete "#{@dep_uri}a"
|
|
end
|
|
|
|
def test_find_all_local
|
|
set = @DR::APISet.new @dep_uri
|
|
set.remote = false
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
|
|
assert_empty set.find_all(a_dep)
|
|
end
|
|
|
|
def test_find_all_missing
|
|
spec_fetcher
|
|
|
|
@fetcher.data["#{@dep_uri}a"] = "---"
|
|
|
|
set = @DR::APISet.new @dep_uri
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
|
|
assert_empty set.find_all(a_dep)
|
|
|
|
@fetcher.data.delete "#{@dep_uri}a"
|
|
|
|
assert_empty set.find_all(a_dep)
|
|
end
|
|
|
|
def test_prefetch
|
|
spec_fetcher
|
|
|
|
@fetcher.data["#{@dep_uri}a"] = "---\n1 \n"
|
|
@fetcher.data["#{@dep_uri}b"] = "---"
|
|
|
|
set = @DR::APISet.new @dep_uri
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
b_dep = @DR::DependencyRequest.new dep('b'), nil
|
|
|
|
set.prefetch [a_dep, b_dep]
|
|
|
|
assert_equal %w[a-1], set.find_all(a_dep).map {|s| s.full_name }
|
|
assert_empty set.find_all(b_dep)
|
|
end
|
|
|
|
def test_prefetch_cache
|
|
spec_fetcher
|
|
|
|
@fetcher.data["#{@dep_uri}a"] = "---\n1 \n"
|
|
|
|
set = @DR::APISet.new @dep_uri
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
b_dep = @DR::DependencyRequest.new dep('b'), nil
|
|
|
|
set.prefetch [a_dep]
|
|
|
|
@fetcher.data.delete "#{@dep_uri}a"
|
|
@fetcher.data["#{@dep_uri}?b"] = "---"
|
|
|
|
set.prefetch [a_dep, b_dep]
|
|
end
|
|
|
|
def test_prefetch_cache_missing
|
|
spec_fetcher
|
|
|
|
@fetcher.data["#{@dep_uri}a"] = "---\n1 \n"
|
|
@fetcher.data["#{@dep_uri}b"] = "---"
|
|
|
|
set = @DR::APISet.new @dep_uri
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
b_dep = @DR::DependencyRequest.new dep('b'), nil
|
|
|
|
set.prefetch [a_dep, b_dep]
|
|
|
|
@fetcher.data.delete "#{@dep_uri}a"
|
|
@fetcher.data.delete "#{@dep_uri}b"
|
|
|
|
set.prefetch [a_dep, b_dep]
|
|
end
|
|
|
|
def test_prefetch_local
|
|
spec_fetcher
|
|
|
|
@fetcher.data["#{@dep_uri}a"] = "---\n1 \n"
|
|
@fetcher.data["#{@dep_uri}b"] = "---"
|
|
|
|
set = @DR::APISet.new @dep_uri
|
|
set.remote = false
|
|
|
|
a_dep = @DR::DependencyRequest.new dep('a'), nil
|
|
b_dep = @DR::DependencyRequest.new dep('b'), nil
|
|
|
|
set.prefetch [a_dep, b_dep]
|
|
|
|
assert_empty set.instance_variable_get :@data
|
|
end
|
|
end
|