/*
* Licensed to Elasticsearch under one or more contributor
* license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright
* ownership. Elasticsearch licenses this file to you under
* the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.elasticsearch.search.aggregations.support;
import com.carrotsearch.randomizedtesting.generators.RandomStrings;
import org.apache.lucene.search.Scorer;
import org.apache.lucene.util.BytesRef;
import org.elasticsearch.script.LeafSearchScript;
import org.elasticsearch.search.aggregations.support.values.ScriptBytesValues;
import org.elasticsearch.search.aggregations.support.values.ScriptDoubleValues;
import org.elasticsearch.search.aggregations.support.values.ScriptLongValues;
import org.elasticsearch.test.ESTestCase;
import java.io.IOException;
import java.util.Arrays;
import java.util.Map;
public class ScriptValuesTests extends ESTestCase {
private static class FakeSearchScript implements LeafSearchScript {
private final Object[][] values;
int index;
FakeSearchScript(Object[][] values) {
this.values = values;
index = -1;
}
@Override
public void setNextVar(String name, Object value) {
}
@Override
public Object run() {
// Script values are supposed to support null, single values, arrays and collections
final Object[] values = this.values[index];
if (values.length <= 1 && randomBoolean()) {
return values.length == 0 ? null : values[0];
}
return randomBoolean() ? values : Arrays.asList(values);
}
@Override
public void setScorer(Scorer scorer) {
}
@Override
public void setDocument(int doc) {
index = doc;
}
@Override
public void setSource(Map<String, Object> source) {
}
@Override
public long runAsLong() {
throw new UnsupportedOperationException();
}
@Override
public double runAsDouble() {
throw new UnsupportedOperationException();
}
}
public void testLongs() throws IOException {
final Object[][] values = new Long[randomInt(10)][];
for (int i = 0; i < values.length; ++i) {
Long[] longs = new Long[randomInt(8)];
for (int j = 0; j < longs.length; ++j) {
longs[j] = randomLong();
}
Arrays.sort(longs);
values[i] = longs;
}
FakeSearchScript script = new FakeSearchScript(values);
ScriptLongValues scriptValues = new ScriptLongValues(script);
for (int i = 0; i < values.length; ++i) {
assertEquals(values[i].length > 0, scriptValues.advanceExact(i));
if (values[i].length > 0) {
assertEquals(values[i].length, scriptValues.docValueCount());
for (int j = 0; j < values[i].length; ++j) {
assertEquals(values[i][j], scriptValues.nextValue());
}
}
}
}
public void testBooleans() throws IOException {
final Object[][] values = new Boolean[randomInt(10)][];
for (int i = 0; i < values.length; ++i) {
Boolean[] booleans = new Boolean[randomInt(8)];
for (int j = 0; j < booleans.length; ++j) {
booleans[j] = randomBoolean();
}
Arrays.sort(booleans);
values[i] = booleans;
}
FakeSearchScript script = new FakeSearchScript(values);
ScriptLongValues scriptValues = new ScriptLongValues(script);
for (int i = 0; i < values.length; ++i) {
assertEquals(values[i].length > 0, scriptValues.advanceExact(i));
if (values[i].length > 0) {
assertEquals(values[i].length, scriptValues.docValueCount());
for (int j = 0; j < values[i].length; ++j) {
assertEquals(values[i][j], scriptValues.nextValue() == 1L);
}
}
}
}
public void testDoubles() throws IOException {
final Object[][] values = new Double[randomInt(10)][];
for (int i = 0; i < values.length; ++i) {
Double[] doubles = new Double[randomInt(8)];
for (int j = 0; j < doubles.length; ++j) {
doubles[j] = randomDouble();
}
Arrays.sort(doubles);
values[i] = doubles;
}
FakeSearchScript script = new FakeSearchScript(values);
ScriptDoubleValues scriptValues = new ScriptDoubleValues(script);
for (int i = 0; i < values.length; ++i) {
assertEquals(values[i].length > 0, scriptValues.advanceExact(i));
if (values[i].length > 0) {
assertEquals(values[i].length, scriptValues.docValueCount());
for (int j = 0; j < values[i].length; ++j) {
assertEquals(values[i][j], scriptValues.nextValue());
}
}
}
}
public void testBytes() throws IOException {
final String[][] values = new String[randomInt(10)][];
for (int i = 0; i < values.length; ++i) {
String[] strings = new String[randomInt(8)];
for (int j = 0; j < strings.length; ++j) {
strings[j] = RandomStrings.randomAsciiOfLength(random(), 5);
}
Arrays.sort(strings);
values[i] = strings;
}
FakeSearchScript script = new FakeSearchScript(values);
ScriptBytesValues scriptValues = new ScriptBytesValues(script);
for (int i = 0; i < values.length; ++i) {
assertEquals(values[i].length > 0, scriptValues.advanceExact(i));
if (values[i].length > 0) {
assertEquals(values[i].length, scriptValues.docValueCount());
for (int j = 0; j < values[i].length; ++j) {
assertEquals(new BytesRef(values[i][j]), scriptValues.nextValue());
}
}
}
}
}