LdifEntry reverse = LdifRevertor.reverseAdd( reverseDn );
String zuluTime = DateUtils.getGeneralizedTime();
long revision = 1L;
LdapPrincipal principal = new LdapPrincipal( adminDn, AuthenticationLevel.SIMPLE, StringTools.getBytesUtf8( "secret" ) );
ChangeLogEvent event = new ChangeLogEvent( revision, zuluTime, principal, forward, reverse );
ByteArrayOutputStream baos = new ByteArrayOutputStream();
ObjectOutputStream out = new ObjectOutputStream( baos );
out.writeObject( event );
byte[] data = baos.toByteArray();
ObjectInputStream in = new ObjectInputStream( new ByteArrayInputStream( data ) );
ChangeLogEvent read = (ChangeLogEvent)in.readObject();
// The read event should not be equal to the written event, as
// the principal's password has not been stored
assertNotSame( event, read );
LdapPrincipal readPrincipal = read.getCommitterPrincipal();
assertEquals( principal.getAuthenticationLevel(), readPrincipal.getAuthenticationLevel() );
assertEquals( principal.getName(), readPrincipal.getName() );
assertEquals( principal.getClonedName(), readPrincipal.getClonedName() );
assertNull( readPrincipal.getUserPassword() );
assertEquals( zuluTime, read.getZuluTime() );
assertEquals( revision, read.getRevision() );
assertEquals( forward, read.getForwardLdif() );
assertEquals( reverse, read.getReverseLdifs().get( 0 ) );