mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* ext/socket/extconf.rb: check struct sockcred.
* ext/socket/ancdata.c (anc_inspect_socket_creds): new function to show SCM_CREDS on NetBSD. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@22126 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
732b695163
commit
e960cf417a
4 changed files with 68 additions and 4 deletions
|
@ -306,11 +306,28 @@ class TestUNIXSocket < Test::Unit::TestCase
|
|||
s.setsockopt(:SOCKET, :PASSCRED, 1)
|
||||
c.print "a"
|
||||
msg, cliend_ai, rflags, cred = s.recvmsg
|
||||
p cred
|
||||
assert_equal("a", msg)
|
||||
assert_match(/pid=#{$$} /, cred.inspect)
|
||||
assert_match(/uid=#{Process.uid} /, cred.inspect)
|
||||
assert_match(/gid=#{Process.gid}>/, cred.inspect)
|
||||
assert_match(/ pid=#{$$} /, cred.inspect)
|
||||
assert_match(/ uid=#{Process.uid} /, cred.inspect)
|
||||
assert_match(/ gid=#{Process.gid}>/, cred.inspect)
|
||||
}
|
||||
end
|
||||
|
||||
def test_netbsd_cred
|
||||
return if /netbsd/ !~ RUBY_PLATFORM
|
||||
Dir.mktmpdir {|d|
|
||||
sockpath = "#{d}/sock"
|
||||
serv = Socket.unix_server_socket(sockpath)
|
||||
c = Socket.unix(sockpath)
|
||||
s, = serv.accept
|
||||
s.setsockopt(0, Socket::LOCAL_CREDS, 1)
|
||||
c.print "a"
|
||||
msg, cliend_ai, rflags, cred = s.recvmsg
|
||||
assert_equal("a", msg)
|
||||
assert_match(/ uid=#{Process.uid} /, cred.inspect)
|
||||
assert_match(/ euid=#{Process.euid} /, cred.inspect)
|
||||
assert_match(/ gid=#{Process.gid} /, cred.inspect)
|
||||
assert_match(/ egid=#{Process.egid} /, cred.inspect)
|
||||
}
|
||||
end
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue