Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

backport: Use try-with-resources to close BatchHandler #15704

Merged
merged 1 commit into from
Nov 15, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -176,30 +176,32 @@ private void populateTableInternal(AnalyticsTablePartition partition, String sql
List<String> columnNames =
getDimensionColumns().stream().map(AnalyticsTableColumn::getName).collect(toList());

MappingBatchHandler batchHandler =
try (MappingBatchHandler batchHandler =
MappingBatchHandler.builder()
.jdbcConfiguration(jdbcConfiguration)
.tableName(partition.getTempTableName())
.columns(columnNames)
.build();

batchHandler.init();

JdbcOwnershipWriter writer = JdbcOwnershipWriter.getInstance(batchHandler);
AtomicInteger queryRowCount = new AtomicInteger();

jdbcTemplate.query(
sql,
resultSet -> {
writer.write(getRowMap(columnNames, resultSet));
queryRowCount.getAndIncrement();
});

log.info(
"OwnershipAnalytics query row count was {} for {}",
queryRowCount,
partition.getTempTableName());
batchHandler.flush();
.build()) {
batchHandler.init();

JdbcOwnershipWriter writer = JdbcOwnershipWriter.getInstance(batchHandler);
AtomicInteger queryRowCount = new AtomicInteger();

jdbcTemplate.query(
sql,
resultSet -> {
writer.write(getRowMap(columnNames, resultSet));
queryRowCount.getAndIncrement();
});

log.info(
"OwnershipAnalytics query row count was {} for {}",
queryRowCount,
partition.getTempTableName());
batchHandler.flush();
} catch (Exception ex) {
log.error("Failed to alter table ownership: ", ex);
}
}

