/* * Licensed to CRATE Technology GmbH ("Crate") under one or more contributor * license agreements. See the NOTICE file distributed with this work for * additional information regarding copyright ownership. Crate 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. * * However, if you have executed another commercial license agreement * with Crate these terms will supersede the license and you may use the * software solely pursuant to the terms of the relevant commercial agreement. */ package io.crate.operation.scalar.geo; import io.crate.analyze.symbol.Literal; import io.crate.operation.scalar.AbstractScalarFunctionsTest; import io.crate.types.DataTypes; import org.junit.Test; import static io.crate.testing.SymbolMatchers.isLiteral; public class DistanceFunctionTest extends AbstractScalarFunctionsTest { @Test public void testResolveWithTooManyArguments() throws Exception { expectedException.expect(UnsupportedOperationException.class); expectedException.expectMessage("unknown function: distance(string, string, string)"); assertNormalize("distance('POINT (10 20)', 'POINT (11 21)', 'foo')", null); } @Test public void testResolveWithInvalidType() throws Exception { expectedException.expect(UnsupportedOperationException.class); expectedException.expectMessage("unknown function: distance(long, string)"); assertNormalize("distance(1, 'POINT (11 21)')", null); } @Test public void testEvaluateWithTwoGeoPointLiterals() throws Exception { assertEvaluate("distance(geopoint, geopoint)", 144572.67952051832, Literal.of(DataTypes.GEO_POINT, new Double[]{10.04, 28.02}), Literal.of(DataTypes.GEO_POINT, DataTypes.GEO_POINT.value("POINT(10.30 29.3)"))); } @Test public void testNormalizeWithStringTypes() throws Exception { // do not evaluate additional to the normalization as strings are only supported on normalization here assertNormalize("distance('POINT (10 20)', 'POINT (11 21)')", isLiteral(152354.3209044634), false); } @Test public void testNormalizeWithDoubleArray() throws Exception { assertNormalize("distance([10.0, 20.0], [11.0, 21.0])", isLiteral(152354.3209044634), false); } @Test public void testNormalizeWithInvalidReferences() throws Exception { expectedException.expect(IllegalArgumentException.class); expectedException.expectMessage("Cannot convert name to a geo point"); assertNormalize("distance(name, [10.04, 28.02])", null); } @Test public void testWithNullValue() throws Exception { assertEvaluate("distance(geopoint, geopoint)", null, Literal.of(DataTypes.GEO_POINT, null), Literal.of(DataTypes.GEO_POINT, DataTypes.GEO_POINT.value("POINT (10 20)"))); assertEvaluate("distance(geopoint, geopoint)", null, Literal.of(DataTypes.GEO_POINT, DataTypes.GEO_POINT.value("POINT (10 20)")), Literal.of(DataTypes.GEO_POINT, null)); } }