Skip to content

Commit 228ad3d

Browse files
committed
* lib/rubygems: Update to RubyGems master d8f12e2. This increases the
speed of `gem install --ignore-dependencies` which helps bundler tests. * test/rubygems: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@44270 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
1 parent 2d493a8 commit 228ad3d

7 files changed

+123
-20
lines changed

ChangeLog

+7
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,10 @@
1+
Wed Dec 18 10:00:22 2013 Eric Hodel <drbrain@segment7.net>
2+
3+
* lib/rubygems: Update to RubyGems master d8f12e2. This increases the
4+
speed of `gem install --ignore-dependencies` which helps bundler
5+
tests.
6+
* test/rubygems: ditto.
7+
18
Wed Dec 18 09:00:17 2013 Koichi Sasada <ko1@atdot.net>
29

310
* test/ruby/test_gc.rb (test_expand_heap): allow +/-1 diff.

lib/rubygems/dependency_installer.rb

+2-1
Original file line numberDiff line numberDiff line change
@@ -426,7 +426,8 @@ def resolve_dependencies dep_or_name, version # :nodoc:
426426

427427
if @ignore_dependencies then
428428
installer_set.ignore_dependencies = true
429-
request_set.soft_missing = true
429+
request_set.ignore_dependencies = true
430+
request_set.soft_missing = true
430431
end
431432

432433
composed_set = Gem::Resolver.compose_sets as, installer_set

lib/rubygems/request_set.rb

+21-13
Original file line numberDiff line numberDiff line change
@@ -32,6 +32,12 @@ class Gem::RequestSet
3232

3333
attr_reader :git_set # :nodoc:
3434

35+
##
36+
# When true, dependency resolution is not performed, only the requested gems
37+
# are installed.
38+
39+
attr_accessor :ignore_dependencies
40+
3541
##
3642
# Sets used for resolution
3743

@@ -59,17 +65,18 @@ class Gem::RequestSet
5965
def initialize *deps
6066
@dependencies = deps
6167

62-
@always_install = []
63-
@dependency_names = {}
64-
@development = false
65-
@git_set = nil
66-
@install_dir = Gem.dir
67-
@requests = []
68-
@sets = []
69-
@soft_missing = false
70-
@sorted = nil
71-
@specs = nil
72-
@vendor_set = nil
68+
@always_install = []
69+
@dependency_names = {}
70+
@development = false
71+
@git_set = nil
72+
@ignore_dependencies = false
73+
@install_dir = Gem.dir
74+
@requests = []
75+
@sets = []
76+
@soft_missing = false
77+
@sorted = nil
78+
@specs = nil
79+
@vendor_set = nil
7380

7481
yield self if block_given?
7582
end
@@ -230,8 +237,9 @@ def resolve set = Gem::Resolver::BestSet.new
230237
set = Gem::Resolver.compose_sets(*@sets)
231238

232239
resolver = Gem::Resolver.new @dependencies, set
233-
resolver.development = @development
234-
resolver.soft_missing = @soft_missing
240+
resolver.development = @development
241+
resolver.ignore_dependencies = @ignore_dependencies
242+
resolver.soft_missing = @soft_missing
235243

236244
@resolver = resolver
237245

lib/rubygems/resolver.rb

+14-6
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,11 @@ class Gem::Resolver
3131

3232
attr_accessor :development
3333

34+
##
35+
# When true, no dependencies are looked up for requested gems.
36+
37+
attr_accessor :ignore_dependencies
38+
3439
##
3540
# List of dependencies that could not be found in the configured sources.
3641

@@ -91,11 +96,12 @@ def initialize needed, set = nil
9196
@set = set || Gem::Resolver::IndexSet.new
9297
@needed = needed
9398

94-
@conflicts = []
95-
@development = false
96-
@missing = []
97-
@soft_missing = false
98-
@stats = Gem::Resolver::Stats.new
99+
@conflicts = []
100+
@development = false
101+
@ignore_dependencies = false
102+
@missing = []
103+
@soft_missing = false
104+
@stats = Gem::Resolver::Stats.new
99105
end
100106

101107
def explain stage, *data # :nodoc:
@@ -132,6 +138,8 @@ def activation_request dep, possible # :nodoc:
132138
end
133139

134140
def requests s, act, reqs=nil # :nodoc:
141+
return reqs if @ignore_dependencies
142+
135143
s.dependencies.reverse_each do |d|
136144
next if d.type == :development and not @development
137145
reqs.add Gem::Resolver::DependencyRequest.new(d, act)
@@ -151,7 +159,7 @@ def requests s, act, reqs=nil # :nodoc:
151159
def resolve
152160
@conflicts = []
153161

