Add isSetSupported test to allow for immutable Lists

from Rich Dougherty, bug fix 15128


git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/collections/trunk@130967 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Stephen Colebourne 2003-01-25 12:55:43 +00:00
parent 775f3598fd
commit 597f6553d0
1 changed files with 48 additions and 13 deletions

View File

@ -1,13 +1,10 @@
/* /*
* $Header: /home/jerenkrantz/tmp/commons/commons-convert/cvs/home/cvs/jakarta-commons//collections/src/test/org/apache/commons/collections/Attic/TestList.java,v 1.14 2002/11/07 21:32:36 bayard Exp $ * $Header: /home/jerenkrantz/tmp/commons/commons-convert/cvs/home/cvs/jakarta-commons//collections/src/test/org/apache/commons/collections/Attic/TestList.java,v 1.15 2003/01/25 12:55:43 scolebourne Exp $
* $Revision: 1.14 $
* $Date: 2002/11/07 21:32:36 $
*
* ==================================================================== * ====================================================================
* *
* The Apache Software License, Version 1.1 * The Apache Software License, Version 1.1
* *
* Copyright (c) 1999-2001 The Apache Software Foundation. All rights * Copyright (c) 1999-2003 The Apache Software Foundation. All rights
* reserved. * reserved.
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
@ -23,11 +20,11 @@
* distribution. * distribution.
* *
* 3. The end-user documentation included with the redistribution, if * 3. The end-user documentation included with the redistribution, if
* any, must include the following acknowlegement: * any, must include the following acknowledgment:
* "This product includes software developed by the * "This product includes software developed by the
* Apache Software Foundation (http://www.apache.org/)." * Apache Software Foundation (http://www.apache.org/)."
* Alternately, this acknowlegement may appear in the software itself, * Alternately, this acknowledgment may appear in the software itself,
* if and wherever such third-party acknowlegements normally appear. * if and wherever such third-party acknowledgments normally appear.
* *
* 4. The names "The Jakarta Project", "Commons", and "Apache Software * 4. The names "The Jakarta Project", "Commons", and "Apache Software
* Foundation" must not be used to endorse or promote products derived * Foundation" must not be used to endorse or promote products derived
@ -36,7 +33,7 @@
* *
* 5. Products derived from this software may not be called "Apache" * 5. Products derived from this software may not be called "Apache"
* nor may "Apache" appear in their names without prior written * nor may "Apache" appear in their names without prior written
* permission of the Apache Group. * permission of the Apache Software Foundation.
* *
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
@ -58,7 +55,6 @@
* <http://www.apache.org/>. * <http://www.apache.org/>.
* *
*/ */
package org.apache.commons.collections; package org.apache.commons.collections;
import java.io.IOException; import java.io.IOException;
@ -76,7 +72,6 @@ import java.util.List;
import java.util.ListIterator; import java.util.ListIterator;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
/** /**
* Tests base {@link java.util.List} methods and contracts. * Tests base {@link java.util.List} methods and contracts.
* <p> * <p>
@ -87,9 +82,11 @@ import java.util.NoSuchElementException;
* you may still use this base set of cases. Simply override the * you may still use this base set of cases. Simply override the
* test case (method) your {@link List} fails. * test case (method) your {@link List} fails.
* *
* @version $Revision: 1.15 $ $Date: 2003/01/25 12:55:43 $
*
* @author Rodney Waldhoff * @author Rodney Waldhoff
* @author Paul Jack * @author Paul Jack
* @version $Id: TestList.java,v 1.14 2002/11/07 21:32:36 bayard Exp $ * @author Stephen Colebourne
*/ */
public abstract class TestList extends TestCollection { public abstract class TestList extends TestCollection {
@ -140,6 +137,18 @@ public abstract class TestList extends TestCollection {
} }
/**
* Returns true if the collections produced by
* {@link #makeCollection()} and {@link #makeFullCollection()}
* support the <code>set</code> operation.<p>
* Default implementation returns true. Override if your collection
* class does not support set.
*/
protected boolean isSetSupported() {
return true;
}
/** /**
* Returns the {@link collection} field cast to a {@link List}. * Returns the {@link collection} field cast to a {@link List}.
* *
@ -496,6 +505,8 @@ public abstract class TestList extends TestCollection {
* empty list. * empty list.
*/ */
public void testListSetByIndexBoundsChecking() { public void testListSetByIndexBoundsChecking() {
if (!isSetSupported()) return;
List list = makeEmptyList(); List list = makeEmptyList();
Object element = getOtherElements()[0]; Object element = getOtherElements()[0];
@ -543,6 +554,8 @@ public abstract class TestList extends TestCollection {
* full list. * full list.
*/ */
public void testListSetByIndexBoundsChecking2() { public void testListSetByIndexBoundsChecking2() {
if (!isSetSupported()) return;
List list = makeFullList(); List list = makeFullList();
Object element = getOtherElements()[0]; Object element = getOtherElements()[0];
@ -582,6 +595,8 @@ public abstract class TestList extends TestCollection {
* Test {@link List#set(int,Object)}. * Test {@link List#set(int,Object)}.
*/ */
public void testListSetByIndex() { public void testListSetByIndex() {
if (!isSetSupported()) return;
resetFull(); resetFull();
Object[] elements = getFullElements(); Object[] elements = getFullElements();
Object[] other = getOtherElements(); Object[] other = getOtherElements();
@ -596,6 +611,26 @@ public abstract class TestList extends TestCollection {
} }
/**
* If {@link #isSetSupported()} returns false, tests that set operation
* raises <Code>UnsupportedOperationException.
*/
public void testUnsupportedSet() {
if (isSetSupported()) return;
resetFull();
try {
((List) collection).set(0, new Object());
fail("Emtpy collection should not support set.");
} catch (UnsupportedOperationException e) {
// expected
}
// make sure things didn't change even if the expected exception was
// thrown.
verify();
}
/** /**
* Tests bounds checking for {@link List#remove(int)} on an * Tests bounds checking for {@link List#remove(int)} on an
* empty list. * empty list.
@ -834,7 +869,7 @@ public abstract class TestList extends TestCollection {
* iterator. * iterator.
*/ */
public void testListIteratorSet() { public void testListIteratorSet() {
if (!isAddSupported()) return; if (!isSetSupported()) return;
Object[] elements = getFullElements(); Object[] elements = getFullElements();