/* * Copyright 2016 MiLaboratory.com * * Licensed 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 com.milaboratory.util; import com.milaboratory.core.Range; import org.junit.Assert; import org.junit.Test; import java.util.List; import java.util.Map; import static org.junit.Assert.assertEquals; public class RangeMapTest { @Test(expected = RangeMap.IntersectingRangesException.class) public void test1() throws Exception { RangeMap<Integer> map = new RangeMap<>(); map.put(new Range(10, 20), 1); map.put(new Range(19, 30), 2); } @Test(expected = IllegalArgumentException.class) public void test2() throws Exception { RangeMap<Integer> map = new RangeMap<>(); map.put(new Range(10, 20), 1); map.put(new Range(48, 35), 2); } @Test public void test3() throws Exception { RangeMap<Integer> map = new RangeMap<>(); map.put(new Range(10, 20), 1); map.put(new Range(35, 48), 2); map.put(new Range(70, 80), 3); assertEquals((Object) 1, map.findContaining(new Range(10, 20)).getValue()); assertEquals((Object) 1, map.findContaining(new Range(11, 19)).getValue()); Assert.assertNull(map.findContaining(new Range(9, 19))); assertEquals((Object) 2, map.findContaining(new Range(35, 48)).getValue()); assertEquals((Object) 2, map.findContaining(new Range(36, 48)).getValue()); assertEquals((Object) 2, map.findContaining(new Range(35, 47)).getValue()); Assert.assertNull(map.findContaining(new Range(34, 49))); assertEquals((Object) 3, map.findContaining(new Range(70, 80)).getValue()); assertEquals((Object) 3, map.findContaining(new Range(71, 79)).getValue()); Assert.assertNull(map.findContaining(new Range(71, 81))); } @Test(expected = RangeMap.IntersectingRangesException.class) public void test4() throws Exception { RangeMap<Integer> map = new RangeMap<>(); map.put(new Range(10, 20), 1); map.put(new Range(35, 48), 2); map.put(new Range(60, 61), 4); map.put(new Range(70, 80), 5); map.put(new Range(79, 81), 5); } @Test(expected = RangeMap.IntersectingRangesException.class) public void test5() throws Exception { RangeMap<Integer> map = new RangeMap<>(); map.put(new Range(10, 20), 1); map.put(new Range(35, 48), 2); map.put(new Range(59, 61), 4); map.put(new Range(70, 80), 5); map.put(new Range(60, 61), 5); } @Test(expected = RangeMap.IntersectingRangesException.class) public void test6() throws Exception { RangeMap<Integer> map = new RangeMap<>(); map.put(new Range(10, 20), 1); map.put(new Range(35, 48), 2); map.put(new Range(59, 61), 4); map.put(new Range(70, 80), 5); map.put(new Range(5, 11), 5); } @Test public void test7() throws Exception { RangeMap<Integer> map = new RangeMap<>(); map.put(new Range(10, 20), 1); map.put(new Range(35, 48), 2); map.put(new Range(59, 61), 4); map.put(new Range(70, 80), 5); assertRangeIntersectsWith(15, 15, map); assertRangeIntersectsWith(5, 7, map); assertRangeIntersectsWith(15, 35, map, 1); assertRangeIntersectsWith(15, 36, map, 1, 2); assertRangeIntersectsWith(15, 48, map, 1, 2); assertRangeIntersectsWith(15, 60, map, 1, 2, 4); assertRangeIntersectsWith(15, 75, map, 1, 2, 4, 5); assertRangeIntersectsWith(19, 75, map, 1, 2, 4, 5); assertRangeIntersectsWith(20, 75, map, 2, 4, 5); assertRangeIntersectsWith(88, 90, map); assertRangeIntersectsOrTouches(15, 15, map, 1); assertRangeIntersectsOrTouches(5, 7, map); assertRangeIntersectsOrTouches(15, 35, map, 1, 2); assertRangeIntersectsOrTouches(15, 36, map, 1, 2); assertRangeIntersectsOrTouches(15, 48, map, 1, 2); assertRangeIntersectsOrTouches(15, 60, map, 1, 2, 4); assertRangeIntersectsOrTouches(15, 75, map, 1, 2, 4, 5); assertRangeIntersectsOrTouches(19, 75, map, 1, 2, 4, 5); assertRangeIntersectsOrTouches(20, 75, map, 1, 2, 4, 5); assertRangeIntersectsOrTouches(88, 90, map); } public void assertRangeIntersectsWith(int from, int to, RangeMap<Integer> map, int... values) { List<Map.Entry<Range, Integer>> al = map.findAllIntersecting(new Range(from, to)); assertEquals(values.length, al.size()); for (int i = 0; i < al.size(); i++) assertEquals((Object) values[i], al.get(i).getValue()); } public void assertRangeIntersectsOrTouches(int from, int to, RangeMap<Integer> map, int... values) { List<Map.Entry<Range, Integer>> al = map.findAllIntersectingOrTouching(new Range(from, to)); assertEquals(values.length, al.size()); for (int i = 0; i < al.size(); i++) assertEquals((Object) values[i], al.get(i).getValue()); } }