ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/src/test/tck/AtomicMarkableReferenceTest.java
Revision: 1.10
Committed: Tue Nov 17 03:12:51 2009 UTC (14 years, 6 months ago) by jsr166
Branch: MAIN
Changes since 1.9: +16 -24 lines
Log Message:
nicer exception handling

File Contents

# Content
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/licenses/publicdomain
5 * Other contributors include Andrew Wright, Jeffrey Hayes,
6 * Pat Fisher, Mike Judd.
7 */
8
9 import junit.framework.*;
10 import java.util.concurrent.atomic.*;
11
12 public class AtomicMarkableReferenceTest extends JSR166TestCase {
13 public static void main (String[] args) {
14 junit.textui.TestRunner.run (suite());
15 }
16 public static Test suite() {
17 return new TestSuite(AtomicMarkableReferenceTest.class);
18 }
19
20 /**
21 * constructor initializes to given reference and mark
22 */
23 public void testConstructor() {
24 AtomicMarkableReference ai = new AtomicMarkableReference(one, false);
25 assertEquals(one,ai.getReference());
26 assertFalse(ai.isMarked());
27 AtomicMarkableReference a2 = new AtomicMarkableReference(null, true);
28 assertNull(a2.getReference());
29 assertTrue(a2.isMarked());
30
31 }
32
33 /**
34 * get returns the last values of reference and mark set
35 */
36 public void testGetSet() {
37 boolean[] mark = new boolean[1];
38 AtomicMarkableReference ai = new AtomicMarkableReference(one, false);
39 assertEquals(one,ai.getReference());
40 assertFalse(ai.isMarked());
41 assertEquals(one, ai.get(mark));
42 assertFalse(mark[0]);
43 ai.set(two, false);
44 assertEquals(two,ai.getReference());
45 assertFalse(ai.isMarked());
46 assertEquals(two, ai.get(mark));
47 assertFalse(mark[0]);
48 ai.set(one, true);
49 assertEquals(one,ai.getReference());
50 assertTrue(ai.isMarked());
51 assertEquals(one, ai.get(mark));
52 assertTrue(mark[0]);
53 }
54
55 /**
56 * attemptMark succeeds in single thread
57 */
58 public void testAttemptMark() {
59 boolean[] mark = new boolean[1];
60 AtomicMarkableReference ai = new AtomicMarkableReference(one, false);
61 assertFalse(ai.isMarked());
62 assertTrue(ai.attemptMark(one, true));
63 assertTrue(ai.isMarked());
64 assertEquals(one, ai.get(mark));
65 assertTrue(mark[0]);
66 }
67
68 /**
69 * compareAndSet succeeds in changing values if equal to expected reference
70 * and mark else fails
71 */
72 public void testCompareAndSet() {
73 boolean[] mark = new boolean[1];
74 AtomicMarkableReference ai = new AtomicMarkableReference(one, false);
75 assertEquals(one, ai.get(mark));
76 assertFalse(ai.isMarked());
77 assertFalse(mark[0]);
78
79 assertTrue(ai.compareAndSet(one, two, false, false));
80 assertEquals(two, ai.get(mark));
81 assertFalse(mark[0]);
82
83 assertTrue(ai.compareAndSet(two, m3, false, true));
84 assertEquals(m3, ai.get(mark));
85 assertTrue(mark[0]);
86
87 assertFalse(ai.compareAndSet(two, m3, true, true));
88 assertEquals(m3, ai.get(mark));
89 assertTrue(mark[0]);
90 }
91
92 /**
93 * compareAndSet in one thread enables another waiting for reference value
94 * to succeed
95 */
96 public void testCompareAndSetInMultipleThreads() throws Exception {
97 final AtomicMarkableReference ai = new AtomicMarkableReference(one, false);
98 Thread t = new Thread(new Runnable() {
99 public void run() {
100 while (!ai.compareAndSet(two, three, false, false)) Thread.yield();
101 }});
102
103 t.start();
104 assertTrue(ai.compareAndSet(one, two, false, false));
105 t.join(LONG_DELAY_MS);
106 assertFalse(t.isAlive());
107 assertEquals(ai.getReference(), three);
108 assertFalse(ai.isMarked());
109 }
110
111 /**
112 * compareAndSet in one thread enables another waiting for mark value
113 * to succeed
114 */
115 public void testCompareAndSetInMultipleThreads2() throws Exception {
116 final AtomicMarkableReference ai = new AtomicMarkableReference(one, false);
117 Thread t = new Thread(new Runnable() {
118 public void run() {
119 while (!ai.compareAndSet(one, one, true, false)) Thread.yield();
120 }});
121
122 t.start();
123 assertTrue(ai.compareAndSet(one, one, false, true));
124 t.join(LONG_DELAY_MS);
125 assertFalse(t.isAlive());
126 assertEquals(ai.getReference(), one);
127 assertFalse(ai.isMarked());
128 }
129
130 /**
131 * repeated weakCompareAndSet succeeds in changing values when equal
132 * to expected
133 */
134 public void testWeakCompareAndSet() {
135 boolean[] mark = new boolean[1];
136 AtomicMarkableReference ai = new AtomicMarkableReference(one, false);
137 assertEquals(one, ai.get(mark));
138 assertFalse(ai.isMarked());
139 assertFalse(mark[0]);
140
141 while (!ai.weakCompareAndSet(one, two, false, false));
142 assertEquals(two, ai.get(mark));
143 assertFalse(mark[0]);
144
145 while (!ai.weakCompareAndSet(two, m3, false, true));
146 assertEquals(m3, ai.get(mark));
147 assertTrue(mark[0]);
148 }
149
150 }