2006-04-15 04:43:36 +00:00
|
|
|
# $Id$
|
|
|
|
#
|
|
|
|
#
|
|
|
|
|
|
|
|
|
2006-04-16 09:40:01 +00:00
|
|
|
$:.unshift "lib"
|
|
|
|
|
2006-04-18 20:55:55 +00:00
|
|
|
require 'test/unit'
|
|
|
|
|
2006-04-16 09:40:01 +00:00
|
|
|
require 'net/ldap'
|
2006-04-15 04:43:36 +00:00
|
|
|
require 'stringio'
|
|
|
|
|
|
|
|
|
|
|
|
class TestLdapClient < Test::Unit::TestCase
|
|
|
|
|
2006-04-16 11:10:17 +00:00
|
|
|
# TODO: these tests crash and burn if the associated
|
|
|
|
# LDAP testserver isn't up and running.
|
2006-04-17 17:57:33 +00:00
|
|
|
# We rely on being able to read a file with test data
|
|
|
|
# in LDIF format.
|
|
|
|
# TODO, WARNING: for the moment, this data is in a file
|
|
|
|
# whose name and location are HARDCODED into the
|
|
|
|
# instance method load_test_data.
|
2006-04-16 11:10:17 +00:00
|
|
|
|
2006-04-15 04:43:36 +00:00
|
|
|
def setup
|
|
|
|
@host = "127.0.0.1"
|
|
|
|
@port = 3890
|
|
|
|
@auth = {
|
|
|
|
:method => :simple,
|
|
|
|
:username => "cn=bigshot,dc=bayshorenetworks,dc=com",
|
|
|
|
:password => "opensesame"
|
|
|
|
}
|
|
|
|
|
2006-04-17 17:57:33 +00:00
|
|
|
@ldif = load_test_data
|
2006-04-15 04:43:36 +00:00
|
|
|
end
|
|
|
|
|
2006-04-17 17:57:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
# Get some test data which will be used to validate
|
|
|
|
# the responses from the test LDAP server we will
|
|
|
|
# connect to.
|
|
|
|
# TODO, Bogus: we are HARDCODING the location of the file for now.
|
|
|
|
#
|
|
|
|
def load_test_data
|
|
|
|
ary = File.readlines( "tests/testdata.ldif" )
|
|
|
|
hash = {}
|
|
|
|
while line = ary.shift and line.chomp!
|
|
|
|
if line =~ /^dn:[\s]*/i
|
|
|
|
dn = $'
|
|
|
|
hash[dn] = {}
|
|
|
|
while attr = ary.shift and attr.chomp! and attr =~ /^([\w]+)[\s]*:[\s]*/
|
|
|
|
hash[dn][$1.downcase.intern] ||= []
|
|
|
|
hash[dn][$1.downcase.intern] << $'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
hash
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
2006-04-15 04:43:36 +00:00
|
|
|
# Binding tests.
|
|
|
|
# Need tests for all kinds of network failures and incorrect auth.
|
|
|
|
# TODO: Implement a class-level timeout for operations like bind.
|
|
|
|
# Search has a timeout defined at the protocol level, other ops do not.
|
|
|
|
# TODO, use constants for the LDAP result codes, rather than hardcoding them.
|
|
|
|
def test_bind
|
|
|
|
ldap = Net::LDAP.new :host => @host, :port => @port, :auth => @auth
|
2006-04-23 01:13:41 +00:00
|
|
|
assert_equal( true, ldap.bind )
|
|
|
|
assert_equal( 0, ldap.get_operation_result.code )
|
|
|
|
assert_equal( "Success", ldap.get_operation_result.message )
|
2006-04-15 04:43:36 +00:00
|
|
|
|
|
|
|
bad_username = @auth.merge( {:username => "cn=badguy,dc=imposters,dc=com"} )
|
|
|
|
ldap = Net::LDAP.new :host => @host, :port => @port, :auth => bad_username
|
2006-04-23 01:13:41 +00:00
|
|
|
assert_equal( false, ldap.bind )
|
|
|
|
assert_equal( 48, ldap.get_operation_result.code )
|
|
|
|
assert_equal( "Inappropriate Authentication", ldap.get_operation_result.message )
|
2006-04-15 04:43:36 +00:00
|
|
|
|
|
|
|
bad_password = @auth.merge( {:password => "cornhusk"} )
|
|
|
|
ldap = Net::LDAP.new :host => @host, :port => @port, :auth => bad_password
|
2006-04-23 01:13:41 +00:00
|
|
|
assert_equal( false, ldap.bind )
|
|
|
|
assert_equal( 49, ldap.get_operation_result.code )
|
|
|
|
assert_equal( "Invalid Credentials", ldap.get_operation_result.message )
|
2006-04-15 04:43:36 +00:00
|
|
|
end
|
|
|
|
|
2006-04-17 17:57:33 +00:00
|
|
|
|
|
|
|
|
2006-04-15 04:43:36 +00:00
|
|
|
def test_search
|
|
|
|
ldap = Net::LDAP.new :host => @host, :port => @port, :auth => @auth
|
|
|
|
|
|
|
|
search = {:base => "dc=smalldomain,dc=com"}
|
2006-04-23 01:17:49 +00:00
|
|
|
assert_equal( false, ldap.search( search ))
|
|
|
|
assert_equal( 32, ldap.get_operation_result.code )
|
2006-04-15 04:43:36 +00:00
|
|
|
|
2006-04-17 03:44:55 +00:00
|
|
|
search = {:base => "dc=bayshorenetworks,dc=com"}
|
2006-04-23 01:17:49 +00:00
|
|
|
assert_equal( true, ldap.search( search ))
|
|
|
|
assert_equal( 0, ldap.get_operation_result.code )
|
2006-04-15 04:43:36 +00:00
|
|
|
|
|
|
|
ldap.search( search ) {|res|
|
2006-04-17 17:57:33 +00:00
|
|
|
assert_equal( res, @ldif )
|
2006-04-15 04:43:36 +00:00
|
|
|
}
|
2006-04-16 11:10:17 +00:00
|
|
|
end
|
2006-04-15 04:43:36 +00:00
|
|
|
|
|
|
|
|
2006-04-17 17:57:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
# This is a helper routine for test_search_attributes.
|
|
|
|
def internal_test_search_attributes attrs_to_search
|
2006-04-16 11:10:17 +00:00
|
|
|
ldap = Net::LDAP.new :host => @host, :port => @port, :auth => @auth
|
2006-04-23 01:13:41 +00:00
|
|
|
assert( ldap.bind )
|
2006-04-16 11:10:17 +00:00
|
|
|
|
|
|
|
search = {
|
2006-04-17 03:44:55 +00:00
|
|
|
:base => "dc=bayshorenetworks,dc=com",
|
2006-04-17 17:57:33 +00:00
|
|
|
:attributes => attrs_to_search
|
2006-04-16 11:10:17 +00:00
|
|
|
}
|
|
|
|
|
2006-04-17 17:57:33 +00:00
|
|
|
ldif = @ldif
|
|
|
|
ldif.each {|dn,entry|
|
|
|
|
entry.delete_if {|attr,value|
|
|
|
|
! attrs_to_search.include?(attr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-04-23 01:17:49 +00:00
|
|
|
assert_equal( true, ldap.search( search ))
|
2006-04-16 11:10:17 +00:00
|
|
|
ldap.search( search ) {|res|
|
2006-04-17 17:57:33 +00:00
|
|
|
res_keys = res.keys.sort
|
|
|
|
ldif_keys = ldif.keys.sort
|
|
|
|
assert( res_keys, ldif_keys )
|
|
|
|
res.keys.each {|rk|
|
|
|
|
assert( res[rk], ldif[rk] )
|
|
|
|
}
|
2006-04-16 11:10:17 +00:00
|
|
|
}
|
2006-04-15 04:43:36 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
|
2006-04-17 17:57:33 +00:00
|
|
|
def test_search_attributes
|
|
|
|
internal_test_search_attributes [:mail]
|
|
|
|
internal_test_search_attributes [:cn]
|
|
|
|
internal_test_search_attributes [:ou]
|
|
|
|
internal_test_search_attributes [:hasaccessprivilege]
|
|
|
|
internal_test_search_attributes ["mail"]
|
|
|
|
internal_test_search_attributes ["cn"]
|
|
|
|
internal_test_search_attributes ["ou"]
|
|
|
|
internal_test_search_attributes ["hasaccessrole"]
|
|
|
|
|
|
|
|
internal_test_search_attributes [:mail, :cn, :ou, :hasaccessrole]
|
|
|
|
internal_test_search_attributes [:mail, "cn", :ou, "hasaccessrole"]
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2006-04-16 11:10:17 +00:00
|
|
|
def test_search_filters
|
2006-04-17 17:57:33 +00:00
|
|
|
ldap = Net::LDAP.new :host => @host, :port => @port, :auth => @auth
|
|
|
|
search = {
|
|
|
|
:base => "dc=bayshorenetworks,dc=com",
|
2006-04-17 20:39:54 +00:00
|
|
|
:filter => Net::LDAP::Filter.eq( "sn", "Fosse" )
|
2006-04-17 17:57:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ldap.search( search ) {|res|
|
|
|
|
p res
|
|
|
|
}
|
2006-04-16 11:10:17 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
2006-04-18 20:55:55 +00:00
|
|
|
def test_open
|
2006-04-18 21:11:33 +00:00
|
|
|
ldap = Net::LDAP.new :host => @host, :port => @port, :auth => @auth
|
|
|
|
ldap.open {|ldap|
|
|
|
|
10.times {
|
|
|
|
rc = ldap.search( :base => "dc=bayshorenetworks,dc=com" )
|
2006-04-23 01:17:49 +00:00
|
|
|
assert_equal( true, rc )
|
2006-04-18 21:11:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
def test_ldap_open
|
|
|
|
Net::LDAP.open( :host => @host, :port => @port, :auth => @auth ) {|ldap|
|
|
|
|
10.times {
|
|
|
|
rc = ldap.search( :base => "dc=bayshorenetworks,dc=com" )
|
2006-04-23 01:17:49 +00:00
|
|
|
assert_equal( true, rc )
|
2006-04-18 21:11:33 +00:00
|
|
|
}
|
2006-04-18 20:55:55 +00:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
2006-04-16 11:10:17 +00:00
|
|
|
|
|
|
|
|
2006-04-15 04:43:36 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
|