Package gnu.trove.list.array

Source Code of gnu.trove.list.array.TArrayListTest

///////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2001, Eric D. Friedman All Rights Reserved.
// Copyright (c) 2009, Rob Eden All Rights Reserved.
// Copyright (c) 2009, Jeff Randall All Rights Reserved.
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
///////////////////////////////////////////////////////////////////////////////

package gnu.trove.list.array;

import gnu.trove.TCollections;
import gnu.trove.list.TIntList;
import gnu.trove.list.TLongList;
import junit.framework.TestCase;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.Arrays;


public class TArrayListTest extends TestCase {

    private TIntList list;


    public void setUp() throws Exception {
        super.setUp();

        list = new TIntArrayList(15, Integer.MIN_VALUE);
        list.add(1);
        list.add(2);
        list.add(3);
        list.add(4);
        list.add(5);
    }


    public void tearDown() throws Exception {
        super.tearDown();
    }


    public void testToArray() {
        assertTrue(Arrays.equals(new int[]{1, 2, 3, 4, 5}, list.toArray()));
        assertTrue(Arrays.equals(new int[]{1, 2, 3, 4}, list.toArray(0, 4)));
        assertTrue(Arrays.equals(new int[]{2, 3, 4, 5}, list.toArray(1, 4)));
        assertTrue(Arrays.equals(new int[]{2, 3, 4}, list.toArray(1, 3)));

        int[] array_correct_size = new int[5];
        list.toArray(array_correct_size);
        assertEquals(1, array_correct_size[0]);
        assertEquals(2, array_correct_size[1]);
        assertEquals(3, array_correct_size[2]);
        assertEquals(4, array_correct_size[3]);
        assertEquals(5, array_correct_size[4]);
        assertEquals(array_correct_size.length, list.size());

        int[] array_too_long = new int[8];
        list.toArray(array_too_long);
        assertEquals(1, array_too_long[0]);
        assertEquals(2, array_too_long[1]);
        assertEquals(3, array_too_long[2]);
        assertEquals(4, array_too_long[3]);
        assertEquals(5, array_too_long[4]);
        assertEquals(list.getNoEntryValue(), array_too_long[5]);

        int[] array_too_short = new int[2];
        list.toArray(array_too_short);
        assertEquals(1, array_too_short[0]);
        assertEquals(2, array_too_short[1]);
    }


    public void testSubList() throws Exception {
        TIntList subList = list.subList(1, 4);
        assertEquals(3, subList.size());
        assertEquals(2, subList.get(0));
        assertEquals(4, subList.get(2));
    }


    public void testSublist_Exceptions() {
        try {
            list.subList(1, 0);
            fail("expected IllegalArgumentException when end < begin");
        } catch (IllegalArgumentException expected) {
        }

        try {
            list.subList(-1, 3);
            fail("expected IndexOutOfBoundsException when begin < 0");
        } catch (IndexOutOfBoundsException expected) {
        }

        try {
            list.subList(1, 42);
            fail("expected IndexOutOfBoundsException when end > length");
        } catch (IndexOutOfBoundsException expected) {
        }
    }


    public void testMax() {
        assertEquals(5, list.max());
        assertEquals(1, list.min());

        TIntArrayList list2 = new TIntArrayList();
        list2.add(3);
        list2.add(1);
        list2.add(2);
        list2.add(5);
        list2.add(4);
        assertEquals(5, list2.max());
        assertEquals(1, list2.min());
    }


    public void testSerialization() throws Exception {
        ByteArrayOutputStream bout = new ByteArrayOutputStream();
        ObjectOutputStream oout = new ObjectOutputStream(bout);
        oout.writeObject(list);
        oout.close();

        ObjectInputStream oin = new ObjectInputStream(
                new ByteArrayInputStream(bout.toByteArray()));

        TIntArrayList new_list = (TIntArrayList) oin.readObject();

        assertEquals(list, new_list);
    }


    // From bug 3077245
    public void testInvalidStartRemoveZeroLength() {
        try {
            TIntArrayList bug = new TIntArrayList();
            bug.remove(0, 0);
        } catch (ArrayIndexOutOfBoundsException ex) {
            ex.printStackTrace();
            fail("Shouldn't raise exception");
        }
    }


    // From bug 3197201
    public void testListRemove() {
        // Remove by value
        TIntArrayList list = new TIntArrayList();
        list.add(0);
        list.add(1);
        list.add(2);

        list.remove(1);

        assertEquals(2, list.size());
        assertEquals(0, list.get(0));
        assertEquals(2, list.get(1));


        // Remove by position with range
        list = new TIntArrayList();
        list.add(0);
        list.add(1);
        list.add(2);

        list.remove(1, 1);

        assertEquals(2, list.size());
        assertEquals(0, list.get(0));
        assertEquals(2, list.get(1));


        // Remove by position, no range
        list = new TIntArrayList();
        list.add(0);
        list.add(1);
        list.add(2);

        list.removeAt(1);

        assertEquals(2, list.size());
        assertEquals(0, list.get(0));
        assertEquals(2, list.get(1));


        // Remove by value (ensure no collision)
        list = new TIntArrayList();
        list.add(10);
        list.add(11);
        list.add(12);

        list.remove(11);

        assertEquals(2, list.size());
        assertEquals(10, list.get(0));
        assertEquals(12, list.get(1));
    }


