/tests/ZendTest/Stdlib/PriorityQueueTest.php

https://github.com/cgmartin/zf2 · PHP · 164 lines · 126 code · 25 blank · 13 comment · 3 complexity · dc7735ae99914a3ac9d12a877f7ef0ab MD5 · raw file

  1. <?php
  2. /**
  3. * Zend Framework (http://framework.zend.com/)
  4. *
  5. * @link http://github.com/zendframework/zf2 for the canonical source repository
  6. * @copyright Copyright (c) 2005-2013 Zend Technologies USA Inc. (http://www.zend.com)
  7. * @license http://framework.zend.com/license/new-bsd New BSD License
  8. */
  9. namespace ZendTest\Stdlib;
  10. use Zend\Stdlib\PriorityQueue;
  11. /**
  12. * @group Zend_Stdlib
  13. */
  14. class PriorityQueueTest extends \PHPUnit_Framework_TestCase
  15. {
  16. /**
  17. * @var PriorityQueue
  18. */
  19. protected $queue;
  20. public function setUp()
  21. {
  22. $this->queue = new PriorityQueue();
  23. $this->queue->insert('foo', 3);
  24. $this->queue->insert('bar', 4);
  25. $this->queue->insert('baz', 2);
  26. $this->queue->insert('bat', 1);
  27. }
  28. public function testSerializationAndDeserializationShouldMaintainState()
  29. {
  30. $s = serialize($this->queue);
  31. $unserialized = unserialize($s);
  32. $count = count($this->queue);
  33. $this->assertSame($count, count($unserialized), 'Expected count ' . $count . '; received ' . count($unserialized));
  34. $expected = array();
  35. foreach ($this->queue as $item) {
  36. $expected[] = $item;
  37. }
  38. $test = array();
  39. foreach ($unserialized as $item) {
  40. $test[] = $item;
  41. }
  42. $this->assertSame($expected, $test, 'Expected: ' . var_export($expected, 1) . "\nReceived:" . var_export($test, 1));
  43. }
  44. public function testRetrievingQueueAsArrayReturnsDataOnlyByDefault()
  45. {
  46. $expected = array(
  47. 'foo',
  48. 'bar',
  49. 'baz',
  50. 'bat',
  51. );
  52. $test = $this->queue->toArray();
  53. $this->assertSame($expected, $test, var_export($test, 1));
  54. }
  55. public function testCanCastToArrayOfPrioritiesOnly()
  56. {
  57. $expected = array(
  58. 3,
  59. 4,
  60. 2,
  61. 1,
  62. );
  63. $test = $this->queue->toArray(PriorityQueue::EXTR_PRIORITY);
  64. $this->assertSame($expected, $test, var_export($test, 1));
  65. }
  66. public function testCanCastToArrayOfDataPriorityPairs()
  67. {
  68. $expected = array(
  69. array('data' => 'foo', 'priority' => 3),
  70. array('data' => 'bar', 'priority' => 4),
  71. array('data' => 'baz', 'priority' => 2),
  72. array('data' => 'bat', 'priority' => 1),
  73. );
  74. $test = $this->queue->toArray(PriorityQueue::EXTR_BOTH);
  75. $this->assertSame($expected, $test, var_export($test, 1));
  76. }
  77. public function testCanIterateMultipleTimesAndReceiveSameResults()
  78. {
  79. $expected = array('bar', 'foo', 'baz', 'bat');
  80. for ($i = 1; $i < 3; $i++) {
  81. $test = array();
  82. foreach ($this->queue as $item) {
  83. $test[] = $item;
  84. }
  85. $this->assertEquals($expected, $test, 'Failed at iteration ' . $i);
  86. }
  87. }
  88. public function testCanRemoveItemFromQueue()
  89. {
  90. $this->queue->remove('baz');
  91. $expected = array('bar', 'foo', 'bat');
  92. $test = array();
  93. foreach ($this->queue as $item) {
  94. $test[] = $item;
  95. }
  96. $this->assertEquals($expected, $test);
  97. }
  98. public function testCanTestForExistenceOfItemInQueue()
  99. {
  100. $this->assertTrue($this->queue->contains('foo'));
  101. $this->assertFalse($this->queue->contains('foobar'));
  102. }
  103. public function testCanTestForExistenceOfPriorityInQueue()
  104. {
  105. $this->assertTrue($this->queue->hasPriority(3));
  106. $this->assertFalse($this->queue->hasPriority(1000));
  107. }
  108. public function testCloningAlsoClonesQueue()
  109. {
  110. $foo = new \stdClass();
  111. $foo->name = 'bar';
  112. $queue = new PriorityQueue();
  113. $queue->insert($foo, 1);
  114. $queue->insert($foo, 2);
  115. $queueClone = clone $queue;
  116. while (!$queue->isEmpty()) {
  117. $this->assertSame($foo, $queue->top());
  118. $queue->remove($queue->top());
  119. }
  120. $this->assertTrue($queue->isEmpty());
  121. $this->assertFalse($queueClone->isEmpty());
  122. $this->assertEquals(2, $queueClone->count());
  123. while (!$queueClone->isEmpty()) {
  124. $this->assertSame($foo, $queueClone->top());
  125. $queueClone->remove($queueClone->top());
  126. }
  127. $this->assertTrue($queueClone->isEmpty());
  128. }
  129. public function testQueueRevertsToInitialStateWhenEmpty()
  130. {
  131. $queue = new PriorityQueue();
  132. $testQueue = clone $queue; // store the default state
  133. $testQueue->insert('foo', 1);
  134. $testQueue->insert('bar', 2);
  135. $testQueue->remove('foo');
  136. $testQueue->remove('bar');
  137. $this->assertEquals($queue, $testQueue);
  138. }
  139. }