Sha256: 9d022c4924caf2d37791bc42c14ec9b6ff3334b63f5562bacd66092d3b919240
Contents?: true
Size: 1.73 KB
Versions: 8
Compression:
Stored size: 1.73 KB
Contents
# $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
Version data entries
8 entries across 8 versions & 2 rubygems