use of com.unboundid.ldif.LDIFDeleteChangeRecord in project ldapsdk by pingidentity.
the class RenameAttributeTransformationTestCase method testTransformDeleteChangeRecordExcludeDNs.
/**
* Provides test coverage for the transformChangeRecord method for a delete
* change record in which renames should not be applied in DNs.
*
* @throws Exception If an unexpected problem occurs.
*/
@Test()
public void testTransformDeleteChangeRecordExcludeDNs() throws Exception {
final Schema schema = Schema.getDefaultStandardSchema();
final RenameAttributeTransformation t = new RenameAttributeTransformation(schema, "cn", "fullName", false);
final LDIFChangeRecord r = t.transformChangeRecord(new LDIFDeleteChangeRecord("cn=A,2.5.4.3=B,dc=example,dc=com"));
assertNotNull(r);
assertEquals(r, new LDIFDeleteChangeRecord("cn=A,2.5.4.3=B,dc=example,dc=com"));
}
use of com.unboundid.ldif.LDIFDeleteChangeRecord in project ldapsdk by pingidentity.
the class RenameAttributeTransformationTestCase method testTransformDeleteChangeRecordIncludeDNs.
/**
* Provides test coverage for the transformChangeRecord method for a delete
* change record in which renames should be applied in DNs.
*
* @throws Exception If an unexpected problem occurs.
*/
@Test()
public void testTransformDeleteChangeRecordIncludeDNs() throws Exception {
final Schema schema = Schema.getDefaultStandardSchema();
final RenameAttributeTransformation t = new RenameAttributeTransformation(schema, "cn", "fullName", true);
final LDIFChangeRecord r = t.transformChangeRecord(new LDIFDeleteChangeRecord("cn=A,2.5.4.3=B,dc=example,dc=com"));
assertNotNull(r);
assertEquals(r, new LDIFDeleteChangeRecord("fullName=A,fullName=B,dc=example,dc=com"));
}
use of com.unboundid.ldif.LDIFDeleteChangeRecord in project ldapsdk by pingidentity.
the class AddAuditLogMessageTestCase method testBasicLogMessageFromListAndChangeRecord.
/**
* Tests the behavior for a basic add audit log message read from a list of
* strings and an already-provided change record.
*
* @throws Exception If an unexpected problem occurs.
*/
@Test()
public void testBasicLogMessageFromListAndChangeRecord() throws Exception {
final AddAuditLogMessage m = new AddAuditLogMessage(Arrays.asList("# 23/Aug/2018:14:02:40 -0500; conn=28; op=1; " + "authzDN=\"cn=Directory Manager,cn=Root DNs,cn=config\"", "dn: ou=People,dc=example,dc=com", "changetype: add", "objectClass: top", "objectClass: organizationalUnit", "ou: People", "createTimestamp: 20180823190240.967Z", "creatorsName: cn=Directory Manager,cn=Root DNs,cn=config", "modifyTimestamp: 20180823190240.967Z", "modifiersName: cn=Directory Manager,cn=Root DNs,cn=config", "entryUUID: b58849bd-2032-4077-ba10-2cd9be8166e0"), new LDIFAddChangeRecord(new AddRequest("dn: ou=People,dc=example,dc=com", "changetype: add", "objectClass: top", "objectClass: organizationalUnit", "ou: People", "createTimestamp: 20180823190240.967Z", "creatorsName: cn=Directory Manager,cn=Root DNs,cn=config", "modifyTimestamp: 20180823190240.967Z", "modifiersName: cn=Directory Manager,cn=Root DNs,cn=config", "entryUUID: b58849bd-2032-4077-ba10-2cd9be8166e0")));
assertNotNull(m.getLogMessageLines());
assertFalse(m.getLogMessageLines().isEmpty());
assertNotNull(m.getCommentedHeaderLine());
assertTrue(m.getCommentedHeaderLine().startsWith("# "));
assertNotNull(m.getUncommentedHeaderLine());
assertFalse(m.getUncommentedHeaderLine().isEmpty());
assertFalse(m.getUncommentedHeaderLine().startsWith("# "));
assertEquals(m.getUncommentedHeaderLine(), m.getCommentedHeaderLine().substring(2));
assertNotNull(m.getTimestamp());
final Calendar calendar = new GregorianCalendar();
calendar.setTime(m.getTimestamp());
assertEquals(calendar.get(Calendar.YEAR), 2018);
assertEquals(calendar.get(Calendar.MONTH), Calendar.AUGUST);
assertNotNull(m.getHeaderNamedValues());
assertFalse(m.getHeaderNamedValues().isEmpty());
assertTrue(m.getHeaderNamedValues().containsKey("conn"));
assertNull(m.getProductName());
assertNull(m.getInstanceName());
assertNull(m.getStartupID());
assertNull(m.getThreadID());
assertNull(m.getRequesterDN());
assertNull(m.getRequesterIPAddress());
assertNotNull(m.getConnectionID());
assertEquals(m.getConnectionID().longValue(), 28L);
assertNotNull(m.getOperationID());
assertEquals(m.getOperationID().longValue(), 1L);
assertNull(m.getTriggeredByConnectionID());
assertNull(m.getTriggeredByOperationID());
assertNull(m.getReplicationChangeID());
assertNotNull(m.getAlternateAuthorizationDN());
assertDNsEqual(m.getAlternateAuthorizationDN(), "cn=Directory Manager,cn=Root DNs,cn=config");
assertNull(m.getTransactionID());
assertNull(m.getOrigin());
assertNull(m.getUsingAdminSessionWorkerThread());
assertNull(m.getRequestControlOIDs());
assertNull(m.getOperationPurposeRequestControl());
assertNull(m.getIntermediateClientRequestControl());
assertNotNull(m.getDN());
assertDNsEqual(m.getDN(), "ou=People,dc=example,dc=com");
assertNotNull(m.getEntry());
assertNull(m.getIsUndelete());
assertNull(m.getUndeleteRequestEntry());
assertNotNull(m.getChangeType());
assertEquals(m.getChangeType(), ChangeType.ADD);
assertNotNull(m.getChangeRecord());
assertTrue(m.getChangeRecord() instanceof LDIFAddChangeRecord);
assertTrue(m.isRevertible());
assertNotNull(m.getRevertChangeRecords());
assertFalse(m.getRevertChangeRecords().isEmpty());
assertEquals(m.getRevertChangeRecords().size(), 1);
assertTrue(m.getRevertChangeRecords().get(0) instanceof LDIFDeleteChangeRecord);
assertNotNull(m.toString());
assertNotNull(m.toMultiLineString());
}
use of com.unboundid.ldif.LDIFDeleteChangeRecord in project ldapsdk by pingidentity.
the class AddAuditLogMessageTestCase method testBasicLogMessageFromArray.
/**
* Tests the behavior for a basic add audit log message read from an array of
* strings.
*
* @throws Exception If an unexpected problem occurs.
*/
@Test()
public void testBasicLogMessageFromArray() throws Exception {
final AddAuditLogMessage m = new AddAuditLogMessage("# 23/Aug/2018:14:02:40 -0500; conn=28; op=1; " + "authzDN=\"cn=Directory Manager,cn=Root DNs,cn=config\"", "dn: ou=People,dc=example,dc=com", "changetype: add", "objectClass: top", "objectClass: organizationalUnit", "ou: People", "createTimestamp: 20180823190240.967Z", "creatorsName: cn=Directory Manager,cn=Root DNs,cn=config", "modifyTimestamp: 20180823190240.967Z", "modifiersName: cn=Directory Manager,cn=Root DNs,cn=config", "entryUUID: b58849bd-2032-4077-ba10-2cd9be8166e0");
assertNotNull(m.getLogMessageLines());
assertFalse(m.getLogMessageLines().isEmpty());
assertNotNull(m.getCommentedHeaderLine());
assertEquals(m.getCommentedHeaderLine(), "# 23/Aug/2018:14:02:40 -0500; conn=28; op=1; " + "authzDN=\"cn=Directory Manager,cn=Root DNs,cn=config\"");
assertNotNull(m.getUncommentedHeaderLine());
assertEquals(m.getUncommentedHeaderLine(), "23/Aug/2018:14:02:40 -0500; conn=28; op=1; " + "authzDN=\"cn=Directory Manager,cn=Root DNs,cn=config\"");
assertNotNull(m.getTimestamp());
final Calendar calendar = new GregorianCalendar();
calendar.setTime(m.getTimestamp());
assertEquals(calendar.get(Calendar.YEAR), 2018);
assertEquals(calendar.get(Calendar.MONTH), Calendar.AUGUST);
assertNotNull(m.getHeaderNamedValues());
assertFalse(m.getHeaderNamedValues().isEmpty());
assertTrue(m.getHeaderNamedValues().containsKey("conn"));
assertNull(m.getProductName());
assertNull(m.getInstanceName());
assertNull(m.getStartupID());
assertNull(m.getThreadID());
assertNull(m.getRequesterDN());
assertNull(m.getRequesterIPAddress());
assertNotNull(m.getConnectionID());
assertEquals(m.getConnectionID().longValue(), 28L);
assertNotNull(m.getOperationID());
assertEquals(m.getOperationID().longValue(), 1L);
assertNull(m.getTriggeredByConnectionID());
assertNull(m.getTriggeredByOperationID());
assertNull(m.getReplicationChangeID());
assertNotNull(m.getAlternateAuthorizationDN());
assertDNsEqual(m.getAlternateAuthorizationDN(), "cn=Directory Manager,cn=Root DNs,cn=config");
assertNull(m.getTransactionID());
assertNull(m.getOrigin());
assertNull(m.getUsingAdminSessionWorkerThread());
assertNull(m.getRequestControlOIDs());
assertNull(m.getOperationPurposeRequestControl());
assertNull(m.getIntermediateClientRequestControl());
assertNotNull(m.getDN());
assertDNsEqual(m.getDN(), "ou=People,dc=example,dc=com");
assertNotNull(m.getEntry());
assertNull(m.getIsUndelete());
assertNotNull(m.getChangeType());
assertEquals(m.getChangeType(), ChangeType.ADD);
assertNotNull(m.getChangeRecord());
assertTrue(m.getChangeRecord() instanceof LDIFAddChangeRecord);
assertTrue(m.isRevertible());
assertNotNull(m.getRevertChangeRecords());
assertFalse(m.getRevertChangeRecords().isEmpty());
assertEquals(m.getRevertChangeRecords().size(), 1);
assertTrue(m.getRevertChangeRecords().get(0) instanceof LDIFDeleteChangeRecord);
final LDIFDeleteChangeRecord revertChangeRecord = (LDIFDeleteChangeRecord) m.getRevertChangeRecords().get(0);
assertDNsEqual(revertChangeRecord.getDN(), "ou=People,dc=example,dc=com");
assertNotNull(revertChangeRecord.getControls());
assertTrue(revertChangeRecord.getControls().isEmpty());
assertNotNull(m.toString());
assertNotNull(m.toMultiLineString());
}
use of com.unboundid.ldif.LDIFDeleteChangeRecord in project ldapsdk by pingidentity.
the class AuditLogReaderTestCase method testBasicAuditLogFile.
/**
* Tests the behavior when trying to read the basic audit log file.
*
* @param reader The reader to use for testing.
* @param origin The origin of the provided reader.
*
* @throws Exception If an unexpected problem occurs.
*/
@Test(dataProvider = "basicAuditLogReaders")
public void testBasicAuditLogFile(final AuditLogReader reader, final String origin) throws Exception {
AuditLogMessage m = reader.read();
assertNotNull(m);
assertTrue(m instanceof AddAuditLogMessage);
final AddAuditLogMessage addMessage = (AddAuditLogMessage) m;
assertNotNull(addMessage.getLogMessageLines());
assertFalse(addMessage.getLogMessageLines().isEmpty());
assertNotNull(addMessage.getCommentedHeaderLine());
assertEquals(addMessage.getCommentedHeaderLine(), "# 23/Aug/2018:14:02:40 -0500; conn=28; op=1; " + "authzDN=\"cn=Directory Manager,cn=Root DNs,cn=config\"");
assertNotNull(addMessage.getUncommentedHeaderLine());
assertEquals(addMessage.getUncommentedHeaderLine(), "23/Aug/2018:14:02:40 -0500; conn=28; op=1; " + "authzDN=\"cn=Directory Manager,cn=Root DNs,cn=config\"");
assertNotNull(addMessage.getTimestamp());
final Calendar calendar = new GregorianCalendar();
calendar.setTime(addMessage.getTimestamp());
assertEquals(calendar.get(Calendar.YEAR), 2018);
assertEquals(calendar.get(Calendar.MONTH), Calendar.AUGUST);
assertNotNull(addMessage.getHeaderNamedValues());
assertFalse(addMessage.getHeaderNamedValues().isEmpty());
assertTrue(addMessage.getHeaderNamedValues().containsKey("conn"));
assertNull(addMessage.getProductName());
assertNull(addMessage.getInstanceName());
assertNull(addMessage.getStartupID());
assertNull(addMessage.getThreadID());
assertNull(addMessage.getRequesterDN());
assertNull(addMessage.getRequesterIPAddress());
assertNotNull(addMessage.getConnectionID());
assertEquals(addMessage.getConnectionID().longValue(), 28L);
assertNotNull(addMessage.getOperationID());
assertEquals(addMessage.getOperationID().longValue(), 1L);
assertNull(addMessage.getTriggeredByConnectionID());
assertNull(addMessage.getTriggeredByOperationID());
assertNull(addMessage.getReplicationChangeID());
assertNotNull(addMessage.getAlternateAuthorizationDN());
assertDNsEqual(addMessage.getAlternateAuthorizationDN(), "cn=Directory Manager,cn=Root DNs,cn=config");
assertNull(addMessage.getTransactionID());
assertNull(addMessage.getOrigin());
assertNull(addMessage.getUsingAdminSessionWorkerThread());
assertNull(addMessage.getRequestControlOIDs());
assertNull(addMessage.getOperationPurposeRequestControl());
assertNull(addMessage.getIntermediateClientRequestControl());
assertNotNull(addMessage.getDN());
assertDNsEqual(addMessage.getDN(), "ou=People,dc=example,dc=com");
assertNotNull(addMessage.getEntry());
assertNull(addMessage.getIsUndelete());
assertNotNull(addMessage.getChangeType());
assertEquals(addMessage.getChangeType(), ChangeType.ADD);
assertNotNull(addMessage.getChangeRecord());
assertTrue(addMessage.getChangeRecord() instanceof LDIFAddChangeRecord);
assertTrue(addMessage.isRevertible());
assertNotNull(addMessage.getRevertChangeRecords());
assertFalse(addMessage.getRevertChangeRecords().isEmpty());
assertEquals(addMessage.getRevertChangeRecords().size(), 1);
assertTrue(addMessage.getRevertChangeRecords().get(0) instanceof LDIFDeleteChangeRecord);
final LDIFDeleteChangeRecord revertDeleteChangeRecord = (LDIFDeleteChangeRecord) addMessage.getRevertChangeRecords().get(0);
assertDNsEqual(revertDeleteChangeRecord.getDN(), "ou=People,dc=example,dc=com");
assertNotNull(revertDeleteChangeRecord.getControls());
assertTrue(revertDeleteChangeRecord.getControls().isEmpty());
assertNotNull(addMessage.toString());
assertNotNull(addMessage.toMultiLineString());
m = reader.read();
assertNotNull(m);
assertTrue(m instanceof DeleteAuditLogMessage);
final DeleteAuditLogMessage deleteMessage = (DeleteAuditLogMessage) m;
assertNotNull(deleteMessage.getLogMessageLines());
assertFalse(deleteMessage.getLogMessageLines().isEmpty());
assertNotNull(deleteMessage.getCommentedHeaderLine());
assertEquals(deleteMessage.getCommentedHeaderLine(), "# 24/Aug/2018:12:11:50 -0500; conn=33; op=1; " + "authzDN=\"cn=Directory Manager,cn=Root DNs,cn=config\"");
assertNotNull(deleteMessage.getUncommentedHeaderLine());
assertEquals(deleteMessage.getUncommentedHeaderLine(), "24/Aug/2018:12:11:50 -0500; conn=33; op=1; " + "authzDN=\"cn=Directory Manager,cn=Root DNs,cn=config\"");
assertNotNull(deleteMessage.getTimestamp());
calendar.setTime(deleteMessage.getTimestamp());
assertEquals(calendar.get(Calendar.YEAR), 2018);
assertEquals(calendar.get(Calendar.MONTH), Calendar.AUGUST);
assertNotNull(deleteMessage.getHeaderNamedValues());
assertFalse(deleteMessage.getHeaderNamedValues().isEmpty());
assertTrue(deleteMessage.getHeaderNamedValues().containsKey("conn"));
assertNull(deleteMessage.getProductName());
assertNull(deleteMessage.getInstanceName());
assertNull(deleteMessage.getStartupID());
assertNull(deleteMessage.getThreadID());
assertNull(deleteMessage.getRequesterDN());
assertNull(deleteMessage.getRequesterIPAddress());
assertNotNull(deleteMessage.getConnectionID());
assertEquals(deleteMessage.getConnectionID().longValue(), 33L);
assertNotNull(deleteMessage.getOperationID());
assertEquals(deleteMessage.getOperationID().longValue(), 1L);
assertNull(deleteMessage.getTriggeredByConnectionID());
assertNull(deleteMessage.getTriggeredByOperationID());
assertNull(deleteMessage.getReplicationChangeID());
assertNotNull(deleteMessage.getAlternateAuthorizationDN());
assertDNsEqual(deleteMessage.getAlternateAuthorizationDN(), "cn=Directory Manager,cn=Root DNs,cn=config");
assertNull(deleteMessage.getTransactionID());
assertNull(deleteMessage.getOrigin());
assertNull(deleteMessage.getUsingAdminSessionWorkerThread());
assertNull(deleteMessage.getRequestControlOIDs());
assertNull(deleteMessage.getOperationPurposeRequestControl());
assertNull(deleteMessage.getIntermediateClientRequestControl());
assertNotNull(deleteMessage.getDN());
assertDNsEqual(deleteMessage.getDN(), "ou=People,dc=example,dc=com");
assertNull(deleteMessage.getIsSubtreeDelete());
assertNull(deleteMessage.getDeletedAsPartOfSubtreeDelete());
assertNull(deleteMessage.getIsSoftDelete());
assertNull(deleteMessage.getSoftDeletedEntryDN());
assertNull(deleteMessage.getIsSoftDeletedEntry());
assertNull(deleteMessage.getDeletedEntry());
assertNull(deleteMessage.getDeletedEntryVirtualAttributes());
assertNotNull(deleteMessage.getChangeType());
assertEquals(deleteMessage.getChangeType(), ChangeType.DELETE);
assertNotNull(deleteMessage.getChangeRecord());
assertTrue(deleteMessage.getChangeRecord() instanceof LDIFDeleteChangeRecord);
assertFalse(deleteMessage.isRevertible());
try {
deleteMessage.getRevertChangeRecords();
fail("Expected an exception when trying to revert a non-revertible " + "delete audit log message");
} catch (final AuditLogException e) {
// This was expected.
}
assertNotNull(deleteMessage.toString());
assertNotNull(deleteMessage.toMultiLineString());
m = reader.read();
assertNotNull(m);
assertTrue(m instanceof ModifyAuditLogMessage);
final ModifyAuditLogMessage modifyMessage = (ModifyAuditLogMessage) m;
assertNotNull(modifyMessage.getLogMessageLines());
assertFalse(modifyMessage.getLogMessageLines().isEmpty());
assertNotNull(modifyMessage.getCommentedHeaderLine());
assertTrue(modifyMessage.getCommentedHeaderLine().startsWith("# 27/Aug/2018:15:09:11.476 -0500; conn=18; op=1; "));
assertNotNull(modifyMessage.getUncommentedHeaderLine());
assertTrue(modifyMessage.getUncommentedHeaderLine().startsWith("27/Aug/2018:15:09:11.476 -0500; conn=18; op=1; "));
assertNotNull(modifyMessage.getTimestamp());
calendar.setTime(modifyMessage.getTimestamp());
assertEquals(calendar.get(Calendar.YEAR), 2018);
assertEquals(calendar.get(Calendar.MONTH), Calendar.AUGUST);
assertNotNull(modifyMessage.getHeaderNamedValues());
assertFalse(modifyMessage.getHeaderNamedValues().isEmpty());
assertTrue(modifyMessage.getHeaderNamedValues().containsKey("conn"));
assertNotNull(modifyMessage.getProductName());
assertEquals(modifyMessage.getProductName(), "Directory Server");
assertNotNull(modifyMessage.getInstanceName());
assertEquals(modifyMessage.getInstanceName(), "ReplicaOne");
assertNotNull(modifyMessage.getStartupID());
assertEquals(modifyMessage.getStartupID(), "W4RZ/w==");
assertNotNull(modifyMessage.getThreadID());
assertEquals(modifyMessage.getThreadID().longValue(), 7L);
assertNotNull(modifyMessage.getRequesterDN());
assertDNsEqual(modifyMessage.getRequesterDN(), "cn=Proxy User,cn=Root DNs,cn=config");
assertNotNull(modifyMessage.getRequesterIPAddress());
assertEquals(modifyMessage.getRequesterIPAddress(), "127.0.0.1");
assertNotNull(modifyMessage.getConnectionID());
assertEquals(modifyMessage.getConnectionID().longValue(), 18L);
assertNotNull(modifyMessage.getOperationID());
assertEquals(modifyMessage.getOperationID().longValue(), 1L);
assertNull(modifyMessage.getTriggeredByConnectionID());
assertNull(modifyMessage.getTriggeredByOperationID());
assertNotNull(modifyMessage.getReplicationChangeID());
assertEquals(modifyMessage.getReplicationChangeID(), "000001657D01242C7A0D00000004");
assertNotNull(modifyMessage.getAlternateAuthorizationDN());
assertDNsEqual(modifyMessage.getAlternateAuthorizationDN(), "cn=Directory Manager,cn=Root DNs,cn=config");
assertNull(modifyMessage.getTransactionID());
assertNull(modifyMessage.getOrigin());
assertNull(modifyMessage.getUsingAdminSessionWorkerThread());
assertNotNull(modifyMessage.getRequestControlOIDs());
assertEquals(modifyMessage.getRequestControlOIDs(), Collections.singletonList("1.3.6.1.4.1.30221.2.5.2"));
assertNull(modifyMessage.getOperationPurposeRequestControl());
assertNotNull(modifyMessage.getIntermediateClientRequestControl());
assertNotNull(modifyMessage.getDN());
assertDNsEqual(modifyMessage.getDN(), "uid=jdoe,ou=People,dc=example,dc=com");
assertNotNull(modifyMessage.getModifications());
assertFalse(modifyMessage.getModifications().isEmpty());
assertEquals(modifyMessage.getModifications(), Arrays.asList(new Modification(ModificationType.DELETE, "displayName", "Johnny Doe"), new Modification(ModificationType.ADD, "givenName", "Jonathan"), new Modification(ModificationType.DELETE, "description", "Initial description"), new Modification(ModificationType.ADD, "description", "Replaced description"), new Modification(ModificationType.INCREMENT, "intAttr1", "123"), new Modification(ModificationType.INCREMENT, "intAttr2", "-456"), new Modification(ModificationType.DELETE, "modifyTimestamp", "20180827200911.455Z"), new Modification(ModificationType.ADD, "modifyTimestamp", "20180827200911.470Z")));
assertNull(modifyMessage.getIsSoftDeletedEntry());
assertNotNull(modifyMessage.getChangeType());
assertEquals(modifyMessage.getChangeType(), ChangeType.MODIFY);
assertNotNull(modifyMessage.getChangeRecord());
assertTrue(modifyMessage.getChangeRecord() instanceof LDIFModifyChangeRecord);
assertTrue(modifyMessage.isRevertible());
List<LDIFChangeRecord> revertChangeRecords = modifyMessage.getRevertChangeRecords();
assertNotNull(revertChangeRecords);
assertFalse(revertChangeRecords.isEmpty());
assertEquals(revertChangeRecords.size(), 1);
assertTrue(revertChangeRecords.get(0) instanceof LDIFModifyChangeRecord);
final LDIFModifyChangeRecord revertModifyChangeRecord = (LDIFModifyChangeRecord) revertChangeRecords.get(0);
assertEquals(revertModifyChangeRecord.getModifications(), new Modification[] { new Modification(ModificationType.DELETE, "modifyTimestamp", "20180827200911.470Z"), new Modification(ModificationType.ADD, "modifyTimestamp", "20180827200911.455Z"), new Modification(ModificationType.INCREMENT, "intAttr2", "456"), new Modification(ModificationType.INCREMENT, "intAttr1", "-123"), new Modification(ModificationType.DELETE, "description", "Replaced description"), new Modification(ModificationType.ADD, "description", "Initial description"), new Modification(ModificationType.DELETE, "givenName", "Jonathan"), new Modification(ModificationType.ADD, "displayName", "Johnny Doe") });
assertNotNull(modifyMessage.toString());
assertNotNull(modifyMessage.toMultiLineString());
m = reader.read();
assertNotNull(m);
assertTrue(m instanceof ModifyDNAuditLogMessage);
final ModifyDNAuditLogMessage modifyDNMessage = (ModifyDNAuditLogMessage) m;
assertNotNull(modifyDNMessage.getLogMessageLines());
assertFalse(modifyDNMessage.getLogMessageLines().isEmpty());
assertNotNull(modifyDNMessage.getCommentedHeaderLine());
assertTrue(modifyDNMessage.getCommentedHeaderLine().startsWith("# 27/Aug/2018:16:33:47.019 -0500; conn=31; op=1; "));
assertNotNull(modifyDNMessage.getUncommentedHeaderLine());
assertTrue(modifyDNMessage.getUncommentedHeaderLine().startsWith("27/Aug/2018:16:33:47.019 -0500; conn=31; op=1; "));
assertNotNull(modifyDNMessage.getTimestamp());
calendar.setTime(modifyDNMessage.getTimestamp());
assertEquals(calendar.get(Calendar.YEAR), 2018);
assertEquals(calendar.get(Calendar.MONTH), Calendar.AUGUST);
assertNotNull(modifyDNMessage.getHeaderNamedValues());
assertFalse(modifyDNMessage.getHeaderNamedValues().isEmpty());
assertTrue(modifyDNMessage.getHeaderNamedValues().containsKey("conn"));
assertNotNull(modifyDNMessage.getProductName());
assertEquals(modifyDNMessage.getProductName(), "Directory Server");
assertNotNull(modifyDNMessage.getInstanceName());
assertEquals(modifyDNMessage.getInstanceName(), "ReplicaOne");
assertNotNull(modifyDNMessage.getStartupID());
assertEquals(modifyDNMessage.getStartupID(), "W4Rt1g==");
assertNotNull(modifyDNMessage.getThreadID());
assertEquals(modifyDNMessage.getThreadID().longValue(), 8L);
assertNotNull(modifyDNMessage.getRequesterDN());
assertDNsEqual(modifyDNMessage.getRequesterDN(), "cn=Proxy User,cn=Root DNs,cn=config");
assertNotNull(modifyDNMessage.getRequesterIPAddress());
assertEquals(modifyDNMessage.getRequesterIPAddress(), "127.0.0.1");
assertNotNull(modifyDNMessage.getConnectionID());
assertEquals(modifyDNMessage.getConnectionID().longValue(), 31L);
assertNotNull(modifyDNMessage.getOperationID());
assertEquals(modifyDNMessage.getOperationID().longValue(), 1L);
assertNull(modifyDNMessage.getTriggeredByConnectionID());
assertNull(modifyDNMessage.getTriggeredByOperationID());
assertNotNull(modifyDNMessage.getReplicationChangeID());
assertEquals(modifyDNMessage.getReplicationChangeID(), "000001657D4E9677214B00000005");
assertNotNull(modifyDNMessage.getAlternateAuthorizationDN());
assertDNsEqual(modifyDNMessage.getAlternateAuthorizationDN(), "cn=Directory Manager,cn=Root DNs,cn=config");
assertNull(modifyDNMessage.getTransactionID());
assertNull(modifyDNMessage.getOrigin());
assertNull(modifyDNMessage.getUsingAdminSessionWorkerThread());
assertNotNull(modifyDNMessage.getRequestControlOIDs());
assertEquals(modifyDNMessage.getRequestControlOIDs(), Collections.singletonList("1.3.6.1.4.1.30221.2.5.2"));
assertNull(modifyDNMessage.getOperationPurposeRequestControl());
assertNotNull(modifyDNMessage.getIntermediateClientRequestControl());
assertNotNull(modifyDNMessage.getDN());
assertDNsEqual(modifyDNMessage.getDN(), "uid=jdoe,ou=People,dc=example,dc=com");
assertNotNull(modifyDNMessage.getNewRDN());
assertDNsEqual(modifyDNMessage.getNewRDN(), "uid=john.doe");
assertTrue(modifyDNMessage.deleteOldRDN());
assertNull(modifyDNMessage.getNewSuperiorDN());
assertNotNull(modifyDNMessage.getAttributeModifications());
assertEquals(modifyDNMessage.getAttributeModifications(), Arrays.asList(new Modification(ModificationType.DELETE, "uid", "jdoe"), new Modification(ModificationType.ADD, "uid", "john.doe")));
assertNotNull(modifyDNMessage.getChangeType());
assertEquals(modifyDNMessage.getChangeType(), ChangeType.MODIFY_DN);
assertNotNull(modifyDNMessage.getChangeRecord());
assertTrue(modifyDNMessage.getChangeRecord() instanceof LDIFModifyDNChangeRecord);
assertTrue(modifyDNMessage.isRevertible());
revertChangeRecords = modifyDNMessage.getRevertChangeRecords();
assertNotNull(revertChangeRecords);
assertFalse(revertChangeRecords.isEmpty());
assertEquals(revertChangeRecords.size(), 1);
assertTrue(revertChangeRecords.get(0) instanceof LDIFModifyDNChangeRecord);
final LDIFModifyDNChangeRecord revertModifyDNChangeRecord = (LDIFModifyDNChangeRecord) revertChangeRecords.get(0);
assertDNsEqual(revertModifyDNChangeRecord.getDN(), "uid=john.doe,ou=People,dc=example,dc=com");
assertDNsEqual(revertModifyDNChangeRecord.getNewRDN(), "uid=jdoe");
assertTrue(revertModifyDNChangeRecord.deleteOldRDN());
assertNull(revertModifyDNChangeRecord.getNewSuperiorDN());
assertNotNull(modifyDNMessage.toString());
assertNotNull(modifyDNMessage.toMultiLineString());
try {
m = reader.read();
fail("Expected an exception when trying to read message " + m);
} catch (final AuditLogException e) {
// This was expected.
}
assertNull(reader.read());
reader.close();
}
Aggregations