forked from AdaGold/stacks-queues
-
Notifications
You must be signed in to change notification settings - Fork 42
Expand file tree
/
Copy pathqueue_test.rb
More file actions
69 lines (60 loc) · 1.4 KB
/
queue_test.rb
File metadata and controls
69 lines (60 loc) · 1.4 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
require 'minitest/autorun'
require 'minitest/reporters'
require_relative '../lib/queue'
Minitest::Reporters.use! Minitest::Reporters::SpecReporter.new
describe "Test Queue Implementation" do
it "creates a Queue" do
q = Queue.new
q.class.must_equal Queue
end
it "adds something to an empty Queue" do
q = Queue.new
q.enqueue(10)
q.to_s.must_equal "[10]"
end
it "adds multiple somethings to a Queue" do
q = Queue.new
q.enqueue(10)
q.enqueue(20)
q.enqueue(30)
q.to_s.must_equal "[10, 20, 30]"
end
it "starts the size of a Queue at 0" do
q = Queue.new
q.empty?.must_equal true
end
it "removes something from the Queue" do
q = Queue.new
q.enqueue(5)
removed = q.dequeue
removed.must_equal 5
q.empty?.must_equal true
end
it "removes the right something (LIFO)" do
q = Queue.new
q.enqueue(5)
q.enqueue(3)
q.enqueue(7)
removed = q.dequeue
removed.must_equal 5
q.to_s.must_equal "[3, 7]"
end
it "properly adjusts the size with enqueueing and dequeueing" do
q = Queue.new
q.empty?.must_equal true
q.enqueue(-1)
q.enqueue(-60)
q.empty?.must_equal false
q.dequeue
q.dequeue
q.empty?.must_equal true
end
it "returns the front element in the Queue" do
q = Queue.new
q.enqueue(40)
q.enqueue(22)
q.enqueue(3)
q.dequeue
expect(q.dequeue).must_equal 22
end
end