Schema migrator returns status (#4937)

* Migrator should return status

* Cleanup

* Add changelog

* Delete unused

* Test fix
This commit is contained in:
James Agnew 2023-05-24 19:31:39 -04:00 committed by GitHub
parent c98c4a4dca
commit a04a49cb68
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 44 additions and 70 deletions

View File

@ -0,0 +1,5 @@
---
type: add
issue: 4937
title: "The SQL schema migrator now returns a status flag indicating whether the schema was initialized
or not."

View File

@ -1,63 +0,0 @@
package ca.uhn.fhir.jpa.searchparam;
import ca.uhn.fhir.context.FhirContext;
import ca.uhn.fhir.context.support.IValidationSupport;
import ca.uhn.fhir.jpa.model.config.PartitionSettings;
import ca.uhn.fhir.jpa.model.entity.StorageSettings;
import ca.uhn.fhir.jpa.model.entity.ResourceIndexedSearchParamString;
import ca.uhn.fhir.jpa.searchparam.extractor.SearchParamExtractorDstu3;
import ca.uhn.fhir.rest.server.util.ISearchParamRegistry;
import ca.uhn.fhir.rest.server.util.ResourceSearchParams;
import ca.uhn.fhir.util.StopWatch;
import org.hl7.fhir.dstu3.model.Patient;
import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Set;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.mockito.ArgumentMatchers.eq;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
public class IndexStressTest {
private static final Logger ourLog = LoggerFactory.getLogger(IndexStressTest.class);
@Test
public void testExtractSearchParams() {
Patient p = new Patient();
p.addName().setFamily("FOO").addGiven("BAR").addGiven("BAR");
p.getMaritalStatus().setText("DDDDD");
p.addAddress().addLine("A").addLine("B").addLine("C");
FhirContext ctx = FhirContext.forDstu3();
IValidationSupport mockValidationSupport = mock(IValidationSupport.class);
when(mockValidationSupport.getFhirContext()).thenReturn(ctx);
ISearchParamRegistry searchParamRegistry = mock(ISearchParamRegistry.class);
SearchParamExtractorDstu3 extractor = new SearchParamExtractorDstu3(new StorageSettings(), new PartitionSettings(), ctx, searchParamRegistry);
extractor.start();
ResourceSearchParams resourceSearchParams = new ResourceSearchParams("Patient");
ctx.getResourceDefinition("Patient")
.getSearchParams()
.forEach(t -> resourceSearchParams.put(t.getName(), t));
when(searchParamRegistry.getActiveSearchParams(eq("Patient"))).thenReturn(resourceSearchParams);
Set<ResourceIndexedSearchParamString> params = extractor.extractSearchParamStrings(p);
StopWatch sw = new StopWatch();
int loops = 100;
for (int i = 0; i < loops; i++) {
params = extractor.extractSearchParamStrings(p);
}
ourLog.info("Indexed {} times in {}ms/time", loops, sw.getMillisPerOperation(loops));
assertEquals(9, params.size());
verify(mockValidationSupport, times(1)).fetchAllStructureDefinitions();
}
}

View File

@ -9,7 +9,10 @@ import ca.uhn.fhir.jpa.migrate.dao.HapiMigrationDao;
import ca.uhn.fhir.jpa.migrate.tasks.HapiFhirJpaMigrationTasks; import ca.uhn.fhir.jpa.migrate.tasks.HapiFhirJpaMigrationTasks;
import ca.uhn.fhir.system.HapiSystemProperties; import ca.uhn.fhir.system.HapiSystemProperties;
import ca.uhn.fhir.util.VersionEnum; import ca.uhn.fhir.util.VersionEnum;
import org.apache.commons.dbcp2.BasicDataSource;
import org.h2.jdbcx.JdbcDataSource;
import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.extension.RegisterExtension;
import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.ArgumentsSource; import org.junit.jupiter.params.provider.ArgumentsSource;
@ -17,11 +20,14 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import javax.sql.DataSource; import javax.sql.DataSource;
import java.sql.SQLException;
import java.util.Collections; import java.util.Collections;
import java.util.Properties; import java.util.Properties;
import static ca.uhn.fhir.jpa.embedded.HapiEmbeddedDatabasesExtension.FIRST_TESTED_VERSION; import static ca.uhn.fhir.jpa.embedded.HapiEmbeddedDatabasesExtension.FIRST_TESTED_VERSION;
import static ca.uhn.fhir.jpa.migrate.SchemaMigrator.HAPI_FHIR_MIGRATION_TABLENAME; import static ca.uhn.fhir.jpa.migrate.SchemaMigrator.HAPI_FHIR_MIGRATION_TABLENAME;
import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.jupiter.api.Assertions.assertTrue;
public class HapiSchemaMigrationTest { public class HapiSchemaMigrationTest {
@ -61,10 +67,34 @@ public class HapiSchemaMigrationTest {
int lastVersion = allVersions.length - 1; int lastVersion = allVersions.length - 1;
VersionEnum to = allVersions[lastVersion]; VersionEnum to = allVersions[lastVersion];
MigrationTaskList migrationTasks = new HapiFhirJpaMigrationTasks(Collections.EMPTY_SET).getTaskList(from, to); MigrationTaskList migrationTasks = new HapiFhirJpaMigrationTasks(Collections.emptySet()).getTaskList(from, to);
SchemaMigrator schemaMigrator = new SchemaMigrator(TEST_SCHEMA_NAME, HAPI_FHIR_MIGRATION_TABLENAME, dataSource, new Properties(), migrationTasks, hapiMigrationStorageSvc); SchemaMigrator schemaMigrator = new SchemaMigrator(TEST_SCHEMA_NAME, HAPI_FHIR_MIGRATION_TABLENAME, dataSource, new Properties(), migrationTasks, hapiMigrationStorageSvc);
schemaMigrator.setDriverType(theDriverType); schemaMigrator.setDriverType(theDriverType);
schemaMigrator.createMigrationTableIfRequired(); schemaMigrator.createMigrationTableIfRequired();
schemaMigrator.migrate(); schemaMigrator.migrate();
} }
@Test
public void testCreateMigrationTableIfRequired() throws SQLException {
// Setup
BasicDataSource dataSource = new BasicDataSource();
dataSource.setUrl("jdbc:h2:mem:no-tables");
dataSource.setUsername("SA");
dataSource.setPassword("SA");
dataSource.start();
MigrationTaskList migrationTasks = new HapiFhirJpaMigrationTasks(Collections.emptySet()).getTaskList(VersionEnum.V6_0_0, VersionEnum.V6_4_0);
HapiMigrationDao hapiMigrationDao = new HapiMigrationDao(dataSource, DriverTypeEnum.H2_EMBEDDED, HAPI_FHIR_MIGRATION_TABLENAME);
HapiMigrationStorageSvc hapiMigrationStorageSvc = new HapiMigrationStorageSvc(hapiMigrationDao);
SchemaMigrator schemaMigrator = new SchemaMigrator(TEST_SCHEMA_NAME, HAPI_FHIR_MIGRATION_TABLENAME, dataSource, new Properties(), migrationTasks, hapiMigrationStorageSvc);
schemaMigrator.setDriverType(DriverTypeEnum.H2_EMBEDDED);
// Test & Validate
assertTrue(schemaMigrator.createMigrationTableIfRequired());
assertFalse(schemaMigrator.createMigrationTableIfRequired());
assertFalse(schemaMigrator.createMigrationTableIfRequired());
}
} }