private String getInputSql(Program program) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -244,9 +244,9 @@ public ImportSummary saveCompleteDataSetRegistrationsJson(
private ImportSummary saveCompleteDataSetRegistrations(
ImportOptions importOptions,
Callable<CompleteDataSetRegistrations> deserializeRegistrations) {
BatchHandler<CompleteDataSetRegistration> batchHandler =
batchHandlerFactory.createBatchHandler(CompleteDataSetRegistrationBatchHandler.class);
try {

try (BatchHandler<CompleteDataSetRegistration> batchHandler =
batchHandlerFactory.createBatchHandler(CompleteDataSetRegistrationBatchHandler.class)) {
CompleteDataSetRegistrations completeDataSetRegistrations = deserializeRegistrations.call();
ImportSummary summary =
saveCompleteDataSetRegistrations(
Expand All @@ -256,7 +256,7 @@ private ImportSummary saveCompleteDataSetRegistrations(

return summary;
} catch (Exception ex) {
batchHandler.flush();
log.error("Complete data set registrations could not be saved.");
return handleImportError(ex);
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -623,14 +623,13 @@ private ImportSummary importDataValueSet(
ImportOptions options, JobConfiguration id, Callable<DataValueSetReader> createReader) {
options = ObjectUtils.firstNonNull(options, ImportOptions.getDefaultImportOptions());

BatchHandler<DataValue> dvBatch =
batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class);
BatchHandler<DataValueAudit> dvaBatch =
batchHandlerFactory.createBatchHandler(DataValueAuditBatchHandler.class);

notifier.clear(id);

try (DataValueSetReader reader = createReader.call()) {
try (BatchHandler<DataValue> dvBatch =
batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class);
BatchHandler<DataValueAudit> dvaBatch =
batchHandlerFactory.createBatchHandler(DataValueAuditBatchHandler.class);
DataValueSetReader reader = createReader.call()) {
ImportSummary summary = importDataValueSet(options, id, reader, dvBatch, dvaBatch);

dvBatch.flush();
Expand All @@ -643,8 +642,6 @@ private ImportSummary importDataValueSet(

return summary;
} catch (Exception ex) {
dvBatch.flush();
dvaBatch.flush();
log.error(DebugUtils.getStackTrace(ex));
notifier.notify(id, ERROR, "Process failed: " + ex.getMessage(), true);
return new ImportSummary(ImportStatus.ERROR, "The import process failed: " + ex.getMessage());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,11 +92,11 @@ class CompleteDataSetRegistrationBatchHandlerTest extends IntegrationTestBase {

private CompleteDataSetRegistration regD;

private Date now = new Date();
private final Date now = new Date();

private String storedBy = "johndoe";
private final String storedBy = "johndoe";

private String lastUpdatedBy = "johndoe";
private final String lastUpdatedBy = "johndoe";

// -------------------------------------------------------------------------
// Fixture
Expand Down Expand Up @@ -165,9 +165,7 @@ public void setUpTest() {
}

@Override
public void tearDownTest() {
batchHandler.flush();
}
public void tearDownTest() {}

// -------------------------------------------------------------------------
// Tests
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,6 @@ class DataValueAuditBatchHandlerTest extends SingleSetupIntegrationTestBase {

@Autowired private CategoryService categoryService;

private BatchHandler<DataValueAudit> batchHandler;

private DataElement dataElementA;

private CategoryOptionCombo categoryOptionComboA;
Expand Down Expand Up @@ -107,7 +105,7 @@ class DataValueAuditBatchHandlerTest extends SingleSetupIntegrationTestBase {
// -------------------------------------------------------------------------
@Override
public void setUpTest() {
batchHandler = batchHandlerFactory.createBatchHandler(DataValueAuditBatchHandler.class);

dataElementA = createDataElement('A');
dataElementService.addDataElement(dataElementA);
categoryOptionComboA = categoryService.getDefaultCategoryOptionCombo();
Expand All @@ -132,19 +130,18 @@ public void setUpTest() {
auditB = new DataValueAudit(dataValueA, "12", storedBy, AuditType.UPDATE);
auditC = new DataValueAudit(dataValueB, "21", storedBy, AuditType.UPDATE);
auditD = new DataValueAudit(dataValueB, "22", storedBy, AuditType.UPDATE);
batchHandler.init();
}

@Override
public void tearDownTest() {
batchHandler.flush();
}
public void tearDownTest() {}

// -------------------------------------------------------------------------
// Tests
// -------------------------------------------------------------------------
@Test
void testAddObject() {
BatchHandler<DataValueAudit> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueAuditBatchHandler.class).init();
batchHandler.addObject(auditA);
batchHandler.addObject(auditB);
batchHandler.addObject(auditC);
Expand All @@ -161,6 +158,8 @@ void testAddObject() {
/** DataValueAudit can never equal another. */
@Test
void testObjectExists() {
BatchHandler<DataValueAudit> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueAuditBatchHandler.class).init();
auditService.addDataValueAudit(auditA);
auditService.addDataValueAudit(auditB);
assertFalse(batchHandler.objectExists(auditA));
Expand All @@ -171,6 +170,8 @@ void testObjectExists() {

@Test
void testUpdateObject() {
BatchHandler<DataValueAudit> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueAuditBatchHandler.class).init();
auditService.addDataValueAudit(auditA);
auditA.setModifiedBy("bill");
batchHandler.updateObject(auditA);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,6 @@ class DataValueBatchHandlerTest extends IntegrationTestBase {

@Autowired private CategoryService categoryService;

private BatchHandler<DataValue> batchHandler;

private DataElement dataElementA;

private CategoryOptionCombo categoryOptionComboA;
Expand Down Expand Up @@ -105,7 +103,7 @@ class DataValueBatchHandlerTest extends IntegrationTestBase {
// -------------------------------------------------------------------------
@Override
public void setUpTest() {
batchHandler = batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class);

dataElementA = createDataElement('A');
dataElementService.addDataElement(dataElementA);
categoryOptionComboA = categoryService.getDefaultCategoryOptionCombo();
Expand Down Expand Up @@ -142,19 +140,19 @@ public void setUpTest() {
dataElementA, periodB, unitB, categoryOptionComboA, categoryOptionComboA, "15");
// with
// 4th
batchHandler.init();

}

@Override
public void tearDownTest() {
batchHandler.flush();
}
public void tearDownTest() {}

// -------------------------------------------------------------------------
// Tests
// -------------------------------------------------------------------------
@Test
void testInsertObject() {
BatchHandler<DataValue> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class).init();
batchHandler.insertObject(dataValueA);
DataValue dataValue =
dataValueService.getDataValue(
Expand All @@ -164,6 +162,8 @@ void testInsertObject() {

@Test
void testAddObject() {
BatchHandler<DataValue> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class).init();
batchHandler.addObject(dataValueA);
batchHandler.addObject(dataValueB);
batchHandler.addObject(dataValueC);
Expand All @@ -185,6 +185,8 @@ void testAddObject() {

@Test
void testAddObjectDuplicates() {
BatchHandler<DataValue> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class).init();
batchHandler.addObject(dataValueA);
batchHandler.addObject(dataValueB);
batchHandler.addObject(dataValueC);
Expand All @@ -208,6 +210,8 @@ void testAddObjectDuplicates() {

@Test
void testFindObject() {
BatchHandler<DataValue> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class).init();
dataValueService.addDataValue(dataValueA);
dataValueService.addDataValue(dataValueC);
DataValue retrievedDataValueA = batchHandler.findObject(dataValueA);
Expand All @@ -224,6 +228,8 @@ void testFindObject() {

@Test
void testObjectExists() {
BatchHandler<DataValue> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class).init();
dataValueService.addDataValue(dataValueA);
dataValueService.addDataValue(dataValueC);
assertTrue(batchHandler.objectExists(dataValueA));
Expand All @@ -235,6 +241,8 @@ void testObjectExists() {
@Test
@Disabled("ERROR: cannot execute UPDATE in a read-only transaction")
void testUpdateObject() {
BatchHandler<DataValue> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class).init();
dataValueService.addDataValue(dataValueA);
dataValueA.setValue("20");
batchHandler.updateObject(dataValueA);
Expand All @@ -247,6 +255,8 @@ void testUpdateObject() {

@Test
void testDeleteObject() {
BatchHandler<DataValue> batchHandler;
batchHandler = batchHandlerFactory.createBatchHandler(DataValueBatchHandler.class).init();
dataValueService.addDataValue(dataValueA);
dataValueService.addDataValue(dataValueC);
assertTrue(batchHandler.objectExists(dataValueA));
Expand Down
2 changes: 1 addition & 1 deletion dhis-2/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@
<dhis2-rule-engine.version>2.1.8.0</dhis2-rule-engine.version>

<!-- HISP Quick and Staxwax -->
<dhis-hisp-quick.version>1.4.1</dhis-hisp-quick.version>
<dhis-hisp-quick.version>1.4.3</dhis-hisp-quick.version>
<dhis-hisp-staxwax.version>2.0.0</dhis-hisp-staxwax.version>
<dhis-json-tree.version>0.5.0</dhis-json-tree.version>

Expand Down