1 /*
2  * Written by Doug Lea with assistance from members of JCP JSR-166
3  * Expert Group and released to the public domain, as explained at
4  * http://creativecommons.org/publicdomain/zero/1.0/
5  * Other contributors include Andrew Wright, Jeffrey Hayes,
6  * Pat Fisher, Mike Judd.
7  */
8 
9 package jsr166;
10 
11 import java.util.AbstractQueue;
12 import java.util.Arrays;
13 import java.util.Iterator;
14 import java.util.NoSuchElementException;
15 
16 import junit.framework.Test;
17 import junit.framework.TestSuite;
18 
19 public class AbstractQueueTest extends JSR166TestCase {
20     // android-note: Removed because the CTS runner does a bad job of
21     // retrying tests that have suite() declarations.
22     //
23     // public static void main(String[] args) {
24     //     main(suite(), args);
25     // }
26     // public static Test suite() {
27     //     return new TestSuite(AbstractQueueTest.class);
28     // }
29 
30     static class Succeed extends AbstractQueue<Integer> {
offer(Integer x)31         public boolean offer(Integer x) {
32             if (x == null) throw new NullPointerException();
33             return true;
34         }
peek()35         public Integer peek() { return one; }
poll()36         public Integer poll() { return one; }
size()37         public int size() { return 0; }
iterator()38         public Iterator iterator() { return null; } // not needed
39     }
40 
41     static class Fail extends AbstractQueue<Integer> {
offer(Integer x)42         public boolean offer(Integer x) {
43             if (x == null) throw new NullPointerException();
44             return false;
45         }
peek()46         public Integer peek() { return null; }
poll()47         public Integer poll() { return null; }
size()48         public int size() { return 0; }
iterator()49         public Iterator iterator() { return null; } // not needed
50     }
51 
52     /**
53      * add returns true if offer succeeds
54      */
testAddS()55     public void testAddS() {
56         Succeed q = new Succeed();
57         assertTrue(q.add(two));
58     }
59 
60     /**
61      * add throws ISE true if offer fails
62      */
testAddF()63     public void testAddF() {
64         Fail q = new Fail();
65         try {
66             q.add(one);
67             shouldThrow();
68         } catch (IllegalStateException success) {}
69     }
70 
71     /**
72      * add throws NPE if offer does
73      */
testAddNPE()74     public void testAddNPE() {
75         Succeed q = new Succeed();
76         try {
77             q.add(null);
78             shouldThrow();
79         } catch (NullPointerException success) {}
80     }
81 
82     /**
83      * remove returns normally if poll succeeds
84      */
testRemoveS()85     public void testRemoveS() {
86         Succeed q = new Succeed();
87         q.remove();
88     }
89 
90     /**
91      * remove throws NSEE if poll returns null
92      */
testRemoveF()93     public void testRemoveF() {
94         Fail q = new Fail();
95         try {
96             q.remove();
97             shouldThrow();
98         } catch (NoSuchElementException success) {}
99     }
100 
101     /**
102      * element returns normally if peek succeeds
103      */
testElementS()104     public void testElementS() {
105         Succeed q = new Succeed();
106         q.element();
107     }
108 
109     /**
110      * element throws NSEE if peek returns null
111      */
testElementF()112     public void testElementF() {
113         Fail q = new Fail();
114         try {
115             q.element();
116             shouldThrow();
117         } catch (NoSuchElementException success) {}
118     }
119 
120     /**
121      * addAll(null) throws NPE
122      */
testAddAll1()123     public void testAddAll1() {
124         Succeed q = new Succeed();
125         try {
126             q.addAll(null);
127             shouldThrow();
128         } catch (NullPointerException success) {}
129     }
130 
131     /**
132      * addAll(this) throws IAE
133      */
testAddAllSelf()134     public void testAddAllSelf() {
135         Succeed q = new Succeed();
136         try {
137             q.addAll(q);
138             shouldThrow();
139         } catch (IllegalArgumentException success) {}
140     }
141 
142     /**
143      * addAll of a collection with null elements throws NPE
144      */
testAddAll2()145     public void testAddAll2() {
146         Succeed q = new Succeed();
147         Integer[] ints = new Integer[SIZE];
148         try {
149             q.addAll(Arrays.asList(ints));
150             shouldThrow();
151         } catch (NullPointerException success) {}
152     }
153 
154     /**
155      * addAll of a collection with any null elements throws NPE after
156      * possibly adding some elements
157      */
testAddAll3()158     public void testAddAll3() {
159         Succeed q = new Succeed();
160         Integer[] ints = new Integer[SIZE];
161         for (int i = 0; i < SIZE - 1; ++i)
162             ints[i] = Integer.valueOf(i);
163         try {
164             q.addAll(Arrays.asList(ints));
165             shouldThrow();
166         } catch (NullPointerException success) {}
167     }
168 
169     /**
170      * addAll throws ISE if an add fails
171      */
testAddAll4()172     public void testAddAll4() {
173         Fail q = new Fail();
174         Integer[] ints = new Integer[SIZE];
175         for (int i = 0; i < SIZE; ++i)
176             ints[i] = Integer.valueOf(i);
177         try {
178             q.addAll(Arrays.asList(ints));
179             shouldThrow();
180         } catch (IllegalStateException success) {}
181     }
182 
183 }
184