--- jsr166/src/test/tck/AtomicReferenceArray9Test.java 2016/06/17 19:00:48 1.1 +++ jsr166/src/test/tck/AtomicReferenceArray9Test.java 2016/10/11 20:38:07 1.3 @@ -4,7 +4,6 @@ * http://creativecommons.org/publicdomain/zero/1.0/ */ -import java.util.Arrays; import java.util.concurrent.atomic.AtomicReferenceArray; import junit.framework.Test; @@ -35,6 +34,7 @@ public class AtomicReferenceArray9Test e () -> aa.compareAndExchange(j, null, null), () -> aa.compareAndExchangeAcquire(j, null, null), () -> aa.compareAndExchangeRelease(j, null, null), + () -> aa.weakCompareAndSetPlain(j, null, null), () -> aa.weakCompareAndSetVolatile(j, null, null), () -> aa.weakCompareAndSetAcquire(j, null, null), () -> aa.weakCompareAndSetRelease(j, null, null), @@ -187,6 +187,22 @@ public class AtomicReferenceArray9Test e assertEquals(seven, aa.get(i)); } } + + /** + * repeated weakCompareAndSetPlain succeeds in changing value when equal + * to expected + */ + public void testWeakCompareAndSetPlain() { + AtomicReferenceArray aa = new AtomicReferenceArray<>(SIZE); + for (int i = 0; i < SIZE; i++) { + aa.set(i, one); + do {} while (!aa.weakCompareAndSetPlain(i, one, two)); + do {} while (!aa.weakCompareAndSetPlain(i, two, m4)); + assertEquals(m4, aa.get(i)); + do {} while (!aa.weakCompareAndSetPlain(i, m4, seven)); + assertEquals(seven, aa.get(i)); + } + } /** * repeated weakCompareAndSetVolatile succeeds in changing value when equal