/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF 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. */ using System; using Lucene.Net.Search; using Lucene.Net.Spatial.Queries; using Lucene.Net.Spatial.Vector; using NUnit.Framework; using Spatial4n.Core.Context; using Spatial4n.Core.Shapes; using Spatial4n.Core.Shapes.Impl; using Spatial4n.Core.Exceptions; namespace Lucene.Net.Contrib.Spatial.Test.Vector { public class TestTwoDoublesStrategy : StrategyTestCase { public override void SetUp() { base.SetUp(); this.ctx = SpatialContext.GEO; this.strategy = new PointVectorStrategy(ctx, GetType().Name); } [Test] public void testCircleShapeSupport() { Circle circle = ctx.MakeCircle(ctx.MakePoint(0, 0), 10); SpatialArgs args = new SpatialArgs(SpatialOperation.Intersects, circle); Query query = this.strategy.MakeQuery(args); Assert.NotNull(query); } [Test] public void testInvalidQueryShape() { Point point = ctx.MakePoint(0, 0); var args = new SpatialArgs(SpatialOperation.Intersects, point); Assert.Throws(() => this.strategy.MakeQuery(args)); } [Test] public void testCitiesIntersectsBBox() { getAddAndVerifyIndexedDocuments(DATA_WORLD_CITIES_POINTS); executeQueries(SpatialMatchConcern.FILTER, QTEST_Cities_Intersects_BBox); } } }