All Downloads are FREE. Search and download functionalities are using the official Maven repository.

it.unimi.dsi.fastutil.ints.Int2ObjectMapGenericLinkedOpenHashTest Maven / Gradle / Ivy

Go to download

fastutil extends the Java Collections Framework by providing type-specific maps, sets, lists, and queues with a small memory footprint and fast access and insertion; it provides also big (64-bit) arrays, sets and lists, sorting algorithms, fast, practical I/O classes for binary and text files, and facilities for memory mapping large files. Note that if you have both this jar and fastutil-core.jar in your dependencies, fastutil-core.jar should be excluded.

There is a newer version: 8.5.15
Show newest version
package it.unimi.dsi.fastutil.ints;

/*
 * Copyright (C) 2017 Sebastiano Vigna
 *
 * 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.
 */

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertSame;

import java.util.Collections;
import java.util.EnumSet;
import java.util.Map;
import java.util.NoSuchElementException;
import java.util.function.Supplier;

import org.junit.Test;
import org.junit.runners.Parameterized.Parameters;

import it.unimi.dsi.fastutil.ints.Int2ObjectMap.Entry;
import it.unimi.dsi.fastutil.objects.ObjectBidirectionalIterator;

public class Int2ObjectMapGenericLinkedOpenHashTest extends Int2ObjectMapGenericTest> {
	@Parameters
	public static Iterable data() {
		return Collections.singletonList(new Object[] {(Supplier>) Int2ObjectLinkedOpenHashMap::new, EnumSet.allOf(Capability.class)});
	}

	@Test
	public void testIterator() {
		m.defaultReturnValue(DEFAULT);
		for (int i = 0; i < 100; i++) {
			assertSame(DEFAULT, m.put(i, Integer.valueOf(i)));
		}
		assertEquals(0, m.firstIntKey());

		IntListIterator iterator = (IntListIterator) m.keySet().iterator();
		for (int i = 0; i <= 100; i++) {
			assertEquals(Integer.toString(i), i - 1, iterator.previousIndex());
			assertEquals(Integer.toString(i), i, iterator.nextIndex());
			if (i != 100) {
				assertEquals(Integer.toString(i), i, iterator.nextInt());
			}
		}

		iterator = (IntListIterator) m.keySet().iterator(m.lastIntKey());
		for (int i = 100; i-- != 0; ) {
			assertEquals(Integer.toString(i), i, iterator.previousIndex());
			assertEquals(Integer.toString(i), i + 1, iterator.nextIndex());
			if (i != 0) {
				assertEquals(Integer.toString(i), i, iterator.previousInt());
			}
		}

		iterator = (IntListIterator) m.keySet().iterator(50);
		for (int i = 50; i < 100; i++) {
			assertEquals(Integer.toString(i), i, iterator.previousIndex());
			assertEquals(Integer.toString(i), i + 1, iterator.nextIndex());
			if (i != 99) {
				assertEquals(Integer.toString(i), i + 1, iterator.nextInt());
			}
		}

		iterator = (IntListIterator) m.keySet().iterator(50);
		for (int i = 50; i-- != -1; ) {
			assertEquals(Integer.toString(i), i + 1, iterator.previousIndex());
			assertEquals(Integer.toString(i), i + 2, iterator.nextIndex());
			if (i != -1) {
				assertEquals(Integer.toString(i), i + 1, iterator.previousInt());
			}
		}

		iterator = (IntListIterator) m.keySet().iterator(50);
		for (int i = 50; i-- != -1; ) {
			assertEquals(Integer.toString(i), i + 1, iterator.previousInt());
		}
		assertEquals(-1, iterator.previousIndex());
		assertEquals(0, iterator.nextIndex());

		iterator = (IntListIterator) m.keySet().iterator(50);
		for (int i = 50; i < 100 - 1; i++) {
			assertEquals(Integer.toString(i), i + 1, iterator.nextInt());
		}
		assertEquals(99, iterator.previousIndex());
		assertEquals(100, iterator.nextIndex());

		iterator = (IntListIterator) m.keySet().iterator(50);
		iterator.previousInt();
		iterator.remove();
		assertEquals(49, iterator.previousIndex());
		assertEquals(49, iterator.previousInt());

		iterator = (IntListIterator) m.keySet().iterator(49);
		iterator.nextInt();
		iterator.remove();
		assertEquals(50, iterator.nextIndex());
		assertEquals(52, iterator.nextInt());
	}

