ifdService.clear();
FieldDataType fieldDataType = new FieldDataType("string", ImmutableSettings.builder().put("format", format)
.put("filter.frequency.min_segment_size", 100).put("filter.frequency.min", 0.0d).put("filter.frequency.max", random.nextBoolean() ? 100 : 0.5d));
IndexOrdinalsFieldData fieldData = getForField(fieldDataType, "high_freq");
AtomicOrdinalsFieldData loadDirect = fieldData.loadDirect(context);
RandomAccessOrds bytesValues = loadDirect.getOrdinalsValues();
assertThat(2L, equalTo(bytesValues.getValueCount()));
assertThat(bytesValues.lookupOrd(0).utf8ToString(), equalTo("10"));
assertThat(bytesValues.lookupOrd(1).utf8ToString(), equalTo("100"));
}
{
ifdService.clear();
FieldDataType fieldDataType = new FieldDataType("string", ImmutableSettings.builder().put("format", format)
.put("filter.frequency.min_segment_size", 100).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d).put("filter.frequency.max", 201));
IndexOrdinalsFieldData fieldData = getForField(fieldDataType, "high_freq");
AtomicOrdinalsFieldData loadDirect = fieldData.loadDirect(context);
RandomAccessOrds bytesValues = loadDirect.getOrdinalsValues();
assertThat(1L, equalTo(bytesValues.getValueCount()));
assertThat(bytesValues.lookupOrd(0).utf8ToString(), equalTo("5"));
}
{
ifdService.clear(); // test # docs with value
FieldDataType fieldDataType = new FieldDataType("string", ImmutableSettings.builder().put("format", format)
.put("filter.frequency.min_segment_size", 101).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d));
IndexOrdinalsFieldData fieldData = getForField(fieldDataType, "med_freq");
AtomicOrdinalsFieldData loadDirect = fieldData.loadDirect(context);
RandomAccessOrds bytesValues = loadDirect.getOrdinalsValues();
assertThat(2L, equalTo(bytesValues.getValueCount()));
assertThat(bytesValues.lookupOrd(0).utf8ToString(), equalTo("10"));
assertThat(bytesValues.lookupOrd(1).utf8ToString(), equalTo("100"));
}
{
ifdService.clear();
FieldDataType fieldDataType = new FieldDataType("string", ImmutableSettings.builder().put("format", format)
.put("filter.frequency.min_segment_size", 101).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d));
IndexOrdinalsFieldData fieldData = getForField(fieldDataType, "med_freq");
AtomicOrdinalsFieldData loadDirect = fieldData.loadDirect(context);
RandomAccessOrds bytesValues = loadDirect.getOrdinalsValues();
assertThat(2L, equalTo(bytesValues.getValueCount()));
assertThat(bytesValues.lookupOrd(0).utf8ToString(), equalTo("10"));
assertThat(bytesValues.lookupOrd(1).utf8ToString(), equalTo("100"));
}
{
ifdService.clear();
FieldDataType fieldDataType = new FieldDataType("string", ImmutableSettings.builder().put("format", format)
.put("filter.regex.pattern", "\\d{2,3}") // allows 10 & 100
.put("filter.frequency.min_segment_size", 0)
.put("filter.frequency.min", random.nextBoolean() ? 1 : 1d/200.0d) // 100, 10, 5
.put("filter.frequency.max", random.nextBoolean() ? 99 : 99d/200.0d)); // 100
IndexOrdinalsFieldData fieldData = getForField(fieldDataType, "high_freq");
AtomicOrdinalsFieldData loadDirect = fieldData.loadDirect(context);
RandomAccessOrds bytesValues = loadDirect.getOrdinalsValues();
assertThat(1L, equalTo(bytesValues.getValueCount()));
assertThat(bytesValues.lookupOrd(0).utf8ToString(), equalTo("100"));
}
}
}