154-
needed = RequirementList.new
162+
needed = Gem::Resolver::RequirementList.new
155163

156164
@needed.reverse_each do |n|
157165
request = Gem::Resolver::DependencyRequest.new n, nil

test/rubygems/test_gem_dependency_installer.rb

+30
Original file line numberDiff line numberDiff line change
@@ -1202,6 +1202,36 @@ def test_gather_dependencies_old_required
12021202
assert_resolve %w[d-1 e-1], e1, @d1, @d2
12031203
end
12041204

1205+
def test_resolve_dependencies
1206+
util_setup_gems
1207+
1208+
FileUtils.mv @a1_gem, @tempdir
1209+
FileUtils.mv @b1_gem, @tempdir
1210+
1211+
inst = Gem::DependencyInstaller.new
1212+
request_set = inst.resolve_dependencies 'b', req('>= 0')
1213+
1214+
requests = request_set.sorted_requests.map { |req| req.full_name }
1215+
1216+
assert_equal %w[a-1 b-1], requests
1217+
end
1218+
1219+
def test_resolve_dependencies_ignore_dependencies
1220+
util_setup_gems
1221+
1222+
FileUtils.mv @a1_gem, @tempdir
1223+
FileUtils.mv @b1_gem, @tempdir
1224+
1225+
inst = Gem::DependencyInstaller.new :ignore_dependencies => true
1226+
request_set = inst.resolve_dependencies 'b', req('>= 0')
1227+
1228+
requests = request_set.sorted_requests.map { |req| req.full_name }
1229+
1230+
assert request_set.ignore_dependencies
1231+
1232+
assert_equal %w[b-1], requests
1233+
end
1234+
12051235
def util_write_a1_bin
12061236
write_file File.join('gems', 'a-1', 'bin', 'a_bin') do |fp|
12071237
fp.puts "#!/usr/bin/ruby"

test/rubygems/test_gem_request_set.rb

+16
Original file line numberDiff line numberDiff line change
@@ -202,6 +202,22 @@ def test_resolve_git
202202
rs.sets.map { |set| set.class }
203203
end
204204

205+
def test_resolve_ignore_dependencies
206+
a = util_spec "a", "2", "b" => ">= 2"
207+
b = util_spec "b", "2"
208+
209+
rs = Gem::RequestSet.new
210+
rs.gem "a"
211+
rs.ignore_dependencies = true
212+
213+
res = rs.resolve StaticSet.new([a, b])
214+
assert_equal 1, res.size
215+
216+
names = res.map { |s| s.full_name }.sort
217+
218+
assert_equal %w[a-2], names
219+
end
220+
205221
def test_resolve_incompatible
206222
a1 = util_spec 'a', 1
207223
a2 = util_spec 'a', 2

test/rubygems/test_gem_resolver.rb

+33
Original file line numberDiff line numberDiff line change
@@ -99,6 +99,39 @@ def test_handle_conflict
9999
assert_equal 2, res.conflicts.length
100100
end
101101

102+
def test_requests
103+
a1 = util_spec 'a', 1, 'b' => 2
104+
105+
r1 = Gem::Resolver::DependencyRequest.new dep('a', '= 1'), nil
106+
107+
act = Gem::Resolver::ActivationRequest.new a1, r1, false
108+
109+
res = Gem::Resolver.new [a1]
110+
111+
reqs = Gem::Resolver::RequirementList.new
112+
113+
res.requests a1, act, reqs
114+
115+
assert_equal ['b (= 2)'], reqs.to_a.map { |req| req.to_s }
116+
end
117+
118+
def test_requests_ignore_dependencies
119+
a1 = util_spec 'a', 1, 'b' => 2
120+
121+
r1 = Gem::Resolver::DependencyRequest.new dep('a', '= 1'), nil
122+
123+
act = Gem::Resolver::ActivationRequest.new a1, r1, false
124+
125+
res = Gem::Resolver.new [a1]
126+
res.ignore_dependencies = true
127+
128+
reqs = Gem::Resolver::RequirementList.new
129+
130+
res.requests a1, act, reqs
131+
132+
assert_empty reqs
133+
end
134+
102135
def test_no_overlap_specificly
103136
a = util_spec "a", '1'
104137
b = util_spec "b", "1"

0 commit comments

Comments
 (0)