	@Test(expected = NoSuchElementException.class)
	public void testIteratorMissingElement() {
		m.defaultReturnValue(DEFAULT);
		for (int i = 0; i < 100; i++) {
			assertSame(DEFAULT, m.put(i, Integer.valueOf(i)));
		}
		m.keySet().iterator(1000);
	}

	@SuppressWarnings("deprecation")
	@Test(expected = NoSuchElementException.class)
	public void testNextAtEnd() {
		m.put(1, ONE);
		m.put(2, TWO);
		m.put(3, THREE);
		final ObjectBidirectionalIterator> iterator = m.entrySet().iterator(m.entrySet().last());
		assertFalse(iterator.hasNext());
		iterator.next();
	}

	@Test(expected = NoSuchElementException.class)
	public void testNextAtEndFast() {
		m.put(1, ONE);
		m.put(2, TWO);
		m.put(3, THREE);
		final ObjectBidirectionalIterator> iterator = m.int2ObjectEntrySet().iterator(m.int2ObjectEntrySet().last());
		assertFalse(iterator.hasNext());
		iterator.next();
	}

	@Test(expected = NoSuchElementException.class)
	public void testPreviousAtStart() {
		m.put(1, ONE);
		m.put(2, TWO);
		m.put(3, THREE);
		@SuppressWarnings("deprecation") final ObjectBidirectionalIterator> iterator = m.entrySet().iterator();
		assertFalse(iterator.hasPrevious());
		iterator.previous();
	}

	@Test(expected = NoSuchElementException.class)
	public void testPreviousAtStartFast() {
		m.put(1, ONE);
		m.put(2, TWO);
		m.put(3, THREE);
		final ObjectBidirectionalIterator> iterator = m.int2ObjectEntrySet().iterator();
		assertFalse(iterator.hasPrevious());
		iterator.previous();
	}

	@Test
	public void testPutAndMove() {
		m.defaultReturnValue(DEFAULT);
		for (int i = 0; i < 100; i++) {
			assertSame(DEFAULT, m.putAndMoveToFirst(i, Integer.valueOf(i)));
		}
		m.clear();
		for (int i = 0; i < 100; i++) {
			assertSame(DEFAULT, m.putAndMoveToLast(i, Integer.valueOf(i)));
		}
		assertSame(DEFAULT, m.putAndMoveToFirst(-1, MINUS_ONE));
		assertEquals(-1, m.firstIntKey());
		assertSame(DEFAULT, m.putAndMoveToFirst(-2, Integer.valueOf(-2)));
		assertEquals(-2, m.firstIntKey());
		assertEquals(MINUS_ONE, m.putAndMoveToFirst(-1, MINUS_ONE));
		assertEquals(-1, m.firstIntKey());
		assertEquals(MINUS_ONE, m.putAndMoveToFirst(-1, MINUS_ONE));
		assertEquals(-1, m.firstIntKey());
		assertEquals(MINUS_ONE, m.putAndMoveToLast(-1, MINUS_ONE));
		assertEquals(-1, m.lastIntKey());
		assertSame(DEFAULT, m.putAndMoveToLast(100, Integer.valueOf(100)));
		assertEquals(100, m.lastIntKey());
		assertSame(DEFAULT, m.putAndMoveToLast(101, Integer.valueOf(101)));
		assertEquals(101, m.lastIntKey());
		assertEquals(Integer.valueOf(100), m.putAndMoveToLast(100, Integer.valueOf(100)));
		assertEquals(100, m.lastIntKey());
		assertEquals(Integer.valueOf(100), m.putAndMoveToLast(100, Integer.valueOf(100)));
		assertEquals(100, m.lastIntKey());
		assertEquals(Integer.valueOf(100), m.putAndMoveToFirst(100, Integer.valueOf(100)));
		assertEquals(100, m.firstIntKey());
	}

	@Test(expected = NoSuchElementException.class)
	public void testRemoveFirstEmpty() {
		m.removeFirst();
	}

	@Test
	public void testRemoveFirstLast() {
		m.defaultReturnValue(DEFAULT);
		for (int i = 0; i < 100; i++) {
			assertEquals(DEFAULT, m.put(i, Integer.valueOf(1 + i)));
		}
		assertEquals(ONE, m.removeFirst());
		assertEquals(TWO, m.removeFirst());
		assertEquals(Integer.valueOf(100), m.removeLast());
	}

	@Test(expected = NoSuchElementException.class)
	public void testRemoveLastEmpty() {
		m.removeLast();
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy