⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 abstractpriorityqueuetestcase.java

📁 BOOK:Beginning Algorithms Code Examples
💻 JAVA
字号:
package com.wrox.algorithms.queues;import junit.framework.TestCase;import com.wrox.algorithms.sorting.NaturalComparator;import com.wrox.algorithms.sorting.Comparator;/** * Abstract base class for testing implementations of LIFO {@link com.wrox.algorithms.queues.Queue}s. * */public abstract class AbstractPriorityQueueTestCase extends TestCase {    private static final String VALUE_A = "A";    private static final String VALUE_B = "B";    private static final String VALUE_C = "C";    private static final String VALUE_D = "D";    private static final String VALUE_E = "E";    private Queue _queue;    protected void setUp() throws Exception {        super.setUp();        _queue = createQueue(NaturalComparator.INSTANCE);    }    protected void tearDown() throws Exception {        _queue = null;        super.tearDown();    }    protected abstract Queue createQueue(Comparator comparable);    public void testAccessAnEmptyQueue() {        assertEquals(0, _queue.size());        assertTrue(_queue.isEmpty());        try {            _queue.dequeue();            fail();        } catch (EmptyQueueException e) {            // expected        }    }    public void testEnqueueDequeue() {        _queue.enqueue(VALUE_B);        _queue.enqueue(VALUE_D);        _queue.enqueue(VALUE_A);        assertEquals(3, _queue.size());        assertFalse(_queue.isEmpty());        assertSame(VALUE_D, _queue.dequeue());        assertEquals(2, _queue.size());        assertFalse(_queue.isEmpty());        assertSame(VALUE_B, _queue.dequeue());        assertEquals(1, _queue.size());        assertFalse(_queue.isEmpty());        _queue.enqueue(VALUE_E);        _queue.enqueue(VALUE_C);        assertEquals(3, _queue.size());        assertFalse(_queue.isEmpty());        assertSame(VALUE_E, _queue.dequeue());        assertEquals(2, _queue.size());        assertFalse(_queue.isEmpty());        assertSame(VALUE_C, _queue.dequeue());        assertEquals(1, _queue.size());        assertFalse(_queue.isEmpty());        assertSame(VALUE_A, _queue.dequeue());        assertEquals(0, _queue.size());        assertTrue(_queue.isEmpty());    }    public void testClear() {        _queue.enqueue(VALUE_A);        _queue.enqueue(VALUE_B);        _queue.enqueue(VALUE_C);        assertFalse(_queue.isEmpty());        _queue.clear();        assertTrue(_queue.isEmpty());    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -