36526cd66a
the implementation of Net::LDAP::open
69 lines
1.7 KiB
Ruby
69 lines
1.7 KiB
Ruby
# $Id$
|
|
#
|
|
#
|
|
|
|
|
|
$:.unshift "lib"
|
|
|
|
require 'test/unit'
|
|
|
|
require 'net/ldap'
|
|
require 'net/ldif'
|
|
|
|
require 'sha1'
|
|
require 'base64'
|
|
|
|
class TestLdif < Test::Unit::TestCase
|
|
|
|
TestLdifFilename = "tests/testdata.ldif"
|
|
|
|
def test_empty_ldif
|
|
ds = Net::LDAP::Dataset::read_ldif( StringIO.new )
|
|
assert_equal( true, ds.empty? )
|
|
end
|
|
|
|
def test_ldif_with_comments
|
|
str = ["# Hello from LDIF-land", "# This is an unterminated comment"]
|
|
io = StringIO.new( str[0] + "\r\n" + str[1] )
|
|
ds = Net::LDAP::Dataset::read_ldif( io )
|
|
assert_equal( str, ds.comments )
|
|
end
|
|
|
|
def test_ldif_with_password
|
|
psw = "goldbricks"
|
|
hashed_psw = "{SHA}" + Base64::encode64( SHA1.new(psw).digest ).chomp
|
|
|
|
ldif_encoded = Base64::encode64( hashed_psw ).chomp
|
|
ds = Net::LDAP::Dataset::read_ldif( StringIO.new( "dn: Goldbrick\r\nuserPassword:: #{ldif_encoded}\r\n\r\n" ))
|
|
recovered_psw = ds["Goldbrick"][:userpassword].shift
|
|
assert_equal( hashed_psw, recovered_psw )
|
|
end
|
|
|
|
def test_ldif_with_continuation_lines
|
|
ds = Net::LDAP::Dataset::read_ldif( StringIO.new( "dn: abcdefg\r\n hijklmn\r\n\r\n" ))
|
|
assert_equal( true, ds.has_key?( "abcdefg hijklmn" ))
|
|
end
|
|
|
|
# TODO, INADEQUATE. We need some more tests
|
|
# to verify the content.
|
|
def test_ldif
|
|
File.open( TestLdifFilename, "r" ) {|f|
|
|
ds = Net::LDAP::Dataset::read_ldif( f )
|
|
assert_equal( 13, ds.length )
|
|
}
|
|
end
|
|
|
|
# TODO, need some tests.
|
|
# Must test folded lines and base64-encoded lines as well as normal ones.
|
|
def test_to_ldif
|
|
File.open( TestLdifFilename, "r" ) {|f|
|
|
ds = Net::LDAP::Dataset::read_ldif( f )
|
|
ds.to_ldif
|
|
assert_equal( true, false ) # REMOVE WHEN WE HAVE SOME TESTS HERE.
|
|
}
|
|
end
|
|
|
|
|
|
end
|
|
|
|
|