Skip to content

Instantly share code, notes, and snippets.

@yurii-litvinov
Created December 21, 2016 11:36
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save yurii-litvinov/85cc529fa7037495af1fa23d350a6b2f to your computer and use it in GitHub Desktop.
Save yurii-litvinov/85cc529fa7037495af1fa23d350a6b2f to your computer and use it in GitHub Desktop.
import org.junit.Test;
import java.lang.reflect.InvocationTargetException;
import java.util.*;
import static org.junit.Assert.*;
public class SmartListTest {
@Test
public void testSimple() {
List<Integer> list = newList();
assertEquals(Collections.<Integer>emptyList(), list);
list.add(1);
assertEquals(Collections.singletonList(1), list);
list.add(2);
assertEquals(Arrays.asList(1, 2), list);
}
@Test
public void testGetSet() {
List<Object> list = newList();
list.add(1);
assertEquals(1, list.get(0));
assertEquals(1, list.set(0, 2));
assertEquals(2, list.get(0));
assertEquals(2, list.set(0, 1));
list.add(2);
assertEquals(1, list.get(0));
assertEquals(2, list.get(1));
assertEquals(1, list.set(0, 2));
assertEquals(Arrays.asList(2, 2), list);
}
@Test
public void testRemove() throws Exception {
List<Object> list = newList();
list.add(1);
list.remove(0);
assertEquals(Collections.emptyList(), list);
list.add(2);
list.remove((Object) 2);
assertEquals(Collections.emptyList(), list);
list.add(1);
list.add(2);
assertEquals(Arrays.asList(1, 2), list);
list.remove(0);
assertEquals(Collections.singletonList(2), list);
list.remove(0);
assertEquals(Collections.emptyList(), list);
}
@Test
public void testIteratorRemove() throws Exception {
List<Object> list = newList();
assertFalse(list.iterator().hasNext());
list.add(1);
Iterator<Object> iterator = list.iterator();
assertTrue(iterator.hasNext());
assertEquals(1, iterator.next());
iterator.remove();
assertFalse(iterator.hasNext());
assertEquals(Collections.emptyList(), list);
list.addAll(Arrays.asList(1, 2));
iterator = list.iterator();
assertTrue(iterator.hasNext());
assertEquals(1, iterator.next());
iterator.remove();
assertTrue(iterator.hasNext());
assertEquals(Collections.singletonList(2), list);
assertEquals(2, iterator.next());
iterator.remove();
assertFalse(iterator.hasNext());
assertEquals(Collections.emptyList(), list);
}
@Test
public void testCollectionConstructor() throws Exception {
assertEquals(Collections.emptyList(), newList(Collections.emptyList()));
assertEquals(
Collections.singletonList(1),
newList(Collections.singletonList(1)));
assertEquals(
Arrays.asList(1, 2),
newList(Arrays.asList(1, 2)));
}
@Test
public void testAddManyElementsThenRemove() throws Exception {
List<Object> list = newList();
for (int i = 0; i < 7; i++) {
list.add(i + 1);
}
assertEquals(Arrays.asList(1, 2, 3, 4, 5, 6, 7), list);
for (int i = 0; i < 7; i++) {
list.remove(list.size() - 1);
assertEquals(6 - i, list.size());
}
assertEquals(Collections.emptyList(), list);
}
private static <T> List<T> newList() {
try {
return (List<T>) getListClass().getConstructor().newInstance();
} catch (InstantiationException | ClassNotFoundException | IllegalAccessException | NoSuchMethodException | InvocationTargetException e) {
throw new RuntimeException(e);
}
}
private static <T> List<T> newList(Collection<T> collection) {
try {
return (List<T>) getListClass().getConstructor(Collection.class).newInstance(collection);
} catch (InstantiationException | ClassNotFoundException | IllegalAccessException | NoSuchMethodException | InvocationTargetException e) {
throw new RuntimeException(e);
}
}
private static Class<?> getListClass() throws ClassNotFoundException {
return Class.forName("ru.spbau.mit.SmartList");
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment