2016-01-29 11:44:19 -08:00
|
|
|
/*
|
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code 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
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is available under and governed by the GNU General Public
|
|
|
|
* License version 2 only, as published by the Free Software Foundation.
|
|
|
|
* However, the following notice accompanied the original version of this
|
|
|
|
* file:
|
|
|
|
*
|
|
|
|
* Written by Doug Lea with assistance from members of JCP JSR-166
|
|
|
|
* Expert Group and released to the public domain, as explained at
|
|
|
|
* http://creativecommons.org/publicdomain/zero/1.0/
|
|
|
|
* Other contributors include Andrew Wright, Jeffrey Hayes,
|
|
|
|
* Pat Fisher, Mike Judd.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import java.util.AbstractQueue;
|
|
|
|
import java.util.Arrays;
|
|
|
|
import java.util.Iterator;
|
|
|
|
import java.util.NoSuchElementException;
|
|
|
|
|
|
|
|
import junit.framework.Test;
|
|
|
|
import junit.framework.TestSuite;
|
|
|
|
|
|
|
|
public class AbstractQueueTest extends JSR166TestCase {
|
|
|
|
public static void main(String[] args) {
|
|
|
|
main(suite(), args);
|
|
|
|
}
|
|
|
|
public static Test suite() {
|
|
|
|
return new TestSuite(AbstractQueueTest.class);
|
|
|
|
}
|
|
|
|
|
2021-01-28 18:06:55 +00:00
|
|
|
static class Succeed extends AbstractQueue<Item> {
|
|
|
|
public boolean offer(Item x) {
|
2016-01-29 11:44:19 -08:00
|
|
|
if (x == null) throw new NullPointerException();
|
|
|
|
return true;
|
|
|
|
}
|
2021-01-28 18:06:55 +00:00
|
|
|
public Item peek() { return one; }
|
|
|
|
public Item poll() { return one; }
|
2016-01-29 11:44:19 -08:00
|
|
|
public int size() { return 0; }
|
2021-01-28 18:06:55 +00:00
|
|
|
public Iterator<Item> iterator() { return null; } // not needed
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
2021-01-28 18:06:55 +00:00
|
|
|
static class Fail extends AbstractQueue<Item> {
|
|
|
|
public boolean offer(Item x) {
|
2016-01-29 11:44:19 -08:00
|
|
|
if (x == null) throw new NullPointerException();
|
|
|
|
return false;
|
|
|
|
}
|
2021-01-28 18:06:55 +00:00
|
|
|
public Item peek() { return null; }
|
|
|
|
public Item poll() { return null; }
|
2016-01-29 11:44:19 -08:00
|
|
|
public int size() { return 0; }
|
2021-01-28 18:06:55 +00:00
|
|
|
public Iterator<Item> iterator() { return null; } // not needed
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* add returns true if offer succeeds
|
|
|
|
*/
|
|
|
|
public void testAddS() {
|
|
|
|
Succeed q = new Succeed();
|
|
|
|
assertTrue(q.add(two));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-01-16 18:28:39 -08:00
|
|
|
* add throws IllegalStateException if offer fails
|
2016-01-29 11:44:19 -08:00
|
|
|
*/
|
|
|
|
public void testAddF() {
|
|
|
|
Fail q = new Fail();
|
|
|
|
try {
|
|
|
|
q.add(one);
|
|
|
|
shouldThrow();
|
|
|
|
} catch (IllegalStateException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-07-22 09:18:50 -07:00
|
|
|
* add throws NullPointerException if offer does
|
2016-01-29 11:44:19 -08:00
|
|
|
*/
|
|
|
|
public void testAddNPE() {
|
|
|
|
Succeed q = new Succeed();
|
|
|
|
try {
|
|
|
|
q.add(null);
|
|
|
|
shouldThrow();
|
|
|
|
} catch (NullPointerException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* remove returns normally if poll succeeds
|
|
|
|
*/
|
|
|
|
public void testRemoveS() {
|
|
|
|
Succeed q = new Succeed();
|
2018-01-16 18:28:39 -08:00
|
|
|
assertSame(one, q.remove());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* remove throws NSEE if poll returns null
|
|
|
|
*/
|
|
|
|
public void testRemoveF() {
|
|
|
|
Fail q = new Fail();
|
|
|
|
try {
|
|
|
|
q.remove();
|
|
|
|
shouldThrow();
|
|
|
|
} catch (NoSuchElementException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* element returns normally if peek succeeds
|
|
|
|
*/
|
|
|
|
public void testElementS() {
|
|
|
|
Succeed q = new Succeed();
|
2018-01-16 18:28:39 -08:00
|
|
|
assertSame(one, q.element());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* element throws NSEE if peek returns null
|
|
|
|
*/
|
|
|
|
public void testElementF() {
|
|
|
|
Fail q = new Fail();
|
|
|
|
try {
|
|
|
|
q.element();
|
|
|
|
shouldThrow();
|
|
|
|
} catch (NoSuchElementException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-07-22 09:18:50 -07:00
|
|
|
* addAll(null) throws NullPointerException
|
2016-01-29 11:44:19 -08:00
|
|
|
*/
|
|
|
|
public void testAddAll1() {
|
|
|
|
Succeed q = new Succeed();
|
|
|
|
try {
|
|
|
|
q.addAll(null);
|
|
|
|
shouldThrow();
|
|
|
|
} catch (NullPointerException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-07-22 09:18:50 -07:00
|
|
|
* addAll(this) throws IllegalArgumentException
|
2016-01-29 11:44:19 -08:00
|
|
|
*/
|
|
|
|
public void testAddAllSelf() {
|
|
|
|
Succeed q = new Succeed();
|
|
|
|
try {
|
|
|
|
q.addAll(q);
|
|
|
|
shouldThrow();
|
|
|
|
} catch (IllegalArgumentException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-07-22 09:18:50 -07:00
|
|
|
* addAll of a collection with null elements throws NullPointerException
|
2016-01-29 11:44:19 -08:00
|
|
|
*/
|
|
|
|
public void testAddAll2() {
|
|
|
|
Succeed q = new Succeed();
|
2021-01-28 18:06:55 +00:00
|
|
|
Item[] items = new Item[SIZE];
|
2016-01-29 11:44:19 -08:00
|
|
|
try {
|
2021-01-28 18:06:55 +00:00
|
|
|
q.addAll(Arrays.asList(items));
|
2016-01-29 11:44:19 -08:00
|
|
|
shouldThrow();
|
|
|
|
} catch (NullPointerException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* addAll of a collection with any null elements throws NPE after
|
|
|
|
* possibly adding some elements
|
|
|
|
*/
|
|
|
|
public void testAddAll3() {
|
|
|
|
Succeed q = new Succeed();
|
2021-01-28 18:06:55 +00:00
|
|
|
Item[] items = new Item[SIZE];
|
2016-01-29 11:44:19 -08:00
|
|
|
for (int i = 0; i < SIZE - 1; ++i)
|
2021-01-28 18:06:55 +00:00
|
|
|
items[i] = itemFor(i);
|
2016-01-29 11:44:19 -08:00
|
|
|
try {
|
2021-01-28 18:06:55 +00:00
|
|
|
q.addAll(Arrays.asList(items));
|
2016-01-29 11:44:19 -08:00
|
|
|
shouldThrow();
|
|
|
|
} catch (NullPointerException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-07-22 09:18:50 -07:00
|
|
|
* addAll throws IllegalStateException if an add fails
|
2016-01-29 11:44:19 -08:00
|
|
|
*/
|
|
|
|
public void testAddAll4() {
|
|
|
|
Fail q = new Fail();
|
2021-01-28 18:06:55 +00:00
|
|
|
Item[] items = seqItems(SIZE);
|
2016-01-29 11:44:19 -08:00
|
|
|
try {
|
2021-01-28 18:06:55 +00:00
|
|
|
q.addAll(Arrays.asList(items));
|
2016-01-29 11:44:19 -08:00
|
|
|
shouldThrow();
|
|
|
|
} catch (IllegalStateException success) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|