From 1e6cdc00e7bb33571016ce8a48a93a586b6ba6a8 Mon Sep 17 00:00:00 2001 From: shugo Date: Thu, 18 Nov 2004 06:12:12 +0000 Subject: * ext/readline/readline.c: check $SAFE. * test/readline/test_readline.rb: added tests for readline. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7309 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/readline/test_readline.rb | 57 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 test/readline/test_readline.rb (limited to 'test/readline') diff --git a/test/readline/test_readline.rb b/test/readline/test_readline.rb new file mode 100644 index 0000000000..f41f3584cb --- /dev/null +++ b/test/readline/test_readline.rb @@ -0,0 +1,57 @@ +begin + require "readline" +rescue LoadError +end + +if defined?(Readline) + +require "test/unit" +require "tempfile" + +class TestReadline < Test::Unit::TestCase + def test_readline + stdin = Tempfile.new("test_readline_stdin") + stdout = Tempfile.new("test_readline_stdout") + begin + stdin.write("hello\n") + stdin.rewind + line = replace_stdio(stdin, stdout) { Readline.readline("> ") } + assert_equal("hello", line) + assert_equal(true, line.tainted?) + assert_raises(SecurityError) do + Thread.start { + $SAFE = 1 + replace_stdio(stdin, stdout) { Readline.readline("> ".taint) } + }.join + end + assert_raises(SecurityError) do + Thread.start { + $SAFE = 4 + replace_stdio(stdin, stdout) { Readline.readline("> ") } + }.join + end + stdout.rewind + assert_equal("> ", stdout.read(2)) + ensure + stdin.close(true) + stdout.close(true) + end + end + + private + + def replace_stdio(stdin, stdout) + orig_stdin = STDIN.dup + orig_stdout = STDOUT.dup + STDIN.reopen(stdin) + STDOUT.reopen(stdout) + begin + yield + ensure + STDIN.reopen(orig_stdin) + STDOUT.reopen(orig_stdout) + end + end +end + +end -- cgit v1.2.3