@Override public RangePredicateContext range() { return delegate.range(); }
@Override public RangePredicateContext range() { return delegate.range(); }
@Test public void rangeQueryAbove() { SearchQuery<DocumentReference> query = rangeQuery( f -> f.range().onField( FIELD_PATH ).above( Boolean.TRUE ).toPredicate() ); assertHasHitsWithBooleanProperties( query, Boolean.TRUE, Boolean.TRUE ); }
@Test public void rangeQueryBelow() { SearchQuery<DocumentReference> query = rangeQuery( f -> f.range().onField( FIELD_PATH ).below( Boolean.FALSE ).toPredicate() ); assertHasHitsWithBooleanProperties( query, Boolean.FALSE, Boolean.FALSE ); }
@Test public void rangeQueryFromTo() { SearchQuery<DocumentReference> query = rangeQuery( f -> f.range().onField( FIELD_PATH ).from( Boolean.FALSE ).to( Boolean.FALSE ).toPredicate() ); assertHasHitsWithBooleanProperties( query, Boolean.FALSE, Boolean.FALSE ); }
() -> searchTarget.predicate().range().onField( "unknown_field" ) () -> searchTarget.predicate().range().onFields( indexMapping.string1Field.relativeFieldName, "unknown_field" ) () -> searchTarget.predicate().range().onField( indexMapping.string1Field.relativeFieldName ).orField( "unknown_field" ) () -> searchTarget.predicate().range().onField( indexMapping.string1Field.relativeFieldName ).orFields( "unknown_field" )
@Test public void unsupported_field_types() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.unsupportedFieldModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; SubTest.expectException( "range() predicate with unsupported type on field " + absoluteFieldPath, () -> searchTarget.predicate().range().onField( absoluteFieldPath ) ) .assertThrown() .isInstanceOf( SearchException.class ) .hasMessageContaining( "Range predicates are not supported by" ) .satisfies( FailureReportUtils.hasContext( EventContexts.fromIndexFieldAbsolutePath( absoluteFieldPath ) ) ); } }
SubTest.expectException( "range() predicate with null bounds on field " + fieldPath, () -> searchTarget.predicate().range().onField( fieldPath ).from( null ).to( null ) () -> searchTarget.predicate().range().onField( fieldPath ).above( null ) () -> searchTarget.predicate().range().onField( fieldPath ).below( null )
@Test public void above() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.supportedFieldModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; Object lowerValueToMatch = fieldModel.predicateLowerBound; SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).above( lowerValueToMatch ).toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_2, DOCUMENT_3 ); } }
@Test public void below() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.supportedFieldModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; Object upperValueToMatch = fieldModel.predicateUpperBound; SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).below( upperValueToMatch ).toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_1, DOCUMENT_2 ); } }
@Test public void below_withDslConverter() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.supportedFieldWithDslConverterModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; Object upperValueToMatch = new ValueWrapper<>( fieldModel.predicateUpperBound ); SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).below( upperValueToMatch ).toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_1, DOCUMENT_2 ); } }
@Test public void above_withDslConverter() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.supportedFieldWithDslConverterModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; Object lowerValueToMatch = new ValueWrapper<>( fieldModel.predicateLowerBound ); SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).above( lowerValueToMatch ).toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_2, DOCUMENT_3 ); } }
@Test public void above_include_exclude() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.supportedFieldModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; Object lowerValueToMatch = fieldModel.document2Value.indexedValue; // Default is inclusion SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).above( lowerValueToMatch ).toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_2, DOCUMENT_3 ); // explicit exclusion query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).above( lowerValueToMatch ).excludeLimit().toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_3 ); } }
.asReference() .predicate( f -> f.bool() .must( f.range().onField( "flattenedObject.string" ) .from( MATCHING_STRING ).to( MATCHING_STRING ) .must( f.range().onField( "flattenedObject.integer" ) .from( MATCHING_INTEGER - 1 ).to( MATCHING_INTEGER + 1 ) .must( f.range().onField( "flattenedObject.localDate" ) .from( MATCHING_LOCAL_DATE.minusDays( 1 ) ).to( MATCHING_LOCAL_DATE.plusDays( 1 ) ) .predicate( f -> f.nested().onObjectField( "nestedObject" ) .nest( f.bool() .must( f.range().onField( "nestedObject.string" ) .from( MATCHING_STRING ).to( MATCHING_STRING ) .must( f.range().onField( "nestedObject.integer" ) .from( MATCHING_INTEGER - 1 ).to( MATCHING_INTEGER + 1 ) .must( f.range().onField( "nestedObject.localDate" ) .from( MATCHING_LOCAL_DATE.minusDays( 1 ) ) .to( MATCHING_LOCAL_DATE.plusDays( 1 ) )
@Test public void fromTo() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.supportedFieldModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; Object lowerValueToMatch = fieldModel.predicateLowerBound; Object upperValueToMatch = fieldModel.predicateUpperBound; SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).from( lowerValueToMatch ).to( upperValueToMatch ).toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_2 ); } }
@Test public void below_include_exclude() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.supportedFieldModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; Object upperValueToMatch = fieldModel.document2Value.indexedValue; // Default is inclusion SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).below( upperValueToMatch ).toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_1, DOCUMENT_2 ); // explicit exclusion query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).below( upperValueToMatch ).excludeLimit().toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_1 ); } }
@Test public void rangeFromToSortByFieldQuery() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( FIELD_PATH ).from( Boolean.FALSE ).to( Boolean.TRUE ).toPredicate() ) .sort( c -> c.byField( FIELD_PATH ).onMissingValue().sortLast() ) .build(); assertHasHitsWithBooleanProperties( query, Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, Boolean.TRUE ); }
.asReference() .predicate( root -> root.bool() .should( c -> c.range().onField( indexMapping.string1Field.relativeFieldName ) .above( indexMapping.string1Field.document3Value.indexedValue ).toPredicate() .should( c -> c.range().onField( indexMapping.string1Field.relativeFieldName ).boostedTo( 42 ) .below( indexMapping.string1Field.document1Value.indexedValue ).toPredicate() .asReference() .predicate( root -> root.bool() .should( c -> c.range().onField( indexMapping.string1Field.relativeFieldName ).boostedTo( 42 ) .above( indexMapping.string1Field.document3Value.indexedValue ).toPredicate() .should( c -> c.range().onField( indexMapping.string1Field.relativeFieldName ) .below( indexMapping.string1Field.document1Value.indexedValue ).toPredicate()
@Test public void fromTo_withDslConverter() { StubMappingSearchTarget searchTarget = indexManager.createSearchTarget(); for ( ByTypeFieldModel<?> fieldModel : indexMapping.supportedFieldWithDslConverterModels ) { String absoluteFieldPath = fieldModel.relativeFieldName; Object lowerValueToMatch = new ValueWrapper<>( fieldModel.predicateLowerBound ); Object upperValueToMatch = new ValueWrapper<>( fieldModel.predicateUpperBound ); SearchQuery<DocumentReference> query = searchTarget.query() .asReference() .predicate( f -> f.range().onField( absoluteFieldPath ).from( lowerValueToMatch ).to( upperValueToMatch ).toPredicate() ) .build(); assertThat( query ) .hasDocRefHitsAnyOrder( INDEX_NAME, DOCUMENT_2 ); } }
.hasHitCount( 1 ); predicate = searchTarget.predicate().range().onField( "integer" ).from( 1 ).to( 2 ).toPredicate(); query = searchTarget.query() .asReference()