aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorDavid Rodríguez <deivid.rodriguez@riseup.net>2020-03-25 15:55:16 +0100
committerHiroshi SHIBATA <hsbt@ruby-lang.org>2020-06-05 07:32:42 +0900
commitf8f5e7fadf689a11a8ee28b7af4e7777e2dec1ea (patch)
tree2c8c7e793df0504e93e714a105ad2f5d27463708 /test
parentff5ca548c3540c5a98a3851248248de117b2bf2f (diff)
downloadruby-f8f5e7fadf689a11a8ee28b7af4e7777e2dec1ea.tar.gz
[rubygems/rubygems] Respect files loaded from default gems before rubygems
https://github.com/rubygems/rubygems/commit/f3da3c1190
Diffstat (limited to 'test')
-rw-r--r--test/rubygems/test_require.rb18
1 files changed, 18 insertions, 0 deletions
diff --git a/test/rubygems/test_require.rb b/test/rubygems/test_require.rb
index 56aa37f65b..2b11e26dfe 100644
--- a/test/rubygems/test_require.rb
+++ b/test/rubygems/test_require.rb
@@ -300,6 +300,24 @@ class TestGemRequire < Gem::TestCase
$LOAD_PATH.replace lp if load_path_changed
end
+ def test_activate_via_require_respects_loaded_default_from_default_gems
+ a1 = new_default_spec "a", "1", nil, "a.rb"
+
+ # simulate requiring a default gem before rubygems is loaded
+ Kernel.send(:gem_original_require, "a")
+
+ # simulate registering default specs on loading rubygems
+ install_default_gems a1
+
+ a2 = util_spec "a", "2", nil, "lib/a.rb"
+
+ install_specs a2
+
+ refute_require 'a'
+
+ assert_equal %w[a-1], loaded_spec_names
+ end
+
def test_already_activated_direct_conflict
a1 = util_spec "a", "1", { "b" => "> 0" }
b1 = util_spec "b", "1", { "c" => ">= 1" }, "lib/ib.rb"