private void putInFieldTypeBucket(Set<String> stringEncodedFieldNames, Set<String> numericEncodedFieldNames, FieldDescriptor fieldDescriptor) { if ( FieldDescriptor.Type.NUMERIC.equals( fieldDescriptor.getType() ) ) { // If the property allows to index a string based null token, a non numeric query is ok // We are currently skipping this case completely from the validation. In a full on implementation we would // need to take term values into account and in the case of a string query only allow the null token. // For now we cast a net which is potentially too wide (HF) if ( !fieldDescriptor.indexNull() ) { numericEncodedFieldNames.add( fieldDescriptor.getName() ); } } else { stringEncodedFieldNames.add( fieldDescriptor.getName() ); } }
@Test public void testFieldDescriptorLuceneOptions() { String fieldName = "my-snafu"; FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, fieldName ); assertEquals( "Wrong field name", fieldName, fieldDescriptor.getName() ); assertEquals( Index.NO, fieldDescriptor.getIndex() ); assertEquals( Analyze.NO, fieldDescriptor.getAnalyze() ); assertEquals( Store.YES, fieldDescriptor.getStore() ); assertEquals( Norms.NO, fieldDescriptor.getNorms() ); assertEquals( TermVector.WITH_POSITIONS, fieldDescriptor.getTermVector() ); assertEquals( 10.0f, fieldDescriptor.getBoost(), 0 ); assertFalse( fieldDescriptor.indexNull() ); assertNull( fieldDescriptor.indexNullAs() ); assertTrue( FieldSettingsDescriptor.Type.BASIC.equals( fieldDescriptor.getType() ) ); }
@Test @TestForIssue(jiraKey = "HSEARCH-1987") public void testSomeOfSeveralFieldsAreNumeric() { Set<FieldDescriptor> fields = sfHolder.getSearchFactory() .getIndexedTypeDescriptor( new PojoIndexedTypeIdentifier( TouristAttraction.class ) ) .getProperty( "rating" ) .getIndexedFields(); assertThat( fields ).extracting( "name" ) .containsExactlyInAnyOrder( "rating", "ratingNumericPrecision1", "ratingNumericPrecision2" ); for ( FieldDescriptor field : fields ) { if ( "ratingNumericPrecision1".equals( field.getName() ) ) { assertThat( field.getType() ).isEqualTo( Type.NUMERIC ); assertThat( field.as( NumericFieldSettingsDescriptor.class ).precisionStep() ).isEqualTo( 1 ); } else if ( "ratingNumericPrecision2".equals( field.getName() ) ) { assertThat( field.getType() ).isEqualTo( Type.NUMERIC ); assertThat( field.as( NumericFieldSettingsDescriptor.class ).precisionStep() ).isEqualTo( 2 ); } else { assertThat( field.getType() ).isEqualTo( Type.BASIC ); } } }
@Test public void testFieldDescriptorByteNumericFieldBridge() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "numericByteField" ); assertNotNull( fieldDescriptor.getFieldBridge() ); assertTrue( fieldDescriptor.getFieldBridge() instanceof NumericFieldBridge ); assertTrue( FieldSettingsDescriptor.Type.NUMERIC.equals( fieldDescriptor.getType() ) ); NumericFieldSettingsDescriptor numericFieldSettingsDescriptor = fieldDescriptor.as( NumericFieldSettingsDescriptor.class ); int expectedPrecisionStep = 4; assertEquals( "the numeric step should be " + expectedPrecisionStep, expectedPrecisionStep, numericFieldSettingsDescriptor.precisionStep() ); NumericEncodingType expectedNumericEncodingType = NumericEncodingType.INTEGER; assertEquals( "the short numeric field should be encoded as " + expectedNumericEncodingType, expectedNumericEncodingType, numericFieldSettingsDescriptor.encodingType() ); }
@Test public void testFieldDescriptorWithCoordinatesWithoutSpatialAnnotation() { FieldDescriptor fieldDescriptor = getFieldDescriptor( SnafuWithCoordinatesWithoutSpatial.class, "location" ); assertNotNull( fieldDescriptor.getFieldBridge() ); assertTrue( fieldDescriptor.getFieldBridge() instanceof SpatialFieldBridge ); assertEquals( FieldSettingsDescriptor.Type.SPATIAL, fieldDescriptor.getType() ); }
@Test public void testCastingNonNumericFieldDescriptorToNumericOneThrowsException() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "my-snafu" ); assertFalse( FieldSettingsDescriptor.Type.NUMERIC.equals( fieldDescriptor.getType() ) ); try { fieldDescriptor.as( NumericFieldSettingsDescriptor.class ); fail( "A basic field descriptor cannot be narrowed to a numeric one" ); } catch (ClassCastException e) { assertTrue( "Wrong exception: " + e.getMessage(), e.getMessage().startsWith( "HSEARCH000180" ) ); } }
@Test public void testFieldDescriptorNullIndexOptions() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "nullValue" ); assertTrue( fieldDescriptor.indexNull() ); assertEquals( "snafu", fieldDescriptor.indexNullAs() ); }
private Map<String, FieldDescriptor> createAllFieldDescriptors() { Map<String, FieldDescriptor> fieldDescriptorMap = new HashMap<String, FieldDescriptor>(); for ( FieldDescriptor fieldDescriptor : classBridgeFieldDescriptors ) { fieldDescriptorMap.put( fieldDescriptor.getName(), fieldDescriptor ); } for ( PropertyDescriptor propertyDescriptor : propertyDescriptors ) { for ( FieldDescriptor fieldDescriptor : propertyDescriptor.getIndexedFields() ) { fieldDescriptorMap.put( fieldDescriptor.getName(), fieldDescriptor ); } } return fieldDescriptorMap; }
@Test public void testFieldDescriptorDefaultFieldBridge() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "my-snafu" ); assertNotNull( fieldDescriptor.getFieldBridge() ); assertTrue( fieldDescriptor.getFieldBridge() instanceof StringBridge ); }
@Test public void testFieldDescriptorExplicitAnalyzer() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "custom" ); assertNotNull( fieldDescriptor.getAnalyzer() ); assertTrue( fieldDescriptor.getAnalyzer() instanceof FooAnalyzer ); }
@Test public void testFieldDescriptorAsWithNullParameterThrowsException() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "my-snafu" ); try { fieldDescriptor.as( null ); fail( "null is not a valid type" ); } catch (ClassCastException e) { assertTrue( "Wrong exception: " + e.getMessage(), e.getMessage().startsWith( "HSEARCH000180" ) ); } }
@Test public void testFieldDescriptorShortNumericFieldBridge() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "numericShortField" ); assertNotNull( fieldDescriptor.getFieldBridge() ); assertTrue( fieldDescriptor.getFieldBridge() instanceof NumericFieldBridge ); assertTrue( FieldSettingsDescriptor.Type.NUMERIC.equals( fieldDescriptor.getType() ) ); NumericFieldSettingsDescriptor numericFieldSettingsDescriptor = fieldDescriptor.as( NumericFieldSettingsDescriptor.class ); int expectedPrecisionStep = 8; assertEquals( "the numeric step should be " + expectedPrecisionStep, expectedPrecisionStep, numericFieldSettingsDescriptor.precisionStep() ); NumericEncodingType expectedNumericEncodingType = NumericEncodingType.INTEGER; assertEquals( "the short numeric field should be encoded as " + expectedNumericEncodingType, expectedNumericEncodingType, numericFieldSettingsDescriptor.encodingType() ); }
@Test public void testFieldDescriptorWithCoordinates() { FieldDescriptor fieldDescriptor = getFieldDescriptor( SnafuWithCoordinates.class, "location" ); assertNotNull( fieldDescriptor.getFieldBridge() ); assertTrue( fieldDescriptor.getFieldBridge() instanceof SpatialFieldBridge ); assertTrue( FieldSettingsDescriptor.Type.SPATIAL.equals( fieldDescriptor.getType() ) ); }
@Test public void testFieldDescriptorExplicitNumericOptions() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "numericField" ); assertTrue( FieldSettingsDescriptor.Type.NUMERIC.equals( fieldDescriptor.getType() ) ); NumericFieldSettingsDescriptor numericFieldSettingsDescriptor = fieldDescriptor.as( NumericFieldSettingsDescriptor.class ); int expectedPrecisionStep = 16; assertEquals( "the numeric step should be " + expectedPrecisionStep, expectedPrecisionStep, numericFieldSettingsDescriptor.precisionStep() ); NumericEncodingType expectedNumericEncodingType = NumericEncodingType.INTEGER; assertEquals( "the numeric field should be encoded as " + expectedNumericEncodingType, expectedNumericEncodingType, numericFieldSettingsDescriptor.encodingType() ); }
@Test public void testFieldDescriptorDefaultNullIndexOptions() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "my-snafu" ); assertFalse( fieldDescriptor.indexNull() ); assertNull( fieldDescriptor.indexNullAs() ); }
private Map<String, FieldDescriptor> createAllFieldDescriptors() { Map<String, FieldDescriptor> fieldDescriptorMap = new HashMap<String, FieldDescriptor>(); for ( FieldDescriptor fieldDescriptor : classBridgeFieldDescriptors ) { fieldDescriptorMap.put( fieldDescriptor.getName(), fieldDescriptor ); } for ( PropertyDescriptor propertyDescriptor : propertyDescriptors ) { for ( FieldDescriptor fieldDescriptor : propertyDescriptor.getIndexedFields() ) { fieldDescriptorMap.put( fieldDescriptor.getName(), fieldDescriptor ); } } return fieldDescriptorMap; }
@Test public void testUsageOfDefaultStringBridgeInFieldBridgeAnnotation() throws Exception { String fieldName = "foo"; FieldDescriptor fieldDescriptor = getFieldDescriptor( Foo.class, fieldName ); FieldBridge fieldBridge = fieldDescriptor.getFieldBridge(); assertTrue( "The DefaultStringBridge should be wrapped in String2FieldBridgeAdaptor", fieldBridge instanceof String2FieldBridgeAdaptor ); // need to use reflection :-( java.lang.reflect.Field field = fieldBridge.getClass().getDeclaredField( "stringBridge" ); field.setAccessible( true ); StringBridge stringBridge = (StringBridge) field.get( fieldBridge ); assertTrue( "There should only be a single instance of DefaultStringBridge", DefaultStringBridge.INSTANCE == stringBridge ); }
@Test public void testFieldDescriptorDefaultAnalyzer() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "my-snafu" ); assertNotNull( fieldDescriptor.getAnalyzer() ); assertTrue( fieldDescriptor.getAnalyzer() instanceof PassThroughAnalyzer ); }
private void putInFieldTypeBucket(Set<String> stringEncodedFieldNames, Set<String> numericEncodedFieldNames, FieldDescriptor fieldDescriptor) { if ( FieldDescriptor.Type.NUMERIC.equals( fieldDescriptor.getType() ) ) { // If the property allows to index a string based null token, a non numeric query is ok // We are currently skipping this case completely from the validation. In a full on implementation we would // need to take term values into account and in the case of a string query only allow the null token. // For now we cast a net which is potentially too wide (HF) if ( !fieldDescriptor.indexNull() ) { numericEncodedFieldNames.add( fieldDescriptor.getName() ); } } else { stringEncodedFieldNames.add( fieldDescriptor.getName() ); } }
@Test public void testFieldDescriptorSpatialFieldBridge() { FieldDescriptor fieldDescriptor = getFieldDescriptor( Snafu.class, "location" ); assertNotNull( fieldDescriptor.getFieldBridge() ); assertTrue( fieldDescriptor.getFieldBridge() instanceof SpatialFieldBridge ); assertTrue( FieldSettingsDescriptor.Type.SPATIAL.equals( fieldDescriptor.getType() ) ); }