package org.jctools.queues.atomic;
import org.jctools.queues.QueueSanityTest;
import org.jctools.queues.spec.ConcurrentQueueSpec;
import org.jctools.queues.spec.Ordering;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Queue;
import static org.jctools.util.JvmInfo.CPUs;
@RunWith(Parameterized.class)
public class AtomicQueueSanityTest extends QueueSanityTest {
@Parameterized.Parameters
public static Collection<Object[]> parameters() {
ArrayList<Object[]> list = new ArrayList<Object[]>();
list.add(makeAtomic(1, 1, 1, Ordering.FIFO, null));
list.add(makeAtomic(1, 1, 0, Ordering.FIFO, null));
list.add(makeAtomic(1, 1, SIZE, Ordering.FIFO, null));
// list.add(test(1, 1, 16, Ordering.FIFO, new SpscGrowableArrayQueue<Integer>(4, 16)));
list.add(makeAtomic(1, 1, 0, Ordering.FIFO, new SpscUnboundedAtomicArrayQueue<Integer>(16)));
list.add(makeAtomic(1, 0, 1, Ordering.FIFO, null));
list.add(makeAtomic(1, 0, SIZE, Ordering.FIFO, null));
list.add(makeAtomic(0, 1, 0, Ordering.FIFO, null));
list.add(makeAtomic(0, 1, 1, Ordering.FIFO, null));
list.add(makeAtomic(0, 1, SIZE, Ordering.FIFO, null));
list.add(makeAtomic(0, 1, 1, Ordering.PRODUCER_FIFO, null));
list.add(makeAtomic(0, 1, SIZE, Ordering.PRODUCER_FIFO, null));
// Compound queue minimal size is the core count
list.add(makeAtomic(0, 1, CPUs, Ordering.NONE, null));
list.add(makeAtomic(0, 1, SIZE, Ordering.NONE, null));
// Mpmc minimal size is 2
list.add(makeAtomic(0, 0, 2, Ordering.FIFO, null));
list.add(makeAtomic(0, 0, SIZE, Ordering.FIFO, null));
return list;
}
public AtomicQueueSanityTest(ConcurrentQueueSpec spec, Queue<Integer> queue) {
super(spec, queue);
}
}