/* * Copyright 2015 Goldman Sachs. * * 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.gs.collections.test.map.mutable.sorted; import java.util.Comparator; import java.util.Iterator; import com.gs.collections.api.map.sorted.MutableSortedMap; import com.gs.collections.impl.block.factory.Comparators; import com.gs.collections.impl.map.sorted.mutable.TreeSortedMap; import com.gs.collections.test.bag.mutable.sorted.OrderedIterableNoIteratorTest; import com.gs.junit.runners.Java8Runner; import org.junit.runner.RunWith; import static org.junit.Assert.assertNull; @RunWith(Java8Runner.class) public class TreeSortedMapNoIteratorTest implements MutableSortedMapIterableTestCase, OrderedIterableNoIteratorTest { @Override public <T> MutableSortedMap<Object, T> newWith(T... elements) { int i = elements.length; MutableSortedMap<Object, T> result = new TreeSortedMapNoIterator<>(Comparators.reverseNaturalOrder()); for (T each : elements) { assertNull(result.put(i, each)); i--; } return result; } @Override public void Iterable_remove() { OrderedIterableNoIteratorTest.super.Iterable_remove(); } public static class TreeSortedMapNoIterator<K, V> extends TreeSortedMap<K, V> { public TreeSortedMapNoIterator() { // For serialization } public TreeSortedMapNoIterator(Comparator<? super K> comparator) { super(comparator); } @Override public Iterator<V> iterator() { throw new AssertionError("No iteration patterns should delegate to iterator()"); } } }