resque-uniqueue 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,5 @@
1
+ lib/**/*.rb
2
+ bin/*
3
+ -
4
+ features/**/*.feature
5
+ LICENSE.txt
data/Gemfile ADDED
@@ -0,0 +1,18 @@
1
+ source "http://rubygems.org"
2
+ # Add dependencies required to use your gem here.
3
+ # Example:
4
+ # gem "activesupport", ">= 2.3.5"
5
+
6
+ # Add dependencies to develop your gem here.
7
+ # Include everything needed to run rake, tests, features, etc.
8
+ gem 'resque', '~> 1.24.1'
9
+
10
+ group :development do
11
+ gem 'mocha'
12
+ gem "shoulda", ">= 0"
13
+ gem "rdoc", "~> 3.12"
14
+ gem "bundler", "~> 1.3.0"
15
+ gem "jeweler", "~> 1.8.4"
16
+ gem "pry"
17
+ end
18
+
@@ -0,0 +1,66 @@
1
+ GEM
2
+ remote: http://rubygems.org/
3
+ specs:
4
+ activesupport (3.2.13)
5
+ i18n (= 0.6.1)
6
+ multi_json (~> 1.0)
7
+ coderay (1.0.8)
8
+ git (1.2.5)
9
+ i18n (0.6.1)
10
+ jeweler (1.8.4)
11
+ bundler (~> 1.0)
12
+ git (>= 1.2.5)
13
+ rake
14
+ rdoc
15
+ json (1.8.0)
16
+ metaclass (0.0.1)
17
+ method_source (0.8.1)
18
+ mocha (0.13.3)
19
+ metaclass (~> 0.0.1)
20
+ mono_logger (1.1.0)
21
+ multi_json (1.7.4)
22
+ pry (0.9.11.3)
23
+ coderay (~> 1.0.5)
24
+ method_source (~> 0.8)
25
+ slop (~> 3.4)
26
+ rack (1.5.2)
27
+ rack-protection (1.5.0)
28
+ rack
29
+ rake (10.0.4)
30
+ rdoc (3.12.2)
31
+ json (~> 1.4)
32
+ redis (3.0.4)
33
+ redis-namespace (1.3.0)
34
+ redis (~> 3.0.0)
35
+ resque (1.24.1)
36
+ mono_logger (~> 1.0)
37
+ multi_json (~> 1.0)
38
+ redis-namespace (~> 1.2)
39
+ sinatra (>= 0.9.2)
40
+ vegas (~> 0.1.2)
41
+ shoulda (3.5.0)
42
+ shoulda-context (~> 1.0, >= 1.0.1)
43
+ shoulda-matchers (>= 1.4.1, < 3.0)
44
+ shoulda-context (1.1.2)
45
+ shoulda-matchers (2.1.0)
46
+ activesupport (>= 3.0.0)
47
+ sinatra (1.4.2)
48
+ rack (~> 1.5, >= 1.5.2)
49
+ rack-protection (~> 1.4)
50
+ tilt (~> 1.3, >= 1.3.4)
51
+ slop (3.4.3)
52
+ tilt (1.4.1)
53
+ vegas (0.1.11)
54
+ rack (>= 1.0.0)
55
+
56
+ PLATFORMS
57
+ ruby
58
+
59
+ DEPENDENCIES
60
+ bundler (~> 1.3.0)
61
+ jeweler (~> 1.8.4)
62
+ mocha
63
+ pry
64
+ rdoc (~> 3.12)
65
+ resque (~> 1.24.1)
66
+ shoulda
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2013 AcademicWorks, inc.
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,19 @@
1
+ = resque-uniqueue
2
+
3
+ Description goes here.
4
+
5
+ == Contributing to resque-uniqueue
6
+
7
+ * Check out the latest master to make sure the feature hasn't been implemented or the bug hasn't been fixed yet.
8
+ * Check out the issue tracker to make sure someone already hasn't requested it and/or contributed it.
9
+ * Fork the project.
10
+ * Start a feature/bugfix branch.
11
+ * Commit and push until you are happy with your contribution.
12
+ * Make sure to add tests for it. This is important so I don't break it in a future version unintentionally.
13
+ * Please try not to mess with the Rakefile, version, or history. If you want to have your own version, or is otherwise necessary, that is fine, but please isolate to its own commit so I can cherry-pick around it.
14
+
15
+ == Copyright
16
+
17
+ Copyright (c) 2013 AcademicWorks, inc. See LICENSE.txt for
18
+ further details.
19
+
@@ -0,0 +1,45 @@
1
+ # encoding: utf-8
2
+
3
+ require 'rubygems'
4
+ require 'bundler'
5
+ begin
6
+ Bundler.setup(:default, :development)
7
+ rescue Bundler::BundlerError => e
8
+ $stderr.puts e.message
9
+ $stderr.puts "Run `bundle install` to install missing gems"
10
+ exit e.status_code
11
+ end
12
+ require 'rake'
13
+
14
+ require 'jeweler'
15
+ Jeweler::Tasks.new do |gem|
16
+ # gem is a Gem::Specification... see http://docs.rubygems.org/read/chapter/20 for more options
17
+ gem.name = "resque-uniqueue"
18
+ gem.homepage = "http://github.com/AcademicWorks/resque-uniqueue"
19
+ gem.license = "MIT"
20
+ gem.summary = %Q{Unique Resque queues using redis 1.6.0 scripting, sets and not much else }
21
+ gem.description = %Q{Unique Resque queues using redis 1.6.0 scripting, sets and not much else}
22
+ gem.email = "aaron@scrug.gs"
23
+ gem.authors = ["Aaron Scruggs"]
24
+ # dependencies defined in Gemfile
25
+ end
26
+ Jeweler::RubygemsDotOrgTasks.new
27
+
28
+ require 'rake/testtask'
29
+ Rake::TestTask.new(:test) do |test|
30
+ test.libs << 'lib' << 'test'
31
+ test.pattern = 'test/**/test_*.rb'
32
+ test.verbose = true
33
+ end
34
+
35
+ task :default => :test
36
+
37
+ require 'rdoc/task'
38
+ Rake::RDocTask.new do |rdoc|
39
+ version = File.exist?('VERSION') ? File.read('VERSION') : ""
40
+
41
+ rdoc.rdoc_dir = 'rdoc'
42
+ rdoc.title = "resque-uniqueue #{version}"
43
+ rdoc.rdoc_files.include('README*')
44
+ rdoc.rdoc_files.include('lib/**/*.rb')
45
+ end
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 0.1.0
@@ -0,0 +1 @@
1
+ require "#{File.dirname(__FILE__)}/resque/uniqueue"
@@ -0,0 +1,108 @@
1
+ require 'resque'
2
+
3
+ module Resque
4
+ module Uniqueue
5
+
6
+ def push(queue, item)
7
+ unique_queue?(queue) ? push_unique(queue, item) : super
8
+ end
9
+
10
+ def pop(queue)
11
+ unique_queue?(queue) ? pop_unique(queue) : super
12
+ end
13
+
14
+ def push_unique(queue, item)
15
+ confirm_unique_queue_validity(queue)
16
+ watch_queue(queue)
17
+ redis.evalsha push_unique_eval_sha, [queue], [encode(item)]
18
+ end
19
+
20
+ def pop_unique(queue)
21
+ confirm_unique_queue_validity(queue)
22
+ decode redis.evalsha pop_unique_eval_sha, [queue]
23
+ end
24
+
25
+ def push_unique_eval_sha
26
+ @push_unique_eval_sha ||= load_script <<-LUA
27
+ local list_name = KEYS[1]
28
+ local set_name = list_name..':uniqueue'
29
+ local in_set = redis.call('sadd', set_name , ARGV[1])
30
+ if in_set == 1 then
31
+ redis.call('rpush', list_name, ARGV[1])
32
+ return in_set
33
+ end
34
+ return in_set
35
+ LUA
36
+ end
37
+
38
+ def pop_unique_eval_sha
39
+ @pop_unique_eval_sha ||= load_script <<-LUA
40
+ local list_name = KEYS[1]
41
+ local set_name = list_name..':uniqueue'
42
+ local job = redis.call('lpop', list_name)
43
+ redis.call('srem', set_name, job)
44
+ return job
45
+ LUA
46
+ end
47
+
48
+ def queue_and_set_length_equal_eval_sha
49
+ @queue_and_set_length_equal_eval_sha ||= load_script <<-LUA
50
+ local list_name = KEYS[1]
51
+ local set_name = list_name..':uniqueue'
52
+ local list_size = redis.call('llen', list_name)
53
+ local set_size = redis.call('scard', set_name)
54
+ return list_size == set_size
55
+ LUA
56
+ end
57
+
58
+ def load_script(script)
59
+ redis.script :load, script
60
+ end
61
+
62
+ #if the queue and set sizes differ, something is very wrong and we should fail loudly
63
+ def confirm_unique_queue_validity(queue)
64
+ response = redis.evalsha queue_and_set_length_equal_eval_sha, [queue]
65
+ return true if response == 1
66
+ #TODO raise specific exception
67
+ raise "Make sure your queues are empty before you start using uniqueue"
68
+ end
69
+
70
+ #is this queue a unique queue
71
+ def unique_queue?(queue)
72
+ unique_queues? && unique_queues.include?(queue)
73
+ end
74
+
75
+ #list the unique queues
76
+ def unique_queues
77
+ @unique_queues || queues
78
+ end
79
+
80
+ #set a specific list of unique queues
81
+ def unique_queues=(unique_queues)
82
+ @unique_queues = unique_queues
83
+ end
84
+
85
+ #turn on unique queues
86
+ def unique_queues!
87
+ confirm_compatible_redis_version
88
+ @unique_queues_enabled = true
89
+ end
90
+
91
+ #are unique queues turned on?
92
+ def unique_queues?
93
+ !!@unique_queues_enabled
94
+ end
95
+
96
+ def confirm_compatible_redis_version
97
+ redis_version = redis.info["redis_version"]
98
+ major, minor, patch = redis_version.split('.').map(&:to_i)
99
+ if major < 2 || minor < 6
100
+ #TODO raise specific exception
101
+ raise "Redis version must be at least 2.6.0 you are running #{redis_version}"
102
+ end
103
+ end
104
+
105
+ end
106
+ end
107
+
108
+ Resque.send(:extend, Resque::Uniqueue)
@@ -0,0 +1,69 @@
1
+ # Generated by jeweler
2
+ # DO NOT EDIT THIS FILE DIRECTLY
3
+ # Instead, edit Jeweler::Tasks in Rakefile, and run 'rake gemspec'
4
+ # -*- encoding: utf-8 -*-
5
+
6
+ Gem::Specification.new do |s|
7
+ s.name = "resque-uniqueue"
8
+ s.version = "0.1.0"
9
+
10
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
+ s.authors = ["Aaron Scruggs"]
12
+ s.date = "2013-05-27"
13
+ s.description = "Unique Resque queues using redis 1.6.0 scripting, sets and not much else"
14
+ s.email = "aaron@scrug.gs"
15
+ s.extra_rdoc_files = [
16
+ "LICENSE.txt",
17
+ "README.rdoc"
18
+ ]
19
+ s.files = [
20
+ ".document",
21
+ "Gemfile",
22
+ "Gemfile.lock",
23
+ "LICENSE.txt",
24
+ "README.rdoc",
25
+ "Rakefile",
26
+ "VERSION",
27
+ "lib/resque-uniqueue.rb",
28
+ "lib/resque/uniqueue.rb",
29
+ "resque-uniqueue.gemspec",
30
+ "test/helper.rb",
31
+ "test/test_resque-uniqueue.rb"
32
+ ]
33
+ s.homepage = "http://github.com/AcademicWorks/resque-uniqueue"
34
+ s.licenses = ["MIT"]
35
+ s.require_paths = ["lib"]
36
+ s.rubygems_version = "1.8.25"
37
+ s.summary = "Unique Resque queues using redis 1.6.0 scripting, sets and not much else"
38
+
39
+ if s.respond_to? :specification_version then
40
+ s.specification_version = 3
41
+
42
+ if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
43
+ s.add_runtime_dependency(%q<resque>, ["~> 1.24.1"])
44
+ s.add_development_dependency(%q<mocha>, [">= 0"])
45
+ s.add_development_dependency(%q<shoulda>, [">= 0"])
46
+ s.add_development_dependency(%q<rdoc>, ["~> 3.12"])
47
+ s.add_development_dependency(%q<bundler>, ["~> 1.3.0"])
48
+ s.add_development_dependency(%q<jeweler>, ["~> 1.8.4"])
49
+ s.add_development_dependency(%q<pry>, [">= 0"])
50
+ else
51
+ s.add_dependency(%q<resque>, ["~> 1.24.1"])
52
+ s.add_dependency(%q<mocha>, [">= 0"])
53
+ s.add_dependency(%q<shoulda>, [">= 0"])
54
+ s.add_dependency(%q<rdoc>, ["~> 3.12"])
55
+ s.add_dependency(%q<bundler>, ["~> 1.3.0"])
56
+ s.add_dependency(%q<jeweler>, ["~> 1.8.4"])
57
+ s.add_dependency(%q<pry>, [">= 0"])
58
+ end
59
+ else
60
+ s.add_dependency(%q<resque>, ["~> 1.24.1"])
61
+ s.add_dependency(%q<mocha>, [">= 0"])
62
+ s.add_dependency(%q<shoulda>, [">= 0"])
63
+ s.add_dependency(%q<rdoc>, ["~> 3.12"])
64
+ s.add_dependency(%q<bundler>, ["~> 1.3.0"])
65
+ s.add_dependency(%q<jeweler>, ["~> 1.8.4"])
66
+ s.add_dependency(%q<pry>, [">= 0"])
67
+ end
68
+ end
69
+
@@ -0,0 +1,21 @@
1
+ require 'rubygems'
2
+ require 'bundler'
3
+
4
+ begin
5
+ Bundler.setup(:default, :development)
6
+ rescue Bundler::BundlerError => e
7
+ $stderr.puts e.message
8
+ $stderr.puts "Run `bundle install` to install missing gems"
9
+ exit e.status_code
10
+ end
11
+ require 'test/unit'
12
+ require 'shoulda'
13
+ require 'mocha/setup'
14
+ require 'pry'
15
+
16
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
17
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
18
+ require 'resque-uniqueue'
19
+
20
+ class Test::Unit::TestCase
21
+ end
@@ -0,0 +1,275 @@
1
+ require 'helper'
2
+
3
+ class TestResqueUniqueue < Test::Unit::TestCase
4
+
5
+ def setup
6
+ Resque.instance_variable_set :@unique_queues, nil
7
+ Resque.instance_variable_set :@unique_queues_enabled, nil
8
+ Resque.instance_variable_set :@pop_unique_eval_sha, nil
9
+ Resque.instance_variable_set :@push_unique_eval_sha, nil
10
+ Resque.instance_variable_set :@queue_and_set_length_equal_eval_sha, nil
11
+ end
12
+
13
+ context "enabling gem" do
14
+
15
+ should "be off by default" do
16
+ refute Resque.unique_queues?
17
+ end
18
+
19
+ should "be able to be turned on" do
20
+ Resque.stubs(:confirm_compatible_redis_version).returns true
21
+ Resque.unique_queues!
22
+ assert Resque.unique_queues?
23
+ end
24
+
25
+ end
26
+
27
+ context "Redis version checking" do
28
+
29
+ should "raise exception if pre 2.6.0" do
30
+ redis = Object.new
31
+ def redis.info
32
+ {"redis_version" => '2.5.9'}
33
+ end
34
+ Resque.stubs(:redis).returns(redis)
35
+ assert_raises(RuntimeError){ Resque.confirm_compatible_redis_version }
36
+ end
37
+
38
+ should "no raise an exception if 2.6.0 or later" do
39
+ redis = Object.new
40
+ def redis.info
41
+ {"redis_version" => '2.6.0'}
42
+ end
43
+ Resque.stubs(:redis).returns(redis)
44
+ assert_nil Resque.confirm_compatible_redis_version
45
+ end
46
+
47
+ end
48
+
49
+ context "setting queues" do
50
+
51
+ setup do
52
+ Resque.stubs(:queues).returns(['priority_10'])
53
+ end
54
+
55
+ should "default to all queues if non set" do
56
+ assert_equal Resque.unique_queues, ['priority_10']
57
+ end
58
+
59
+ should "be able to set specific queue list" do
60
+ Resque.unique_queues = ['priority_20']
61
+ assert_equal Resque.unique_queues, ['priority_20']
62
+ end
63
+
64
+ end
65
+
66
+ context "deteriming if a queue is unique" do
67
+
68
+ setup do
69
+ Resque.unique_queues = ['priority_10']
70
+ end
71
+
72
+ should "no be unique if gem not enabled" do
73
+ refute Resque.unique_queue?('priority_10')
74
+ end
75
+
76
+ should "be have unique queues when enabled" do
77
+ Resque.stubs(:confirm_compatible_redis_version).returns true
78
+ Resque.unique_queues!
79
+ assert Resque.unique_queue?('priority_10')
80
+ end
81
+
82
+ end
83
+
84
+ context "loading redis scripts" do
85
+
86
+ should "load push_unique_eval_sha" do
87
+ Resque.expects(:load_script).returns("12345")
88
+ assert Resque.push_unique_eval_sha, "12345"
89
+ end
90
+
91
+ should "load pop_unique_eval_sha" do
92
+ Resque.expects(:load_script).returns("12345")
93
+ assert Resque.pop_unique_eval_sha, "12345"
94
+ end
95
+
96
+ should "load queue_and_set_length_equal_eval_sha" do
97
+ Resque.expects(:load_script).returns("12345")
98
+ assert Resque.queue_and_set_length_equal_eval_sha, "12345"
99
+ end
100
+
101
+ should "memoize push_unique_eval_sha" do
102
+ Resque.stubs(:load_script).returns("12345")
103
+ Resque.push_unique_eval_sha
104
+ Resque.stubs(:load_script).returns("54321")
105
+ assert Resque.push_unique_eval_sha, "12345"
106
+ end
107
+
108
+ should "memoize pop_unique_eval_sha" do
109
+ Resque.stubs(:load_script).returns("12345")
110
+ Resque.pop_unique_eval_sha
111
+ Resque.stubs(:load_script).returns("54321")
112
+ assert Resque.pop_unique_eval_sha, "12345"
113
+ end
114
+
115
+ should "memoize queue_and_set_length_equal_eval_sha" do
116
+ Resque.stubs(:load_script).returns("12345")
117
+ Resque.queue_and_set_length_equal_eval_sha
118
+ Resque.stubs(:load_script).returns("54321")
119
+ assert Resque.queue_and_set_length_equal_eval_sha, "12345"
120
+ end
121
+
122
+ end
123
+
124
+ context "pushing & popping" do
125
+
126
+ context "non-unique queues" do
127
+
128
+ setup do
129
+ Resque.stubs(:confirm_compatible_redis_version).returns true
130
+ Resque.unique_queues!
131
+ Resque.unique_queues=['priority_10']
132
+ end
133
+
134
+ should "call parent for push" do
135
+ Resque.stubs(:push_unique).returns "failed"
136
+ refute_equal Resque.push('priority_20', {'name' => 'bob'}), "failed"
137
+ end
138
+
139
+ should 'call parent for pop' do
140
+ Resque.stubs(:pop_unique).returns "failed"
141
+ refute_equal Resque.pop('priority_20'), "failed"
142
+ end
143
+
144
+ end
145
+
146
+ context "unique queues" do
147
+
148
+ setup do
149
+ Resque.stubs(:confirm_compatible_redis_version).returns true
150
+ Resque.unique_queues!
151
+ Resque.unique_queues=['priority_10']
152
+ end
153
+
154
+ should "call push_unique for push" do
155
+ Resque.stubs(:push_unique).returns "success"
156
+ assert_equal Resque.push('priority_10', {'name' => 'bob'}), "success"
157
+ end
158
+
159
+ should 'call pop_unique for pop' do
160
+ Resque.stubs(:pop_unique).returns "success"
161
+ assert_equal Resque.pop('priority_10'), "success"
162
+ end
163
+
164
+ end
165
+
166
+ context "confirm_unique_queue_validity" do
167
+
168
+ setup do
169
+ Resque.redis.flushall
170
+ end
171
+
172
+ should "return true if set length and list length are the same" do
173
+ Resque.redis.sadd "priority_10:uniqueue", "test"
174
+ Resque.redis.rpush "priority_10", "test"
175
+ Resque.confirm_unique_queue_validity("priority_10")
176
+ end
177
+
178
+ should 'raise exception if length of set and list differ' do
179
+ Resque.redis.rpush "priority_10", "test"
180
+ assert_raises(RuntimeError){ Resque.confirm_unique_queue_validity("priority_10") }
181
+ end
182
+
183
+ end
184
+
185
+ context "queue names" do
186
+
187
+ setup do
188
+ Resque.redis.flushall
189
+ end
190
+
191
+ should "maintain same queue name between unique and non unique" do
192
+ assert_equal Resque.queues.size, 0
193
+ refute Resque.unique_queues?
194
+ Resque.push('priority_20', {'name' => 'bob'})
195
+ queues = Resque.queues
196
+ Resque.redis.flushall
197
+ Resque.unique_queues!
198
+ Resque.unique_queues= ['priority_20']
199
+ Resque.push('priority_20', {'name' => 'bob'})
200
+ assert_equal queues, Resque.queues
201
+ assert_equal queues.size, 1
202
+ end
203
+
204
+ end
205
+
206
+ context 'scripting logic' do
207
+
208
+ setup do
209
+ Resque.redis.flushall
210
+ Resque.unique_queues!
211
+ Resque.unique_queues= ['priority_10']
212
+ end
213
+
214
+ context 'push_unique' do
215
+
216
+ should 'create set & list if they do not exist' do
217
+ refute Resque.redis.exists 'priority_10'
218
+ refute Resque.redis.exists 'priority_10:uniqueue'
219
+ Resque.push('priority_10', {'name' => 'bob'})
220
+ assert Resque.redis.exists 'priority_10'
221
+ assert Resque.redis.exists 'priority_10:uniqueue'
222
+ end
223
+
224
+ should "add items to set and list if message unique" do
225
+ Resque.push('priority_10', {'name' => 'bob'})
226
+ assert_equal Resque.redis.llen('priority_10'), 1
227
+ assert_equal Resque.redis.scard('priority_10:uniqueue'), 1
228
+ end
229
+
230
+ should "not add item to queue if already on there" do
231
+ Resque.push('priority_10', {'name' => 'bob'})
232
+ assert_equal Resque.redis.llen('priority_10'), 1
233
+ assert_equal Resque.redis.scard('priority_10:uniqueue'), 1
234
+ Resque.push('priority_10', {'name' => 'bob'})
235
+ assert_equal Resque.redis.llen('priority_10'), 1
236
+ assert_equal Resque.redis.scard('priority_10:uniqueue'), 1
237
+ end
238
+
239
+ end
240
+
241
+ context "pop_unique" do
242
+
243
+ should "return same item whether unique queue or not" do
244
+ Resque.push('priority_20', {'name' => 'bob'})
245
+ job = Resque.pop('priority_20')
246
+ Resque.push('priority_10', {'name' => 'bob'})
247
+ uniqueue_job = Resque.pop('priority_10')
248
+ assert_equal job, uniqueue_job
249
+ end
250
+
251
+ should "return same item whether unique queue or not when queue is empty" do
252
+ job = Resque.pop('priority_20')
253
+ uniqueue_job = Resque.pop('priority_10')
254
+ assert_equal job, uniqueue_job
255
+ end
256
+
257
+ should 'remove job from list and set' do
258
+ Resque.push('priority_10', {'name' => 'bob'})
259
+ assert_equal Resque.redis.llen('priority_10'), 1
260
+ assert_equal Resque.redis.scard('priority_10:uniqueue'), 1
261
+ Resque.pop('priority_10')
262
+ assert_equal Resque.redis.llen('priority_10'), 0
263
+ assert_equal Resque.redis.scard('priority_10:uniqueue'), 0
264
+ end
265
+
266
+ end
267
+
268
+ end
269
+
270
+
271
+
272
+
273
+ end
274
+
275
+ end
metadata ADDED
@@ -0,0 +1,174 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: resque-uniqueue
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Aaron Scruggs
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2013-05-27 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: resque
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ~>
20
+ - !ruby/object:Gem::Version
21
+ version: 1.24.1
22
+ type: :runtime
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ~>
28
+ - !ruby/object:Gem::Version
29
+ version: 1.24.1
30
+ - !ruby/object:Gem::Dependency
31
+ name: mocha
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ! '>='
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
38
+ type: :development
39
+ prerelease: false
40
+ version_requirements: !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ! '>='
44
+ - !ruby/object:Gem::Version
45
+ version: '0'
46
+ - !ruby/object:Gem::Dependency
47
+ name: shoulda
48
+ requirement: !ruby/object:Gem::Requirement
49
+ none: false
50
+ requirements:
51
+ - - ! '>='
52
+ - !ruby/object:Gem::Version
53
+ version: '0'
54
+ type: :development
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ none: false
58
+ requirements:
59
+ - - ! '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ - !ruby/object:Gem::Dependency
63
+ name: rdoc
64
+ requirement: !ruby/object:Gem::Requirement
65
+ none: false
66
+ requirements:
67
+ - - ~>
68
+ - !ruby/object:Gem::Version
69
+ version: '3.12'
70
+ type: :development
71
+ prerelease: false
72
+ version_requirements: !ruby/object:Gem::Requirement
73
+ none: false
74
+ requirements:
75
+ - - ~>
76
+ - !ruby/object:Gem::Version
77
+ version: '3.12'
78
+ - !ruby/object:Gem::Dependency
79
+ name: bundler
80
+ requirement: !ruby/object:Gem::Requirement
81
+ none: false
82
+ requirements:
83
+ - - ~>
84
+ - !ruby/object:Gem::Version
85
+ version: 1.3.0
86
+ type: :development
87
+ prerelease: false
88
+ version_requirements: !ruby/object:Gem::Requirement
89
+ none: false
90
+ requirements:
91
+ - - ~>
92
+ - !ruby/object:Gem::Version
93
+ version: 1.3.0
94
+ - !ruby/object:Gem::Dependency
95
+ name: jeweler
96
+ requirement: !ruby/object:Gem::Requirement
97
+ none: false
98
+ requirements:
99
+ - - ~>
100
+ - !ruby/object:Gem::Version
101
+ version: 1.8.4
102
+ type: :development
103
+ prerelease: false
104
+ version_requirements: !ruby/object:Gem::Requirement
105
+ none: false
106
+ requirements:
107
+ - - ~>
108
+ - !ruby/object:Gem::Version
109
+ version: 1.8.4
110
+ - !ruby/object:Gem::Dependency
111
+ name: pry
112
+ requirement: !ruby/object:Gem::Requirement
113
+ none: false
114
+ requirements:
115
+ - - ! '>='
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ none: false
122
+ requirements:
123
+ - - ! '>='
124
+ - !ruby/object:Gem::Version
125
+ version: '0'
126
+ description: Unique Resque queues using redis 1.6.0 scripting, sets and not much else
127
+ email: aaron@scrug.gs
128
+ executables: []
129
+ extensions: []
130
+ extra_rdoc_files:
131
+ - LICENSE.txt
132
+ - README.rdoc
133
+ files:
134
+ - .document
135
+ - Gemfile
136
+ - Gemfile.lock
137
+ - LICENSE.txt
138
+ - README.rdoc
139
+ - Rakefile
140
+ - VERSION
141
+ - lib/resque-uniqueue.rb
142
+ - lib/resque/uniqueue.rb
143
+ - resque-uniqueue.gemspec
144
+ - test/helper.rb
145
+ - test/test_resque-uniqueue.rb
146
+ homepage: http://github.com/AcademicWorks/resque-uniqueue
147
+ licenses:
148
+ - MIT
149
+ post_install_message:
150
+ rdoc_options: []
151
+ require_paths:
152
+ - lib
153
+ required_ruby_version: !ruby/object:Gem::Requirement
154
+ none: false
155
+ requirements:
156
+ - - ! '>='
157
+ - !ruby/object:Gem::Version
158
+ version: '0'
159
+ segments:
160
+ - 0
161
+ hash: -1288207955428299107
162
+ required_rubygems_version: !ruby/object:Gem::Requirement
163
+ none: false
164
+ requirements:
165
+ - - ! '>='
166
+ - !ruby/object:Gem::Version
167
+ version: '0'
168
+ requirements: []
169
+ rubyforge_project:
170
+ rubygems_version: 1.8.25
171
+ signing_key:
172
+ specification_version: 3
173
+ summary: Unique Resque queues using redis 1.6.0 scripting, sets and not much else
174
+ test_files: []