    public void testSum() {
        TIntList list = new TIntArrayList();
        assertEquals(0, list.sum());

        list.add(1);
        assertEquals(1, list.sum());

        list.add(1234);
        assertEquals(1235, list.sum());

        list.removeAt(0);
        assertEquals(1234, list.sum());

        list.clear();
        assertEquals(0, list.sum());
    }

    public void testBinarySearch() {
        System.out.println("Java version: " + System.getProperty("java.version"));
        TIntList list;
        for (int i = 0; i <= 100000; i++) {
            if ((i % 100) == 0) {
                System.out.print(i);
                System.out.print(" ");
            }

            list = new TIntArrayList(i);
            list.add(5);
            list.binarySearch(6);
        }

        list = new TIntArrayList();
        list.add(5);

        assertEquals(-1, list.binarySearch(Integer.MIN_VALUE));
        assertEquals(-1, list.binarySearch(-1));
        assertEquals(-1, list.binarySearch(0));
        assertEquals(-1, list.binarySearch(1));
        assertEquals(-1, list.binarySearch(2));
        assertEquals(-1, list.binarySearch(3));
        assertEquals(-1, list.binarySearch(4));

        assertEquals(0, list.binarySearch(5));

        assertEquals(-2, list.binarySearch(6));
    }

    public void testListWrapExpand() {
        // Remove by value
        TIntArrayList list = TIntArrayList.wrap(new int[]{1, 0, 2});
        try {
            list.add(0);
            fail();
        } catch (Exception expected) {

        }
    }

    public void testListWrap() {
        // Remove by value
        TIntArrayList list = TIntArrayList.wrap(new int[]{1, 0, 2});

        list.remove(1);

        assertEquals(2, list.size());
        assertEquals(0, list.get(0));
        assertEquals(2, list.get(1));

        list.add(1);
        assertEquals(3, list.size());
        assertEquals(0, list.get(0));
        assertEquals(2, list.get(1));
        assertEquals(1, list.get(2));

        list.fill(5);
        assertEquals(3, list.size());
        assertEquals(5, list.get(0));
        assertEquals(5, list.get(1));
        assertEquals(5, list.get(2));
    }

    public void test3448111() throws Exception {
        TIntArrayList i = new TIntArrayList();
        i.add(1);
        i.add(2);
        i.add(3);
        i.add(4);

        int[] a = new int[]{1, 2, 3};
        i.retainAll(a);
    }

  public void testIntUnmodifiableEquality() {
    TIntList list1 = new TIntArrayList();
    TIntList list2 = new TIntArrayList();

    assertEquals( list1, list2 );
    assertEquals( list1, TCollections.unmodifiableList( list2 ) );
    assertEquals( TCollections.unmodifiableList( list1 ), list2 );
    assertEquals( TCollections.unmodifiableList( list1 ),
      TCollections.unmodifiableList( list2 ) );

    list1.add( 1 );
    list1.add( 2 );
    list1.add( 3 );

    list2.add( 1 );
    list2.add( 2 );
    list2.add( 3 );

    assertEquals( list1, list2 );
    assertEquals( list1, TCollections.unmodifiableList( list2 ) );
    assertEquals( TCollections.unmodifiableList( list1 ), list2 );
    assertEquals( TCollections.unmodifiableList( list1 ),
      TCollections.unmodifiableList( list2 ) );
  }

  public void testLongUnmodifiableEquality() {
    TLongList list1 = new TLongArrayList();
    TLongList list2 = new TLongArrayList();

    assertEquals( list1, list2 );
    assertEquals( list1, TCollections.unmodifiableList( list2 ) );
    assertEquals( TCollections.unmodifiableList( list1 ), list2 );
    assertEquals( TCollections.unmodifiableList( list1 ),
      TCollections.unmodifiableList( list2 ) );

    list1.add( 1 );
    list1.add( 2 );
    list1.add( 3 );

    list2.add( 1 );
    list2.add( 2 );
    list2.add( 3 );

    assertEquals( list1, list2 );
    assertEquals( list1, TCollections.unmodifiableList( list2 ) );
    assertEquals( TCollections.unmodifiableList( list1 ), list2 );
    assertEquals( TCollections.unmodifiableList( list1 ),
      TCollections.unmodifiableList( list2 ) );
  }
}
TOP

Related Classes of gnu.trove.list.array.TArrayListTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.