HEX
Server: Apache
System: Linux s198.coreserver.jp 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC 2025 x86_64
User: nagasaki (10062)
PHP: 7.1.33
Disabled: NONE
Upload Files
File: //usr/local/rvm/src/ruby-2.2.10/test/dtrace/test_require.rb
require_relative 'helper'

module DTrace
  class TestRequire < TestCase
    def test_require_entry
      probe = <<-eoprobe
ruby$target:::require-entry
{
  printf("%s %s %d\\n", copyinstr(arg0), copyinstr(arg1), arg2);
}
      eoprobe
      trap_probe(probe, ruby_program) { |d_file, rb_file, saw|
	required = saw.map { |s| s.split }.find_all do |(required, _)|
	  required == 'dtrace/dummy'
	end
	assert_equal 10, required.length
      }
    end

    def test_require_return
      probe = <<-eoprobe
ruby$target:::require-return
{
  printf("%s\\n", copyinstr(arg0));
}
      eoprobe
    end

    private
    def ruby_program
      "10.times { require 'dtrace/dummy' }"
    end
  end
end if defined?(DTrace::TestCase)