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:
parent
775f3598fd
commit
597f6553d0
|
@ -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();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue