mirror of
https://github.com/2006-Scape/apollo.git
synced 2026-07-03 00:38:21 +00:00
Merge pull request #129 from ryleykimmel/pr1-issue98
Fixes issue #98 (also adds unit test for MobRepository)
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
package org.apollo.game.model.entity;
|
||||
|
||||
import java.util.Iterator;
|
||||
import java.util.NoSuchElementException;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
|
||||
@@ -21,25 +22,27 @@ public final class MobRepository<T extends Mob> implements Iterable<T> {
|
||||
*/
|
||||
private final class MobRepositoryIterator implements Iterator<T> {
|
||||
|
||||
/**
|
||||
* The current index of this Iterator.
|
||||
*/
|
||||
private int current;
|
||||
|
||||
/**
|
||||
* The last index found.
|
||||
*/
|
||||
private int last = -1;
|
||||
|
||||
/**
|
||||
* The repository of {@link Mob}s this {@link Iterator} iterates over.
|
||||
*/
|
||||
private final MobRepository<T> repository;
|
||||
|
||||
/**
|
||||
* The current index of this iterator.
|
||||
*/
|
||||
private int currentIndex;
|
||||
|
||||
/**
|
||||
* The amount of indexes found.
|
||||
*/
|
||||
private int foundIndex;
|
||||
|
||||
/**
|
||||
* Constructs a new {@link MobRepositoryIterator} with the specified MobRepository.
|
||||
*
|
||||
* @param repository The repository of Mob's this Iterator iterates over.
|
||||
* Constructs a new {@link MobRepositoryIterator} with the specified
|
||||
* MobRepository.
|
||||
*
|
||||
* @param repository
|
||||
* The MobRepository we're iterating over.
|
||||
*/
|
||||
private MobRepositoryIterator(MobRepository<T> repository) {
|
||||
this.repository = repository;
|
||||
@@ -47,27 +50,40 @@ public final class MobRepository<T extends Mob> implements Iterable<T> {
|
||||
|
||||
@Override
|
||||
public boolean hasNext() {
|
||||
if (foundIndex == size()) {
|
||||
return false;
|
||||
}
|
||||
int index = current;
|
||||
|
||||
while (currentIndex < capacity()) {
|
||||
if (mobs[currentIndex++] != null) {
|
||||
foundIndex++;
|
||||
while (index <= repository.size()) {
|
||||
Mob mob = repository.mobs[index++];
|
||||
if (mob != null) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
@Override
|
||||
public T next() {
|
||||
return get(currentIndex);
|
||||
while (current <= repository.size()) {
|
||||
Mob mob = repository.mobs[current++];
|
||||
if (mob != null) {
|
||||
last = current;
|
||||
return (T) mob;
|
||||
}
|
||||
}
|
||||
|
||||
throw new NoSuchElementException("There are no more elements!");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void remove() {
|
||||
repository.remove(currentIndex + 1);
|
||||
if (last == -1) {
|
||||
throw new IllegalStateException("remove() may only be called once per call to next()");
|
||||
}
|
||||
|
||||
repository.remove(last);
|
||||
last = -1;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -0,0 +1,208 @@
|
||||
package org.apollo.game.model.entity;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
import static org.powermock.api.mockito.PowerMockito.mock;
|
||||
import static org.powermock.api.mockito.PowerMockito.when;
|
||||
|
||||
import java.util.Iterator;
|
||||
import java.util.NoSuchElementException;
|
||||
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||
import org.powermock.modules.junit4.PowerMockRunner;
|
||||
|
||||
/**
|
||||
* Tests the {@link MobRepository} class.
|
||||
*
|
||||
* @author Ryley
|
||||
*/
|
||||
@RunWith(PowerMockRunner.class)
|
||||
@PrepareForTest(Player.class)
|
||||
public final class MobRepositoryTest {
|
||||
|
||||
/**
|
||||
* The capacity of the MobRepository.
|
||||
*/
|
||||
private static final int CAPACITY = 10;
|
||||
|
||||
/**
|
||||
* Tests {@link MobRepository#capacity()}.
|
||||
*/
|
||||
@Test
|
||||
public void testCapacity() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
assertEquals(CAPACITY, players.capacity());
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests {@link MobRepository#add(Mob)}.
|
||||
*/
|
||||
@Test
|
||||
public void testAdd() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
Player player = mock(Player.class);
|
||||
when(player.getIndex()).thenReturn(1);
|
||||
|
||||
players.add(player);
|
||||
|
||||
assertEquals(1, players.size());
|
||||
assertEquals(player, players.get(player.getIndex()));
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests {@link MobRepository#remove(Mob)}.
|
||||
*/
|
||||
@Test
|
||||
public void testRemove() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
Player player = mock(Player.class);
|
||||
when(player.getIndex()).thenReturn(1);
|
||||
|
||||
players.add(player);
|
||||
|
||||
assertEquals(1, players.size());
|
||||
assertEquals(player, players.get(player.getIndex()));
|
||||
|
||||
players.remove(player);
|
||||
assertEquals(0, players.size());
|
||||
}
|
||||
|
||||
/**
|
||||
* Ensures that a MobRepository maintains a fixed capacity.
|
||||
*/
|
||||
@Test
|
||||
public void testCapacityExceeded() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
for (int index = 0; index < CAPACITY; index++) {
|
||||
Player player = mock(Player.class);
|
||||
when(player.getIndex()).thenReturn(index + 1);
|
||||
|
||||
assertTrue(players.add(player));
|
||||
}
|
||||
|
||||
Player player = mock(Player.class);
|
||||
when(player.getIndex()).thenReturn(CAPACITY);
|
||||
|
||||
assertTrue(players.full());
|
||||
assertFalse(players.add(player));
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests {@link Iterator#hasNext()} for a MobRepository.
|
||||
*/
|
||||
@Test
|
||||
public void testIteratorHasNext() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
Player player = mock(Player.class);
|
||||
when(player.getIndex()).thenReturn(1);
|
||||
|
||||
players.add(player);
|
||||
|
||||
Iterator<Player> iterator = players.iterator();
|
||||
assertTrue(iterator.hasNext());
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests {@link Iterator#next()} for a MobRepository.
|
||||
*/
|
||||
@Test
|
||||
public void testIteratorNext() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
Player first = mock(Player.class);
|
||||
when(first.getIndex()).thenReturn(1);
|
||||
|
||||
Player second = mock(Player.class);
|
||||
when(second.getIndex()).thenReturn(2);
|
||||
|
||||
players.add(first);
|
||||
players.add(second);
|
||||
|
||||
Iterator<Player> iterator = players.iterator();
|
||||
|
||||
assertTrue(iterator.hasNext());
|
||||
assertEquals(first, iterator.next());
|
||||
assertTrue(iterator.hasNext());
|
||||
assertEquals(second, iterator.next());
|
||||
assertFalse(iterator.hasNext());
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests {@link Iterator#remove()} for a MobRepository.
|
||||
*/
|
||||
@Test
|
||||
public void testIteratorRemove() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
Player first = mock(Player.class);
|
||||
when(first.getIndex()).thenReturn(1);
|
||||
|
||||
Player second = mock(Player.class);
|
||||
when(second.getIndex()).thenReturn(2);
|
||||
|
||||
players.add(first);
|
||||
players.add(second);
|
||||
|
||||
Iterator<Player> iterator = players.iterator();
|
||||
|
||||
iterator.next();
|
||||
iterator.remove();
|
||||
iterator.next();
|
||||
iterator.remove();
|
||||
|
||||
assertFalse(iterator.hasNext());
|
||||
}
|
||||
|
||||
/**
|
||||
* Ensures {@link Iterator#next()} for a MobRepository throws a
|
||||
* {@link NoSuchElementException} if the iterator contains no more elements.
|
||||
*/
|
||||
@Test(expected = NoSuchElementException.class)
|
||||
public void testIteratorNextOverflow() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
Player first = mock(Player.class);
|
||||
when(first.getIndex()).thenReturn(1);
|
||||
|
||||
Player second = mock(Player.class);
|
||||
when(second.getIndex()).thenReturn(2);
|
||||
|
||||
players.add(first);
|
||||
players.add(second);
|
||||
|
||||
Iterator<Player> iterator = players.iterator();
|
||||
|
||||
iterator.next();
|
||||
iterator.next();
|
||||
|
||||
iterator.next();
|
||||
}
|
||||
|
||||
/**
|
||||
* Ensures {@link Iterator#remove()} for a MobRepository throws an
|
||||
* {@link IllegalStateException} if remove() is called without a call to
|
||||
* next().
|
||||
*/
|
||||
@Test(expected = IllegalStateException.class)
|
||||
public void testIteratorRemoveIllegalState() {
|
||||
MobRepository<Player> players = new MobRepository<>(CAPACITY);
|
||||
|
||||
Player player = mock(Player.class);
|
||||
when(player.getIndex()).thenReturn(1);
|
||||
|
||||
players.add(player);
|
||||
|
||||
Iterator<Player> iterator = players.iterator();
|
||||
|
||||
iterator.remove();
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user