FileDocCategorySizeDatePackage
Support_ListTest.javaAPI DocAndroid 1.5 API9474Wed May 06 22:41:06 BST 2009tests.support

Support_ListTest.java

/* 
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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 tests.support;

import dalvik.annotation.TestTargetClass;

import java.util.LinkedList;
import java.util.List;
import java.util.ListIterator;
import java.util.NoSuchElementException;

@TestTargetClass(List.class)
public class Support_ListTest extends junit.framework.TestCase {

    List<Integer> list; // must contain the Integers 0 to 99 in order

    public Support_ListTest(String p1) {
        super(p1);
    }

    public Support_ListTest(String p1, List<Integer> l) {
        super(p1);
        list = l;
    }

    @Override
    public void runTest() {
        int hashCode = 1;
        for (int counter = 0; counter < 100; counter++) {
            Object elem;
            elem = list.get(counter);
            hashCode = 31 * hashCode + elem.hashCode();
            assertTrue("ListTest - get failed", elem
                    .equals(new Integer(counter)));
        }
        assertTrue("ListTest - hashCode failed", hashCode == list.hashCode());

        list.add(50, new Integer(1000));
        assertTrue("ListTest - a) add with index failed--did not insert", list
                .get(50).equals(new Integer(1000)));
        assertTrue(
                "ListTest - b) add with index failed--did not move following elements",
                list.get(51).equals(new Integer(50)));
        assertTrue(
                "ListTest - c) add with index failed--affected previous elements",
                list.get(49).equals(new Integer(49)));

        list.set(50, new Integer(2000));
        assertTrue("ListTest - a) set failed--did not set", list.get(50)
                .equals(new Integer(2000)));
        assertTrue("ListTest - b) set failed--affected following elements",
                list.get(51).equals(new Integer(50)));
        assertTrue("ListTest - c) set failed--affected previous elements", list
                .get(49).equals(new Integer(49)));

        list.remove(50);
        assertTrue("ListTest - a) remove with index failed--did not remove",
                list.get(50).equals(new Integer(50)));
        assertTrue(
                "ListTest - b) remove with index failed--did not move following elements",
                list.get(51).equals(new Integer(51)));
        assertTrue(
                "ListTest - c) remove with index failed--affected previous elements",
                list.get(49).equals(new Integer(49)));

        List<Integer> myList = new LinkedList<Integer>();
        myList.add(new Integer(500));
        myList.add(new Integer(501));
        myList.add(new Integer(502));

        list.addAll(50, myList);
        assertTrue("ListTest - a) addAll with index failed--did not insert",
                list.get(50).equals(new Integer(500)));
        assertTrue("ListTest - b) addAll with index failed--did not insert",
                list.get(51).equals(new Integer(501)));
        assertTrue("ListTest - c) addAll with index failed--did not insert",
                list.get(52).equals(new Integer(502)));
        assertTrue(
                "ListTest - d) addAll with index failed--did not move following elements",
                list.get(53).equals(new Integer(50)));
        assertTrue(
                "ListTest - e) addAll with index failed--affected previous elements",
                list.get(49).equals(new Integer(49)));

        List<Integer> mySubList = list.subList(50, 53);
        assertEquals(3, mySubList.size());
        assertTrue(
                "ListTest - a) sublist Failed--does not contain correct elements",
                mySubList.get(0).equals(new Integer(500)));
        assertTrue(
                "ListTest - b) sublist Failed--does not contain correct elements",
                mySubList.get(1).equals(new Integer(501)));
        assertTrue(
                "ListTest - c) sublist Failed--does not contain correct elements",
                mySubList.get(2).equals(new Integer(502)));

        t_listIterator(mySubList);

        mySubList.clear();
        assertEquals("ListTest - Clearing the sublist did not remove the appropriate elements from the original list",
                100, list.size());

        t_listIterator(list);
        ListIterator<Integer> li = list.listIterator();
        for (int counter = 0; li.hasNext(); counter++) {
            Object elem;
            elem = li.next();
            assertTrue("ListTest - listIterator failed", elem
                    .equals(new Integer(counter)));
        }

        new Support_CollectionTest("", list).runTest();

    }

    public void t_listIterator(List<Integer> list) {
        ListIterator<Integer> li = list.listIterator(1);
        assertTrue("listIterator(1)", li.next() == list.get(1));

        int orgSize = list.size();
        li = list.listIterator();
        for (int i = 0; i <= orgSize; i++) {
            if (i == 0) {
                assertTrue("list iterator hasPrevious(): " + i, !li
                        .hasPrevious());
            } else {
                assertTrue("list iterator hasPrevious(): " + i, li
                        .hasPrevious());
            }
            if (i == list.size()) {
                assertTrue("list iterator hasNext(): " + i, !li.hasNext());
            } else {
                assertTrue("list iterator hasNext(): " + i, li.hasNext());
            }
            assertTrue("list iterator nextIndex(): " + i, li.nextIndex() == i);
            assertTrue("list iterator previousIndex(): " + i, li
                    .previousIndex() == i - 1);
            boolean exception = false;
            try {
                assertTrue("list iterator next(): " + i, li.next() == list
                        .get(i));
            } catch (NoSuchElementException e) {
                exception = true;
            }
            if (i == list.size()) {
                assertTrue("list iterator next() exception: " + i, exception);
            } else {
                assertTrue("list iterator next() exception: " + i, !exception);
            }
        }

        for (int i = orgSize - 1; i >= 0; i--) {
            assertTrue("list iterator previous(): " + i, li.previous() == list
                    .get(i));
            assertTrue("list iterator nextIndex()2: " + i, li.nextIndex() == i);
            assertTrue("list iterator previousIndex()2: " + i, li
                    .previousIndex() == i - 1);
            if (i == 0) {
                assertTrue("list iterator hasPrevious()2: " + i, !li
                        .hasPrevious());
            } else {
                assertTrue("list iterator hasPrevious()2: " + i, li
                        .hasPrevious());
            }
            assertTrue("list iterator hasNext()2: " + i, li.hasNext());
        }
        boolean exception = false;
        try {
            li.previous();
        } catch (NoSuchElementException e) {
            exception = true;
        }
        assertTrue("list iterator previous() exception", exception);

        Integer add1 = new Integer(600);
        Integer add2 = new Integer(601);
        li.add(add1);
        assertTrue("list iterator add(), size()", list.size() == (orgSize + 1));
        assertEquals("list iterator add(), nextIndex()", 1, li.nextIndex());
        assertEquals("list iterator add(), previousIndex()",
                0, li.previousIndex());
        Object next = li.next();
        assertTrue("list iterator add(), next(): " + next, next == list.get(1));
        li.add(add2);
        Object previous = li.previous();
        assertTrue("list iterator add(), previous(): " + previous,
                previous == add2);
        assertEquals("list iterator add(), nextIndex()2", 2, li.nextIndex());
        assertEquals("list iterator add(), previousIndex()2",
                1, li.previousIndex());

        li.remove();
        assertTrue("list iterator remove(), size()",
                list.size() == (orgSize + 1));
        assertEquals("list iterator remove(), nextIndex()", 2, li.nextIndex());
        assertEquals("list iterator remove(), previousIndex()", 1, li
                .previousIndex());
        assertTrue("list iterator previous()2", li.previous() == list.get(1));
        assertTrue("list iterator previous()3", li.previous() == list.get(0));
        assertTrue("list iterator next()2", li.next() == list.get(0));
        li.remove();
        assertTrue("list iterator hasPrevious()3", !li.hasPrevious());
        assertTrue("list iterator hasNext()3", li.hasNext());
        assertTrue("list iterator size()", list.size() == orgSize);
        assertEquals("list iterator nextIndex()3", 0, li.nextIndex());
        assertEquals("list iterator previousIndex()3", -1, li.previousIndex());
    }
}