summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-08 11:36:18 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-08 11:36:18 +0000
commite960cf417abc5b3c2fef8271412fcfc9c2c32607 (patch)
tree058f5230a9b4ad1471ccaaf297b66c19fb3059bc /test
parent732b695163362f2ef865a077a22c2bf5187cd4d4 (diff)
* 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
Diffstat (limited to 'test')
-rw-r--r--test/socket/test_unix.rb25
1 files changed, 21 insertions, 4 deletions
diff --git a/test/socket/test_unix.rb b/test/socket/test_unix.rb
index e783faff3b..4d6aa23e40 100644
--- a/test/socket/test_unix.rb
+++ b/test/socket/test_unix.rb
@@ -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