Fix sort in hsearch - use full millis (#3787)
Fix sort in hsearch - use full millis
This commit is contained in:
parent
1785c07283
commit
94a1cda512
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
type: fix
|
||||
issue: 3787
|
||||
title: "FHIR queries using date sort were ignoring seconds and milliseconds when using lucene/elasticsearch SearchParameter indexing.
|
||||
This has been corrected."
|
|
@ -59,7 +59,7 @@ public class HSearchSortHelperImpl implements IHSearchSortHelper {
|
|||
String.join(".", NESTED_SEARCH_PARAM_ROOT, "*", "token", "system"),
|
||||
String.join(".", NESTED_SEARCH_PARAM_ROOT, "*", "token", "code") ),
|
||||
RestSearchParameterTypeEnum.REFERENCE, List.of(SEARCH_PARAM_ROOT + ".*.reference.value"),
|
||||
RestSearchParameterTypeEnum.DATE, List.of(SEARCH_PARAM_ROOT + ".*.dt.lower-ord"),
|
||||
RestSearchParameterTypeEnum.DATE, List.of(SEARCH_PARAM_ROOT + ".*.dt.lower"),
|
||||
RestSearchParameterTypeEnum.QUANTITY, List.of(
|
||||
String.join(".", NESTED_SEARCH_PARAM_ROOT, "*", QTY_PARAM_NAME, QTY_VALUE_NORM),
|
||||
String.join(".", NESTED_SEARCH_PARAM_ROOT, "*", QTY_PARAM_NAME, QTY_VALUE) ),
|
||||
|
|
|
@ -145,7 +145,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
|||
DependencyInjectionTestExecutionListener.class
|
||||
,FhirResourceDaoR4SearchWithElasticSearchIT.TestDirtiesContextTestExecutionListener.class
|
||||
})
|
||||
public class FhirResourceDaoR4SearchWithElasticSearchIT extends BaseJpaTest {
|
||||
public class FhirResourceDaoR4SearchWithElasticSearchIT extends BaseJpaTest implements ITestDataBuilder {
|
||||
public static final String URL_MY_CODE_SYSTEM = "http://example.com/my_code_system";
|
||||
public static final String URL_MY_VALUE_SET = "http://example.com/my_value_set";
|
||||
private static final org.slf4j.Logger ourLog = org.slf4j.LoggerFactory.getLogger(FhirResourceDaoR4SearchWithElasticSearchIT.class);
|
||||
|
@ -229,7 +229,17 @@ public class FhirResourceDaoR4SearchWithElasticSearchIT extends BaseJpaTest {
|
|||
}
|
||||
|
||||
@Override
|
||||
protected FhirContext getFhirContext() {
|
||||
public IIdType doCreateResource(IBaseResource theResource) {
|
||||
return myTestDataBuilder.doCreateResource(theResource);
|
||||
}
|
||||
|
||||
@Override
|
||||
public IIdType doUpdateResource(IBaseResource theResource) {
|
||||
return myTestDataBuilder.doUpdateResource(theResource);
|
||||
}
|
||||
|
||||
@Override
|
||||
public FhirContext getFhirContext() {
|
||||
return myFhirCtx;
|
||||
}
|
||||
|
||||
|
@ -1944,19 +1954,19 @@ public class FhirResourceDaoR4SearchWithElasticSearchIT extends BaseJpaTest {
|
|||
|
||||
@Test
|
||||
public void byDate() {
|
||||
String id1 = myTestDataBuilder.createObservation(List.of(
|
||||
myTestDataBuilder.withEffectiveDate("2017-01-20T03:21:47")
|
||||
)).getIdPart();
|
||||
String id2 = myTestDataBuilder.createObservation(List.of(
|
||||
myTestDataBuilder.withEffectiveDate("2017-01-24T03:21:47")
|
||||
)).getIdPart();
|
||||
// check milli level precision
|
||||
String id1 = createObservation(withId("20-000"), withEffectiveDate("2017-01-20T03:21:47.000")).getIdPart();
|
||||
String id2 = createObservation(withId("24-002"), withEffectiveDate("2017-01-24T03:21:47.002")).getIdPart();
|
||||
String id3 = createObservation(withId("24-001"), withEffectiveDate("2017-01-24T03:21:47.001")).getIdPart();
|
||||
String id4 = createObservation(withId("20-002"), withEffectiveDate("2017-01-20T03:21:47.002")).getIdPart();
|
||||
|
||||
myCaptureQueriesListener.clear();
|
||||
IBundleProvider result = myTestDaoSearch.searchForBundleProvider("/Observation?_sort=-date");
|
||||
List<String> result = myTestDaoSearch.searchForIds("/Observation?_sort=-date");
|
||||
|
||||
assertEquals(0, myCaptureQueriesListener.getSelectQueriesForCurrentThread().size(), "we build the bundle with no sql");
|
||||
// requesteddate descending so order should be id2, id1
|
||||
assertThat(getResultIds(result), contains(id2, id1));
|
||||
ourLog.info("byDate sort {}", result);
|
||||
// date descending - order should be id2, id1
|
||||
assertThat(result, contains(id2, id3, id4, id1));
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -1,8 +1,5 @@
|
|||
<configuration>
|
||||
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
|
||||
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
|
||||
<level>INFO</level>
|
||||
</filter>
|
||||
<encoder>
|
||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} [%file:%line] %msg%n</pattern>
|
||||
</encoder>
|
||||
|
@ -27,10 +24,6 @@
|
|||
<appender-ref ref="STDOUT" />
|
||||
</logger>
|
||||
|
||||
<logger name="org.elasticsearch.client" additivity="true" level="trace">
|
||||
<appender-ref ref="STDOUT" />
|
||||
</logger>
|
||||
|
||||
<logger name="org.eclipse" additivity="false" level="error">
|
||||
</logger>
|
||||
|
||||
|
@ -43,7 +36,7 @@
|
|||
</logger>
|
||||
|
||||
<!-- set to debug to enable term expansion logs -->
|
||||
<logger name="ca.uhn.fhir.jpa.term" additivity="false" level="debug">
|
||||
<logger name="ca.uhn.fhir.jpa.term" additivity="false" level="info">
|
||||
<appender-ref ref="STDOUT" />
|
||||
</logger>
|
||||
|
||||
|
@ -56,15 +49,17 @@
|
|||
<appender-ref ref="STDOUT" />
|
||||
</logger>
|
||||
|
||||
<logger name="org.hibernate.search.elasticsearch.request" additivity="false" level="trace">
|
||||
<appender-ref ref="STDOUT" />
|
||||
</logger>
|
||||
<!--
|
||||
<logger name="ca.uhn.fhir.jpa.model.search" additivity="false" level="debug">
|
||||
<appender-ref ref="STDOUT" />
|
||||
</logger>
|
||||
-->
|
||||
<logger name="org.springframework.test.context.cache" additivity="false" level="debug">
|
||||
<logger name="ca.uhn.fhir.jpa.model.search" additivity="false" level="debug"/>
|
||||
<logger name="org.elasticsearch.client" additivity="true" level="trace"/>
|
||||
<logger name="org.hibernate.search.elasticsearch.request" additivity="false" level="trace"/>
|
||||
<logger name="org.hibernate.search" level="TRACE"/>
|
||||
<logger name="org.hibernate.search.query" level="TRACE"/>
|
||||
<logger name="org.hibernate.search.elasticsearch.request" level="TRACE"/>
|
||||
-->
|
||||
<!-- See https://docs.jboss.org/hibernate/stable/search/reference/en-US/html_single/#backend-lucene-io-writer-infostream for lucene logging
|
||||
<logger name="org.hibernate.search.backend.lucene.infostream" level="TRACE"/> -->
|
||||
<logger name="org.springframework.test.context.cache" additivity="false" level="info">
|
||||
<appender-ref ref="STDOUT" />
|
||||
</logger>
|
||||
|
||||
|
|
|
@ -37,6 +37,12 @@ import org.springframework.beans.factory.annotation.Autowired;
|
|||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
|
||||
/**
|
||||
* Implements ITestDataBuilder via a live DaoRegistry.
|
||||
*
|
||||
* Add the inner {@link Config} to your spring context to inject this.
|
||||
* For convenience, you can still implement ITestDataBuilder on your test class, and delegate the missing methods to this bean.
|
||||
*/
|
||||
public class DaoTestDataBuilder implements ITestDataBuilder, AfterEachCallback {
|
||||
private static final Logger ourLog = LoggerFactory.getLogger(DaoTestDataBuilder.class);
|
||||
|
||||
|
@ -84,6 +90,7 @@ public class DaoTestDataBuilder implements ITestDataBuilder, AfterEachCallback {
|
|||
ourLog.info("cleanup {}", myIds);
|
||||
|
||||
myIds.keySet().forEach(nextType->{
|
||||
// todo do this in a bundle for perf.
|
||||
IFhirResourceDao<?> dao = myDaoRegistry.getResourceDao(nextType);
|
||||
myIds.get(nextType).forEach(dao::delete);
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue