aboutsummaryrefslogtreecommitdiffstats
path: root/test/test_rbconfig.rb
diff options
context:
space:
mode:
Diffstat (limited to 'test/test_rbconfig.rb')
-rw-r--r--test/test_rbconfig.rb12
1 files changed, 12 insertions, 0 deletions
diff --git a/test/test_rbconfig.rb b/test/test_rbconfig.rb
index 49d65e9d06..aa44c4edbf 100644
--- a/test/test_rbconfig.rb
+++ b/test/test_rbconfig.rb
@@ -1,10 +1,18 @@
require 'test/unit'
require 'rbconfig'
+require 'shellwords'
class TestRbConfig < Test::Unit::TestCase
+ @@with_config = {}
+
+ Shellwords::shellwords(CONFIG["configure_args"]).grep(/\A--with-([^=]*)=(.*)/) do
+ @@with_config[$1.tr('_', '-')] = $2
+ end
+
def test_sitedirs
RbConfig::MAKEFILE_CONFIG.each do |key, val|
next unless /\Asite(?!arch)/ =~ key
+ next if @@with_config[key]
assert_match(/(?:\$\(|\/)site/, val, key)
end
end
@@ -12,6 +20,7 @@ class TestRbConfig < Test::Unit::TestCase
def test_vendordirs
RbConfig::MAKEFILE_CONFIG.each do |key, val|
next unless /\Avendor(?!arch)/ =~ key
+ next if @@with_config[key]
assert_match(/(?:\$\(|\/)vendor/, val, key)
end
end
@@ -19,6 +28,7 @@ class TestRbConfig < Test::Unit::TestCase
def test_archdirs
RbConfig::MAKEFILE_CONFIG.each do |key, val|
next unless /\A(?!site|vendor|archdir\z).*arch.*dir\z/ =~ key
+ next if @@with_config[key]
assert_match(/\$\(arch|\$\(rubyarchprefix\)/, val, key)
end
end
@@ -27,6 +37,7 @@ class TestRbConfig < Test::Unit::TestCase
bug7823 = '[ruby-dev:46964] [Bug #7823]'
RbConfig::MAKEFILE_CONFIG.each do |key, val|
next unless /\Asite.*arch.*dir\z/ =~ key
+ next if @@with_config[key]
assert_match(/\$\(sitearch|\$\(rubysitearchprefix\)/, val, "#{key} #{bug7823}")
end
end
@@ -35,6 +46,7 @@ class TestRbConfig < Test::Unit::TestCase
bug7823 = '[ruby-dev:46964] [Bug #7823]'
RbConfig::MAKEFILE_CONFIG.each do |key, val|
next unless /\Avendor.*arch.*dir\z/ =~ key
+ next if @@with_config[key]
assert_match(/\$\(sitearch|\$\(rubysitearchprefix\)/, val, "#{key} #{bug7823}")
end
end