/*
* 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.types;
import io.crate.test.integration.CrateUnitTest;
import org.elasticsearch.common.io.stream.BytesStreamOutput;
import org.elasticsearch.common.io.stream.StreamInput;
import org.junit.Test;
import java.util.Arrays;
import static org.hamcrest.Matchers.equalTo;
import static org.hamcrest.Matchers.is;
public class GeoPointTypeTest extends CrateUnitTest {
@Test
public void testStreaming() throws Throwable {
Double[] p1 = new Double[]{41.2, -37.4};
BytesStreamOutput out = new BytesStreamOutput();
DataTypes.GEO_POINT.writeValueTo(out, p1);
StreamInput in = out.bytes().streamInput();
Double[] p2 = DataTypes.GEO_POINT.readValueFrom(in);
assertThat(p1, equalTo(p2));
}
@Test
public void testWktToGeoPointValue() throws Exception {
Double[] value = DataTypes.GEO_POINT.value("POINT(1 2)");
assertThat(value[0], is(1.0d));
assertThat(value[1], is(2.0d));
}
@Test
public void testInvalidWktToGeoPointValue() throws Exception {
expectedException.expect(IllegalArgumentException.class);
expectedException.expectMessage("Cannot convert \"POINT(54.321 -123.456)\" to geo_point." +
" Bad Y value -123.456 is not in boundary Rect(minX=-180.0,maxX=180.0,minY=-90.0,maxY=90.0)");
DataTypes.GEO_POINT.value("POINT(54.321 -123.456)");
}
@Test
public void testValueConversionFromList() throws Exception {
Double[] value = DataTypes.GEO_POINT.value(Arrays.asList(10.0, 20.2));
assertThat(value[0], is(10.0d));
assertThat(value[1], is(20.2d));
}
@Test
public void testConversionFromObjectArrayOfIntegers() throws Exception {
Double[] value = DataTypes.GEO_POINT.value(new Object[]{1, 2});
assertThat(value[0], is(1.0));
assertThat(value[1], is(2.0));
}
@Test
public void testConversionFromIntegerArray() throws Exception {
Double[] value = DataTypes.GEO_POINT.value(new Integer[]{1, 2});
assertThat(value[0], is(1.0));
assertThat(value[1], is(2.0));
}
@Test
public void testInvalidLatitude() throws Exception {
expectedException.expectMessage("Failed to validate geo point [lon=54.321000, lat=-123.456000], not a valid location.");
DataTypes.GEO_POINT.value(new Double[]{54.321, -123.456});
}
@Test
public void testInvalidLongitude() throws Exception {
expectedException.expectMessage("Failed to validate geo point [lon=-187.654000, lat=123.456000], not a valid location.");
DataTypes.GEO_POINT.value(new Double[]{-187.654, 123.456});
}
}