2003-09-04 12:18:59 -04:00
|
|
|
require 'test/unit'
|
|
|
|
|
|
|
|
class TestTrace < Test::Unit::TestCase
|
|
|
|
def test_trace
|
|
|
|
$x = 1234
|
|
|
|
$y = 0
|
|
|
|
trace_var :$x, proc{$y = $x}
|
|
|
|
$x = 40414
|
2003-09-05 11:15:43 -04:00
|
|
|
assert_equal($x, $y)
|
2009-03-05 22:56:38 -05:00
|
|
|
|
2003-09-04 12:18:59 -04:00
|
|
|
untrace_var :$x
|
|
|
|
$x = 19660208
|
2003-09-06 13:27:58 -04:00
|
|
|
assert_not_equal($x, $y)
|
2009-03-05 22:56:38 -05:00
|
|
|
|
2003-09-04 12:18:59 -04:00
|
|
|
trace_var :$x, proc{$x *= 2}
|
|
|
|
$x = 5
|
2003-09-05 11:15:43 -04:00
|
|
|
assert_equal(10, $x)
|
2009-03-05 22:56:38 -05:00
|
|
|
|
2003-09-04 12:18:59 -04:00
|
|
|
untrace_var :$x
|
2003-09-05 11:15:43 -04:00
|
|
|
end
|
2008-05-14 08:52:17 -04:00
|
|
|
|
|
|
|
def test_trace_tainted_proc
|
|
|
|
$x = 1234
|
|
|
|
s = proc { $y = :foo }
|
|
|
|
trace_var :$x, s
|
|
|
|
s.taint
|
|
|
|
$x = 42
|
|
|
|
assert_equal(:foo, $y)
|
|
|
|
ensure
|
|
|
|
untrace_var :$x
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_trace_proc_that_raises_exception
|
|
|
|
$x = 1234
|
|
|
|
trace_var :$x, proc { raise }
|
|
|
|
assert_raise(RuntimeError) { $x = 42 }
|
|
|
|
ensure
|
|
|
|
untrace_var :$x
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_trace_string
|
|
|
|
$x = 1234
|
|
|
|
trace_var :$x, "$y = :bar"
|
|
|
|
$x = 42
|
|
|
|
assert_equal(:bar, $y)
|
|
|
|
ensure
|
|
|
|
untrace_var :$x
|
|
|
|
end
|
2010-08-31 23:56:39 -04:00
|
|
|
|
|
|
|
def test_trace_break
|
|
|
|
bug2722 = '[ruby-core:31783]'
|
|
|
|
a = Object.new.extend(Enumerable)
|
|
|
|
def a.each
|
|
|
|
yield
|
|
|
|
end
|
|
|
|
assert(Thread.start {
|
|
|
|
Thread.current.add_trace_func(proc{})
|
|
|
|
a.any? {true}
|
|
|
|
}.value, bug2722)
|
|
|
|
end
|
2003-09-04 12:18:59 -04:00
|
|
|
end
|