summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-12-03 07:02:19 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-12-03 07:02:19 +0000
commitb887c7c20ab81b50ed7cb8c7db3218c443985d6b (patch)
tree031095aca3d134a7739d0aee6638990570687884 /test
parente2977fc8f36cc25008011698b03fe7b012077101 (diff)
string.c: should not taint fstring
* string.c (rb_obj_as_string): fstring should not be infected. TODO: other frozen strings also may not be. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52872 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test')
-rw-r--r--test/ruby/test_object.rb9
1 files changed, 9 insertions, 0 deletions
diff --git a/test/ruby/test_object.rb b/test/ruby/test_object.rb
index a3c71d605c..27f3bd18ce 100644
--- a/test/ruby/test_object.rb
+++ b/test/ruby/test_object.rb
@@ -755,6 +755,15 @@ class TestObject < Test::Unit::TestCase
end
EOS
assert_match(/\bToS\u{3042}:/, x)
+
+ name = "X".freeze
+ x = Object.new.taint
+ class<<x;self;end.class_eval {define_method(:to_s) {name}}
+ assert_same(name, x.to_s)
+ assert_not_predicate(name, :tainted?)
+ assert_raise(RuntimeError) {name.taint}
+ assert_equal("X", [x].join(""))
+ assert_not_predicate(name, :tainted?)
end
def test_inspect