summaryrefslogtreecommitdiff
path: root/test/dtrace/helper.rb
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-05-10 01:48:20 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-05-10 01:48:20 +0000
commit14c9944e88d8c03aeb26f450c72c4d9a6e6632e1 (patch)
treebad15ec21355350d80aabad6e8f5f50c7f2d2adc /test/dtrace/helper.rb
parent95b690d2a76f9911662161a4a5f95bba8688546f (diff)
* 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
Diffstat (limited to 'test/dtrace/helper.rb')
-rw-r--r--test/dtrace/helper.rb18
1 files changed, 11 insertions, 7 deletions
diff --git a/test/dtrace/helper.rb b/test/dtrace/helper.rb
index a462851dbf..318857c8dd 100644
--- a/test/dtrace/helper.rb
+++ b/test/dtrace/helper.rb
@@ -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