|
1 | 1 | require 'test_helper'
|
2 | 2 | require 'resque/queue'
|
3 | 3 |
|
4 |
| -module Resque |
5 |
| - class TestQueue < MiniTest::Unit::TestCase |
6 |
| - include Test::Unit::Assertions |
| 4 | +describe "Resque::Queue" do |
| 5 | + include Test::Unit::Assertions |
7 | 6 |
|
8 |
| - class Thing |
9 |
| - attr_reader :inside |
| 7 | + class Thing |
| 8 | + attr_reader :inside |
10 | 9 |
|
11 |
| - def initialize |
12 |
| - @inside = "x" |
13 |
| - end |
14 |
| - |
15 |
| - def == other |
16 |
| - super || @inside == other.inside |
17 |
| - end |
| 10 | + def initialize |
| 11 | + @inside = "x" |
18 | 12 | end
|
19 | 13 |
|
20 |
| - def test_sanity |
21 |
| - queue = q |
22 |
| - x = Thing.new |
23 |
| - queue.push x |
24 |
| - assert_equal x, queue.pop |
| 14 | + def == other |
| 15 | + super || @inside == other.inside |
25 | 16 | end
|
| 17 | + end |
26 | 18 |
|
27 |
| - def test_pop_blocks |
28 |
| - queue1 = q |
29 |
| - queue2 = q |
| 19 | + it "acts sanely" do |
| 20 | + queue = q |
| 21 | + x = Thing.new |
| 22 | + queue.push x |
| 23 | + assert_equal x, queue.pop |
| 24 | + end |
30 | 25 |
|
31 |
| - t = Thread.new { queue1.pop } |
32 |
| - x = Thing.new |
| 26 | + it "blocks on pop" do |
| 27 | + queue1 = q |
| 28 | + queue2 = q |
33 | 29 |
|
34 |
| - queue2.push x |
35 |
| - assert_equal x, t.join.value |
36 |
| - end |
| 30 | + t = Thread.new { queue1.pop } |
| 31 | + x = Thing.new |
37 | 32 |
|
38 |
| - def test_nonblock_pop |
39 |
| - queue1 = q |
| 33 | + queue2.push x |
| 34 | + assert_equal x, t.join.value |
| 35 | + end |
| 36 | + |
| 37 | + it "nonblocking pop works" do |
| 38 | + queue1 = q |
40 | 39 |
|
41 |
| - assert_raises ThreadError do |
42 |
| - queue1.pop(true) |
43 |
| - end |
| 40 | + assert_raises ThreadError do |
| 41 | + queue1.pop(true) |
44 | 42 | end
|
| 43 | + end |
45 | 44 |
|
46 |
| - def test_pop_blocks_forever |
47 |
| - queue1 = q |
48 |
| - assert_raises Timeout::Error do |
49 |
| - Timeout.timeout(2) { queue1.pop } |
50 |
| - end |
| 45 | + it "blocks forever on pop" do |
| 46 | + queue1 = q |
| 47 | + assert_raises Timeout::Error do |
| 48 | + Timeout.timeout(2) { queue1.pop } |
51 | 49 | end
|
| 50 | + end |
52 | 51 |
|
53 |
| - def test_size |
54 |
| - queue = q |
| 52 | + it "#size" do |
| 53 | + queue = q |
| 54 | + |
| 55 | + begin |
55 | 56 | assert_equal 0, queue.size
|
56 | 57 |
|
57 | 58 | queue << Thing.new
|
58 | 59 | assert_equal 1, queue.size
|
59 | 60 | ensure
|
60 | 61 | queue.pop
|
61 | 62 | end
|
| 63 | + end |
62 | 64 |
|
63 |
| - def test_empty? |
64 |
| - queue = q |
| 65 | + it "#empty?" do |
| 66 | + queue = q |
| 67 | + |
| 68 | + begin |
65 | 69 | assert queue.empty?
|
66 | 70 |
|
67 | 71 | queue << Thing.new
|
68 | 72 | refute queue.empty?
|
69 | 73 | ensure
|
70 | 74 | queue.pop
|
71 | 75 | end
|
| 76 | + end |
72 | 77 |
|
73 |
| - def q |
74 |
| - Queue.new 'foo', backend |
75 |
| - end |
| 78 | + def q |
| 79 | + Resque::Queue.new 'foo', backend |
| 80 | + end |
76 | 81 |
|
77 |
| - def backend |
78 |
| - redis = Redis.new(:host => "127.0.0.1", :port => 9736) |
79 |
| - Redis::Namespace.new :resque, :redis => redis |
80 |
| - end |
| 82 | + def backend |
| 83 | + redis = Redis.new(:host => "127.0.0.1", :port => 9736) |
| 84 | + Redis::Namespace.new :resque, :redis => redis |
81 | 85 | end
|
82 | 86 | end
|
0 commit comments