forked from quirkey/resque-status
/
test_resque-status.rb
122 lines (95 loc) · 3.24 KB
/
test_resque-status.rb
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
require 'test_helper'
class TestResqueStatus < Test::Unit::TestCase
context "Resque::Status" do
setup do
Resque.redis.flushall
Resque::Status.expire_in = nil
@uuid = Resque::Status.create
Resque::Status.set(@uuid, "my status")
@uuid_with_json = Resque::Status.create({"im" => "json"})
end
context ".get" do
should "return the status as a Resque::Status for the uuid" do
status = Resque::Status.get(@uuid)
assert status.is_a?(Resque::Status)
assert_equal 'my status', status.message
end
should "return false if the status is not set" do
assert !Resque::Status.get('whu')
end
should "decode encoded json" do
assert_equal("json", Resque::Status.get(@uuid_with_json)['im'])
end
end
context ".set" do
should "set the status for the uuid" do
assert Resque::Status.set(@uuid, "updated")
assert_equal "updated", Resque::Status.get(@uuid).message
end
should "return the status" do
assert Resque::Status.set(@uuid, "updated").is_a?(Resque::Status)
end
end
context ".create" do
should "add an item to a key set" do
before = Resque::Status.status_ids.length
Resque::Status.create
after = Resque::Status.status_ids.length
assert_equal 1, after - before
end
should "return a uuid" do
assert_match(/^\w{32}$/, Resque::Status.create)
end
should "store any status passed" do
uuid = Resque::Status.create("initial status")
status = Resque::Status.get(uuid)
assert status.is_a?(Resque::Status)
assert_equal "initial status", status.message
end
should "expire keys if expire_in is set" do
Resque::Status.expire_in = 1
uuid = Resque::Status.create("new status")
assert_contains Resque::Status.status_ids, uuid
assert_equal "new status", Resque::Status.get(uuid).message
sleep 2
Resque::Status.create
assert_does_not_contain Resque::Status.status_ids, uuid
assert_nil Resque::Status.get(uuid)
end
end
context ".clear" do
setup do
Resque::Status.clear
end
should "clear any statuses" do
assert_nil Resque::Status.get(@uuid)
end
should "clear any recent statuses" do
assert Resque::Status.status_ids.empty?
end
end
context ".status_ids" do
should "return an array of job ids" do
assert Resque::Status.status_ids.is_a?(Array)
end
end
context ".statuses" do
should "return an array status objects" do
statuses = Resque::Status.statuses
assert statuses.is_a?(Array)
assert_same_elements [@uuid_with_json, @uuid], statuses.collect {|s| s.uuid }
end
end
context ".logger" do
setup do
@logger = Resque::Status.logger(@uuid)
end
should "return a redisk logger" do
assert @logger.is_a?(Redisk::Logger)
end
should "scope the logger to a key" do
assert_match(/#{@uuid}/, @logger.name)
end
end
end
end