View File

@ -88,8 +88,8 @@ public class HapiMigrationStorageSvc {
* Create the migration table if it does not already exist * Create the migration table if it does not already exist
*/ */
public void createMigrationTableIfRequired() { public boolean createMigrationTableIfRequired() {
myHapiMigrationDao.createMigrationTableIfRequired(); return myHapiMigrationDao.createMigrationTableIfRequired();
} }

View File

@ -111,7 +111,7 @@ public class SchemaMigrator {
myCallbacks = theCallbacks; myCallbacks = theCallbacks;
} }
public void createMigrationTableIfRequired() { public boolean createMigrationTableIfRequired() {
myHapiMigrationStorageSvc.createMigrationTableIfRequired(); return myHapiMigrationStorageSvc.createMigrationTableIfRequired();
} }
} }

View File

@ -104,9 +104,9 @@ public class HapiMigrationDao {
return myJdbcTemplate.queryForObject(highestKeyQuery, Integer.class); return myJdbcTemplate.queryForObject(highestKeyQuery, Integer.class);
} }
public void createMigrationTableIfRequired() { public boolean createMigrationTableIfRequired() {
if (migrationTableExists()) { if (migrationTableExists()) {
return; return false;
} }
ourLog.info("Creating table {}", myMigrationTablename); ourLog.info("Creating table {}", myMigrationTablename);
@ -120,6 +120,8 @@ public class HapiMigrationDao {
HapiMigrationEntity entity = HapiMigrationEntity.tableCreatedRecord(); HapiMigrationEntity entity = HapiMigrationEntity.tableCreatedRecord();
myJdbcTemplate.update(myMigrationQueryBuilder.insertPreparedStatement(), entity.asPreparedStatementSetter()); myJdbcTemplate.update(myMigrationQueryBuilder.insertPreparedStatement(), entity.asPreparedStatementSetter());
return true;
} }
private boolean migrationTableExists() { private boolean migrationTableExists() {