mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* test/dtrace/helper.rb: ignore empty SUDO. reuse SUDO value by using
class variable. use test/unit instead of minitest/autorun. dispose `Interrupted system call' error messages at parallel test. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@40630 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
95b690d2a7
commit
14c9944e88
1 changed files with 11 additions and 7 deletions
|
@ -1,26 +1,26 @@
|
|||
# -*- coding: us-ascii -*-
|
||||
require 'minitest/autorun'
|
||||
require 'test/unit'
|
||||
require 'tempfile'
|
||||
require_relative '../ruby/envutil'
|
||||
|
||||
if Process.euid == 0
|
||||
ok = true
|
||||
elsif (sudo = ENV["SUDO"]) and (`#{sudo} echo ok` rescue false)
|
||||
elsif (sudo = ENV["SUDO"]) and !sudo.empty? and (`#{sudo} echo ok` rescue false)
|
||||
ok = true
|
||||
else
|
||||
ok = false
|
||||
end
|
||||
ok &= (`dtrace -V` rescue false)
|
||||
module DTrace
|
||||
class TestCase < MiniTest::Unit::TestCase
|
||||
class TestCase < Test::Unit::TestCase
|
||||
INCLUDE = File.expand_path('..', File.dirname(__FILE__))
|
||||
|
||||
def trap_probe d_program, ruby_program
|
||||
d = Tempfile.new('probe.d')
|
||||
d = Tempfile.new(%w'probe .d')
|
||||
d.write d_program
|
||||
d.flush
|
||||
|
||||
rb = Tempfile.new('probed.rb')
|
||||
rb = Tempfile.new(%w'probed .rb')
|
||||
rb.write ruby_program
|
||||
rb.flush
|
||||
|
||||
|
@ -28,7 +28,7 @@ module DTrace
|
|||
rb_path = rb.path
|
||||
|
||||
cmd = ["dtrace", "-q", "-s", d_path, "-c", "#{EnvUtil.rubybin} -I#{INCLUDE} #{rb_path}"]
|
||||
if sudo = ENV["SUDO"]
|
||||
if sudo = @@sudo
|
||||
[RbConfig::CONFIG["LIBPATHENV"], "RUBY", "RUBYOPT"].each do |name|
|
||||
if name and val = ENV[name]
|
||||
cmd.unshift("#{name}=#{val}")
|
||||
|
@ -36,7 +36,7 @@ module DTrace
|
|||
end
|
||||
cmd.unshift(sudo)
|
||||
end
|
||||
probes = IO.popen(cmd) do |io|
|
||||
probes = IO.popen(cmd, err: [:child, :out]) do |io|
|
||||
io.readlines
|
||||
end
|
||||
d.close(true)
|
||||
|
@ -45,3 +45,7 @@ module DTrace
|
|||
end
|
||||
end
|
||||
end if ok
|
||||
|
||||
if ok
|
||||
DTrace::TestCase.class_variable_set(:@@sudo, sudo)
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue