summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authormame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-05-21 15:31:15 +0000
committermame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-05-21 15:31:15 +0000
commit2c8dd794e9c86846f5989569b76c8c8006b18853 (patch)
treee2557f8521156567643b56776c2818cdfa04e871 /test
parent4c094940aa8544e3ee149dee57ec294a47f3099d (diff)
* test/ruby/test_require.rb: new tests for library requiring, to
achieve over 90% test coverage of dln.c. * test/ruby/test_class.rb: add tests to achieve over 90% test coverage of class.c. * test/ruby/test_module.rb: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@16510 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test')
-rw-r--r--test/ruby/test_class.rb41
-rw-r--r--test/ruby/test_module.rb19
-rw-r--r--test/ruby/test_require.rb215
3 files changed, 275 insertions, 0 deletions
diff --git a/test/ruby/test_class.rb b/test/ruby/test_class.rb
index d4813a5f07..8c035b5d59 100644
--- a/test/ruby/test_class.rb
+++ b/test/ruby/test_class.rb
@@ -1,6 +1,10 @@
require 'test/unit'
+require_relative 'envutil'
class TestClass < Test::Unit::TestCase
+ def ruby(*r, &b)
+ EnvUtil.rubyexec(*r, &b)
+ end
# ------------------
# Various test classes
@@ -105,4 +109,41 @@ class TestClass < Test::Unit::TestCase
end
end
+ def test_check_inheritable
+ assert_raise(TypeError) { Class.new(Object.new) }
+
+ o = Object.new
+ c = class << o; self; end
+ assert_raise(TypeError) { Class.new(c) }
+
+ assert_nothing_raised { Class.new(Class) } # is it OK?
+ assert_raise(TypeError) { eval("class Foo < Class; end") }
+ end
+
+ def test_initialize_copy
+ c = Class.new
+ assert_raise(TypeError) { c.instance_eval { initialize_copy(1) } }
+
+ o = Object.new
+ c = class << o; self; end
+ assert_raise(TypeError) { c.dup }
+ end
+
+ def test_singleton_class
+ assert_raise(TypeError) { 1.extend(Module.new) }
+ assert_raise(TypeError) { :foo.extend(Module.new) }
+
+ ruby do |w, r, e|
+ w.puts "module Foo; def foo; :foo; end; end"
+ w.puts "false.extend(Foo)"
+ w.puts "true.extend(Foo)"
+ w.puts "p false.foo"
+ w.puts "p true.foo"
+ w.puts "p FalseClass.include?(Foo)"
+ w.puts "p TrueClass.include?(Foo)"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":foo\n:foo\ntrue\ntrue", r.read.chomp)
+ end
+ end
end
diff --git a/test/ruby/test_module.rb b/test/ruby/test_module.rb
index 6b5a6be533..2e9d69af90 100644
--- a/test/ruby/test_module.rb
+++ b/test/ruby/test_module.rb
@@ -690,4 +690,23 @@ class TestModule < Test::Unit::TestCase
o.extend(m2)
assert_equal(true, o.respond_to?(:foo))
end
+
+ def test_cyclic_include
+ m1 = Module.new
+ m2 = Module.new
+ m1.instance_eval { include(m2) }
+ assert_raise(ArgumentError) do
+ m2.instance_eval { include(m1) }
+ end
+ end
+
+ def test_include_p
+ m = Module.new
+ c1 = Class.new
+ c1.instance_eval { include(m) }
+ c2 = Class.new(c1)
+ assert_equal(true, c1.include?(m))
+ assert_equal(true, c2.include?(m))
+ assert_equal(false, m.include?(m))
+ end
end
diff --git a/test/ruby/test_require.rb b/test/ruby/test_require.rb
new file mode 100644
index 0000000000..299baeac62
--- /dev/null
+++ b/test/ruby/test_require.rb
@@ -0,0 +1,215 @@
+require 'test/unit'
+
+require 'tempfile'
+require_relative 'envutil'
+
+class TestRequire < Test::Unit::TestCase
+ def ruby(*r, &b)
+ EnvUtil.rubyexec(*r, &b)
+ end
+
+ def test_require_invalid_shared_object
+ t = Tempfile.new(["test_ruby_test_require", ".so"])
+ t.puts "dummy"
+ t.close
+
+ ruby do |w, r, e|
+ w.puts "begin"
+ w.puts " require \"#{ t.path }\""
+ w.puts "rescue LoadError"
+ w.puts " p :ok"
+ w.puts "end"
+ w.close
+ assert_equal(":ok", r.read.chomp)
+ end
+ end
+
+ def test_require_too_long_filename
+ ruby do |w, r, e|
+ w.puts "begin"
+ w.puts " require '#{ "foo/" * 10000 }foo'"
+ w.puts "rescue LoadError"
+ w.puts " p :ok"
+ w.puts "end"
+ w.close
+ e.read
+ assert_equal(":ok", r.read.chomp)
+ end
+ end
+
+ def test_require_path_home
+ env_rubypath, env_home = ENV["RUBYPATH"], ENV["HOME"]
+
+ ENV["RUBYPATH"] = "~"
+ ENV["HOME"] = "/foo" * 10000
+ ruby("-S", "test_ruby_test_require") do |w, r, e|
+ w.close
+ e.read
+ assert_equal("", r.read)
+ end
+
+ ENV["RUBYPATH"] = "~" + "/foo" * 10000
+ ENV["HOME"] = "/foo"
+ ruby("-S", "test_ruby_test_require") do |w, r, e|
+ w.close
+ e.read
+ assert_equal("", r.read)
+ end
+
+ t = Tempfile.new(["test_ruby_test_require", ".rb"])
+ t.puts "p :ok"
+ t.close
+ ENV["RUBYPATH"] = "~"
+ ENV["HOME"], name = File.split(t.path)
+ ruby("-S", name) do |w, r, e|
+ w.close
+ assert_equal(":ok", r.read.chomp)
+ assert_equal("", e.read)
+ end
+
+ ensure
+ env_rubypath ? ENV["RUBYPATH"] = env_rubypath : ENV.delete("RUBYPATH")
+ env_home ? ENV["HOME"] = env_home : ENV.delete("HOME")
+ end
+
+ def test_define_class
+ begin
+ require "socket"
+ rescue LoadError
+ return
+ end
+
+ ruby do |w, r, e|
+ w.puts "BasicSocket = 1"
+ w.puts "begin"
+ w.puts " require 'socket'"
+ w.puts " p :ng"
+ w.puts "rescue TypeError"
+ w.puts " p :ok"
+ w.puts "end"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":ok", r.read.chomp)
+ end
+
+ ruby do |w, r, e|
+ w.puts "class BasicSocket; end"
+ w.puts "begin"
+ w.puts " require 'socket'"
+ w.puts " p :ng"
+ w.puts "rescue NameError"
+ w.puts " p :ok"
+ w.puts "end"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":ok", r.read.chomp)
+ end
+
+ ruby do |w, r, e|
+ w.puts "class BasicSocket < IO; end"
+ w.puts "begin"
+ w.puts " require 'socket'"
+ w.puts " p :ok"
+ w.puts "rescue Exception"
+ w.puts " p :ng"
+ w.puts "end"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":ok", r.read.chomp)
+ end
+ end
+
+ def test_define_class_under
+ begin
+ require "zlib"
+ rescue LoadError
+ return
+ end
+
+ ruby do |w, r, e|
+ w.puts "module Zlib; end"
+ w.puts "Zlib::Error = 1"
+ w.puts "begin"
+ w.puts " require 'zlib'"
+ w.puts " p :ng"
+ w.puts "rescue TypeError"
+ w.puts " p :ok"
+ w.puts "end"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":ok", r.read.chomp)
+ end
+
+ ruby do |w, r, e|
+ w.puts "module Zlib; end"
+ w.puts "class Zlib::Error; end"
+ w.puts "begin"
+ w.puts " require 'zlib'"
+ w.puts " p :ng"
+ w.puts "rescue NameError"
+ w.puts " p :ok"
+ w.puts "end"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":ok", r.read.chomp)
+ end
+
+ ruby do |w, r, e|
+ w.puts "module Zlib; end"
+ w.puts "class Zlib::Error < StandardError; end"
+ w.puts "begin"
+ w.puts " require 'zlib'"
+ w.puts " p :ok"
+ w.puts "rescue Exception"
+ w.puts " p :ng"
+ w.puts "end"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":ok", r.read.chomp)
+ end
+ end
+
+ def test_define_module
+ begin
+ require "zlib"
+ rescue LoadError
+ return
+ end
+
+ ruby do |w, r, e|
+ w.puts "Zlib = 1"
+ w.puts "begin"
+ w.puts " require 'zlib'"
+ w.puts " p :ng"
+ w.puts "rescue TypeError"
+ w.puts " p :ok"
+ w.puts "end"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":ok", r.read.chomp)
+ end
+ end
+
+ def test_define_module_under
+ begin
+ require "socket"
+ rescue LoadError
+ return
+ end
+
+ ruby do |w, r, e|
+ w.puts "class BasicSocket < IO; end"
+ w.puts "class Socket < BasicSocket; end"
+ w.puts "Socket::Constants = 1"
+ w.puts "begin"
+ w.puts " require 'socket'"
+ w.puts " p :ng"
+ w.puts "rescue TypeError"
+ w.puts " p :ok"
+ w.puts "end"
+ w.close
+ assert_equal("", e.read)
+ assert_equal(":ok", r.read.chomp)
+ end
+ end
+end