Sha256: 678f25f623781f846e3ab1749a97b8e3b63a7a0e6aa500cb1d010918ee242970

Contents?: true

Size: 1.56 KB

Versions: 3

Compression:

Stored size: 1.56 KB

Contents

#!/usr/bin/env ruby
require 'test/unit'
require_relative '../../app/frame'
require 'thread_frame'

class TestAppFrame < Test::Unit::TestCase

  include Trepan::Frame

  def test_app_frame
    frame = RubyVM::Frame.current
    base_count = frame.stack_size
    s = format_stack_entry(frame)
    pat = /^METHOD .*#test_app_frame\(\) in file .*test-app-frame.rb at line \d+/
    assert(s =~ pat, "got #{s}, expected pat #{pat}")
    1.times do 
      assert_equal(base_count+2, RubyVM::Frame.current.stack_size)
      s = format_stack_entry(frame)
      assert(s =~ pat, "got #{s}, expected pat #{pat}")
    end

    def inner_test(count)
      frame = RubyVM::Frame.current
      assert_equal(count, frame.stack_size)

      s = format_stack_entry(frame)
      pat = /^METHOD .*#inner_test\(count\) in file .*test-app-frame.rb at line \d+/
      assert(s =~ pat, "got: #{s.inspect},\nexpected: pat #{pat}")

      s = format_stack_entry(frame, :basename => true)
      pat = /^METHOD .*#inner_test\(count\) in file test-app-frame.rb at line \d+/
      assert(s =~ pat, "got: #{s.inspect},\nexpected: pat #{pat}")

      s = format_stack_entry(frame, :basename => true, :show_pc => true)
      pat = /^METHOD .*#inner_test\(count\) in file test-app-frame.rb at line \d+, pc: \d+/
      assert(s =~ pat, "got: #{s.inspect},\nexpected: pat #{pat}")
    end
    inner_test(base_count+1)
  end

  def test_return
    assert_equal(1, offset_for_return('return'))
    assert_equal(4, offset_for_return('c-return'))
    assert_raises RuntimeError do
      offset_for_return('c-call')
    end
  end

end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
trepanning-1.93.35 test/unit/test-app-frame.rb
trepanning-1.93.32 test/unit/test-app-frame.rb
trepanning-0.1.6 test/unit/test-app-frame.rb