123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- # $Id: testldif.rb 61 2006-04-18 20:55:55Z blackhedd $
- #
- #
-
-
- $:.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
-
|