mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	helper.rb: try with sudo
* test/dtrace/helper.rb (DTrace::TestCase#trap_probe): try with $SUDO if set. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@37986 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
		
							parent
							
								
									d22ac50ad4
								
							
						
					
					
						commit
						8818a574a1
					
				
					 1 changed files with 11 additions and 2 deletions
				
			
		| 
						 | 
				
			
			@ -2,6 +2,14 @@
 | 
			
		|||
require 'minitest/autorun'
 | 
			
		||||
require 'tempfile'
 | 
			
		||||
 | 
			
		||||
if Process.euid == 0
 | 
			
		||||
  ok = true
 | 
			
		||||
elsif (sudo = ENV["SUDO"]) and (`#{sudo} echo ok` rescue false)
 | 
			
		||||
  ok = true
 | 
			
		||||
else
 | 
			
		||||
  ok = false
 | 
			
		||||
end
 | 
			
		||||
ok &= (`dtrace -V` rescue false)
 | 
			
		||||
module DTrace
 | 
			
		||||
  class TestCase < MiniTest::Unit::TestCase
 | 
			
		||||
    INCLUDE = File.expand_path(File.join(File.dirname(__FILE__), '..'))
 | 
			
		||||
| 
						 | 
				
			
			@ -18,7 +26,8 @@ module DTrace
 | 
			
		|||
      d_path  = d.path
 | 
			
		||||
      rb_path = rb.path
 | 
			
		||||
 | 
			
		||||
      cmd = "dtrace -q -s #{d_path} -c '#{Gem.ruby} -I#{INCLUDE} #{rb_path}'"
 | 
			
		||||
      cmd = ["dtrace", "-q", "-s", d_path, "-c", "#{Gem.ruby} -I#{INCLUDE} #{rb_path}"]
 | 
			
		||||
      sudo = ENV["SUDO"] and cmd.unshift(sudo)
 | 
			
		||||
      probes = IO.popen(cmd) do |io|
 | 
			
		||||
        io.readlines
 | 
			
		||||
      end
 | 
			
		||||
| 
						 | 
				
			
			@ -27,4 +36,4 @@ module DTrace
 | 
			
		|||
      yield(d_path, rb_path, probes)
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end if Process.euid == 0 and (`dtrace -V` rescue false)
 | 
			
		||||
end if ok
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue