mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
26209efac2
The change to only grow the array when the capacity has been reached exposed a bug in the remove method when shifting the array elements.
194 lines
4.8 KiB
Java
194 lines
4.8 KiB
Java
import java.util.ArrayList;
|
|
import java.util.LinkedList;
|
|
import java.util.ListIterator;
|
|
|
|
public class List {
|
|
private static void expect(boolean v) {
|
|
if (! v) throw new RuntimeException();
|
|
}
|
|
|
|
private static String printList(ArrayList<Integer> list) {
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
for (Integer i : list) {
|
|
sb.append(i);
|
|
sb.append(", ");
|
|
}
|
|
sb.setLength(sb.length()-2);
|
|
return sb.toString();
|
|
}
|
|
|
|
private static void isEqual(String s1, String s2) {
|
|
System.out.println(s1);
|
|
expect(s1.equals(s2));
|
|
}
|
|
|
|
private static void testIterators(java.util.List<Integer> l) {
|
|
l.add(1);
|
|
l.add(2);
|
|
l.add(3);
|
|
|
|
ListIterator<Integer> it = l.listIterator();
|
|
expect(it.next().equals(Integer.valueOf(1)));
|
|
expect(it.next().equals(Integer.valueOf(2)));
|
|
expect(it.next().equals(Integer.valueOf(3)));
|
|
expect(! it.hasNext());
|
|
|
|
it = l.listIterator(1);
|
|
expect(it.next().equals(Integer.valueOf(2)));
|
|
expect(it.next().equals(Integer.valueOf(3)));
|
|
expect(! it.hasNext());
|
|
|
|
it = l.listIterator(2);
|
|
expect(it.next().equals(Integer.valueOf(3)));
|
|
expect(! it.hasNext());
|
|
|
|
it = l.listIterator(3);
|
|
expect(it.previous().equals(Integer.valueOf(3)));
|
|
expect(it.previous().equals(Integer.valueOf(2)));
|
|
expect(it.previous().equals(Integer.valueOf(1)));
|
|
expect(! it.hasPrevious());
|
|
|
|
it = l.listIterator(2);
|
|
expect(it.previous().equals(Integer.valueOf(2)));
|
|
expect(it.previous().equals(Integer.valueOf(1)));
|
|
expect(! it.hasPrevious());
|
|
|
|
it = l.listIterator(1);
|
|
expect(it.previous().equals(Integer.valueOf(1)));
|
|
expect(! it.hasPrevious());
|
|
}
|
|
|
|
private static void testIterators2(java.util.List<Integer> l) {
|
|
l.add(1);
|
|
l.add(2);
|
|
l.add(3);
|
|
|
|
ListIterator<Integer> it = l.listIterator();
|
|
expect(it.next().equals(Integer.valueOf(1)));
|
|
it.remove();
|
|
expect(it.next().equals(Integer.valueOf(2)));
|
|
it.remove();
|
|
expect(it.next().equals(Integer.valueOf(3)));
|
|
it.remove();
|
|
expect(! it.hasNext());
|
|
expect(l.isEmpty());
|
|
|
|
l.add(1);
|
|
l.add(2);
|
|
l.add(3);
|
|
|
|
it = l.listIterator(1);
|
|
expect(it.next().equals(Integer.valueOf(2)));
|
|
it.remove();
|
|
expect(it.next().equals(Integer.valueOf(3)));
|
|
it.remove();
|
|
expect(! it.hasNext());
|
|
expect(l.size() == 1);
|
|
|
|
l.add(2);
|
|
l.add(3);
|
|
|
|
it = l.listIterator(2);
|
|
expect(it.next().equals(Integer.valueOf(3)));
|
|
it.remove();
|
|
expect(! it.hasNext());
|
|
expect(l.size() == 2);
|
|
|
|
l.add(3);
|
|
|
|
it = l.listIterator(3);
|
|
expect(it.previous().equals(Integer.valueOf(3)));
|
|
it.remove();
|
|
expect(it.previous().equals(Integer.valueOf(2)));
|
|
it.remove();
|
|
expect(it.previous().equals(Integer.valueOf(1)));
|
|
it.remove();
|
|
expect(! it.hasPrevious());
|
|
expect(l.isEmpty());
|
|
|
|
l.add(1);
|
|
l.add(2);
|
|
l.add(3);
|
|
|
|
it = l.listIterator(2);
|
|
expect(it.previous().equals(Integer.valueOf(2)));
|
|
it.remove();
|
|
expect(it.previous().equals(Integer.valueOf(1)));
|
|
it.remove();
|
|
expect(! it.hasPrevious());
|
|
expect(l.size() == 1);
|
|
|
|
l.clear();
|
|
l.add(1);
|
|
l.add(2);
|
|
l.add(3);
|
|
|
|
it = l.listIterator(1);
|
|
expect(it.previous().equals(Integer.valueOf(1)));
|
|
it.remove();
|
|
expect(! it.hasPrevious());
|
|
expect(l.size() == 2);
|
|
}
|
|
|
|
private static void testGrow() {
|
|
ArrayList<Integer> foo = new ArrayList<Integer>(2);
|
|
foo.add(0);
|
|
foo.add(1);
|
|
foo.add(2); // first grow
|
|
foo.add(3);
|
|
foo.add(4); // second grow
|
|
foo.add(5);
|
|
|
|
for (int i = 0; i < foo.size(); i++) {
|
|
expect(i == foo.get(i));
|
|
}
|
|
}
|
|
|
|
private static void testRemove() {
|
|
ArrayList<String> foo = new ArrayList<String>(2);
|
|
foo.add("Uno");
|
|
foo.add("Dos");
|
|
foo.add("Tres");
|
|
foo.add("Cuatro");
|
|
|
|
ArrayList<String> fooToRemove = new ArrayList<String>(2);
|
|
fooToRemove.add(foo.get(0));
|
|
fooToRemove.add(foo.get(1));
|
|
|
|
for (String s : fooToRemove) {
|
|
foo.remove(s);
|
|
}
|
|
|
|
expect(foo.size() == 2);
|
|
}
|
|
|
|
public static void main(String args[]) {
|
|
ArrayList<Integer> l = new ArrayList<Integer>();
|
|
l.add(1); l.add(2); l.add(3); l.add(4); l.add(5);
|
|
isEqual(printList(l), "1, 2, 3, 4, 5");
|
|
l.add(0, 6);
|
|
isEqual(printList(l), "6, 1, 2, 3, 4, 5");
|
|
l.add(2, 7);
|
|
isEqual(printList(l), "6, 1, 7, 2, 3, 4, 5");
|
|
l.remove(1);
|
|
isEqual(printList(l), "6, 7, 2, 3, 4, 5");
|
|
l.add(6, 8);
|
|
isEqual(printList(l), "6, 7, 2, 3, 4, 5, 8");
|
|
Integer[] ints = new Integer[15];
|
|
Integer[] z = l.toArray(ints);
|
|
expect(z == ints);
|
|
for (int i=0; i < z.length; i++) {
|
|
System.out.println(z[i]);
|
|
}
|
|
|
|
testIterators(new ArrayList());
|
|
testIterators(new LinkedList());
|
|
|
|
testIterators2(new ArrayList());
|
|
testIterators2(new LinkedList());
|
|
testGrow();
|
|
testRemove();
|
|
}
|
|
}
|