sqeduler 0.3.4 → 0.3.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGES.md +4 -0
- data/lib/sqeduler/redis_lock.rb +3 -3
- data/lib/sqeduler/redis_scripts.rb +1 -1
- data/lib/sqeduler/service.rb +4 -4
- data/lib/sqeduler/version.rb +1 -1
- data/lib/sqeduler/worker/kill_switch.rb +1 -1
- data/lib/sqeduler/worker/synchronization.rb +2 -2
- data/spec/lock_maintainer_spec.rb +2 -2
- data/sqeduler.gemspec +3 -2
- metadata +21 -7
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: f538f7aff473b6d02317f52b26462ec8a9432be0
|
4
|
+
data.tar.gz: 6a130c0ff71ccd03426845fe98b58b47df6b8812
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3b23839d88381b74537db921e6ceb9128c14cd21053adbb1d56f06096fd7b0155274f1070dd66cefc459b71b5d95181c499f31eafbd783641bd081ecb55eab28
|
7
|
+
data.tar.gz: a5e48c55681c012e7eabc00d2aa4c7624d5e7a01076506aec9bb26ebe6cec439d7440ae9b1d65fb4f62bb7e9691df669d7062adac99b99fd988f5fcbecca001d
|
data/CHANGES.md
CHANGED
data/lib/sqeduler/redis_lock.rb
CHANGED
@@ -13,7 +13,7 @@ module Sqeduler
|
|
13
13
|
def initialize(key, options = {})
|
14
14
|
@key = key
|
15
15
|
@expiration = options[:expiration]
|
16
|
-
|
16
|
+
raise ArgumentError, "Expiration must be provided!" unless @expiration
|
17
17
|
@timeout = options[:timeout] || 5
|
18
18
|
end
|
19
19
|
|
@@ -64,10 +64,10 @@ module Sqeduler
|
|
64
64
|
end
|
65
65
|
|
66
66
|
def self.with_lock(key, options)
|
67
|
-
|
67
|
+
raise "Block is required" unless block_given?
|
68
68
|
mutex = new(key, options)
|
69
69
|
unless mutex.lock
|
70
|
-
|
70
|
+
raise LockTimeoutError, "Timed out trying to get #{key} lock. Exceeded #{mutex.timeout} sec"
|
71
71
|
end
|
72
72
|
begin
|
73
73
|
yield
|
data/lib/sqeduler/service.rb
CHANGED
@@ -11,7 +11,7 @@ module Sqeduler
|
|
11
11
|
attr_accessor :config
|
12
12
|
|
13
13
|
def start
|
14
|
-
|
14
|
+
raise "No config provided" unless config
|
15
15
|
config_sidekiq_server
|
16
16
|
config_sidekiq_client
|
17
17
|
config_scheduler
|
@@ -22,7 +22,7 @@ module Sqeduler
|
|
22
22
|
redis_pool.with do |redis|
|
23
23
|
version = redis.info["redis_version"]
|
24
24
|
unless Gem::Version.new(version) >= Gem::Version.new(MINIMUM_REDIS_VERSION)
|
25
|
-
|
25
|
+
raise "Must be using redis >= #{MINIMUM_REDIS_VERSION}"
|
26
26
|
end
|
27
27
|
@verified = true
|
28
28
|
end
|
@@ -81,7 +81,7 @@ module Sqeduler
|
|
81
81
|
end
|
82
82
|
|
83
83
|
def parse_schedule(path)
|
84
|
-
|
84
|
+
raise "Schedule file #{path} does not exist!" unless File.exist?(path)
|
85
85
|
file_contents = File.read(path)
|
86
86
|
YAML.load(ERB.new(file_contents).result)
|
87
87
|
end
|
@@ -112,7 +112,7 @@ module Sqeduler
|
|
112
112
|
def logger
|
113
113
|
return config.logger if config.logger
|
114
114
|
return Rails.logger if defined?(Rails)
|
115
|
-
|
115
|
+
raise ArgumentError, "No logger provided and Rails.logger cannot be inferred"
|
116
116
|
end
|
117
117
|
end
|
118
118
|
end
|
data/lib/sqeduler/version.rb
CHANGED
@@ -7,7 +7,7 @@ module Sqeduler
|
|
7
7
|
|
8
8
|
def self.prepended(base)
|
9
9
|
if base.ancestors.include?(Sqeduler::Worker::Callbacks)
|
10
|
-
|
10
|
+
raise "Sqeduler::Worker::Callbacks must be the last module that you prepend."
|
11
11
|
end
|
12
12
|
base.extend(ClassMethods)
|
13
13
|
end
|
@@ -9,7 +9,7 @@ module Sqeduler
|
|
9
9
|
module Synchronization
|
10
10
|
def self.prepended(base)
|
11
11
|
if base.ancestors.include?(Sqeduler::Worker::Callbacks)
|
12
|
-
|
12
|
+
raise "Sqeduler::Worker::Callbacks must be the last module that you prepend."
|
13
13
|
end
|
14
14
|
|
15
15
|
base.extend(ClassMethods)
|
@@ -25,7 +25,7 @@ module Sqeduler
|
|
25
25
|
self.synchronize_jobs_timeout = opts[:timeout] || 5
|
26
26
|
self.synchronize_jobs_expiration = opts[:expiration]
|
27
27
|
return if synchronize_jobs_expiration
|
28
|
-
|
28
|
+
raise ArgumentError, ":expiration is required!"
|
29
29
|
end
|
30
30
|
|
31
31
|
def sync_lock_key(*args)
|
@@ -26,7 +26,7 @@ RSpec.describe Sqeduler::LockMaintainer do
|
|
26
26
|
synchronize :one_at_a_time, :expiration => 5, :timeout => 5
|
27
27
|
|
28
28
|
def perform
|
29
|
-
|
29
|
+
raise "This shouldn't be called"
|
30
30
|
end
|
31
31
|
end
|
32
32
|
)
|
@@ -38,7 +38,7 @@ RSpec.describe Sqeduler::LockMaintainer do
|
|
38
38
|
prepend Sqeduler::Worker::Synchronization
|
39
39
|
|
40
40
|
def perform
|
41
|
-
|
41
|
+
raise "This shouldn't be called"
|
42
42
|
end
|
43
43
|
end
|
44
44
|
)
|
data/sqeduler.gemspec
CHANGED
@@ -20,14 +20,15 @@ Gem::Specification.new do |gem|
|
|
20
20
|
gem.require_paths = ["lib"]
|
21
21
|
|
22
22
|
gem.add_runtime_dependency "sidekiq"
|
23
|
-
gem.add_runtime_dependency "
|
23
|
+
gem.add_runtime_dependency "redis-namespace"
|
24
|
+
gem.add_runtime_dependency "sidekiq-scheduler", "~> 2.0"
|
24
25
|
gem.add_runtime_dependency "activesupport"
|
25
26
|
|
26
27
|
gem.add_development_dependency "bundler", "~> 1.10"
|
27
28
|
gem.add_development_dependency "pry", "~> 0"
|
28
29
|
gem.add_development_dependency "rake", "~> 10"
|
29
30
|
gem.add_development_dependency "rspec", "~> 3.3"
|
30
|
-
gem.add_development_dependency "rubocop", "~> 0.
|
31
|
+
gem.add_development_dependency "rubocop", "~> 0.39.0"
|
31
32
|
gem.add_development_dependency "timecop", "~> 0"
|
32
33
|
gem.add_development_dependency "yard", "~> 0"
|
33
34
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sqeduler
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.3.
|
4
|
+
version: 0.3.5
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Jared Jenkins
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2016-03
|
11
|
+
date: 2016-05-03 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: sidekiq
|
@@ -24,20 +24,34 @@ dependencies:
|
|
24
24
|
- - ">="
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: '0'
|
27
|
+
- !ruby/object:Gem::Dependency
|
28
|
+
name: redis-namespace
|
29
|
+
requirement: !ruby/object:Gem::Requirement
|
30
|
+
requirements:
|
31
|
+
- - ">="
|
32
|
+
- !ruby/object:Gem::Version
|
33
|
+
version: '0'
|
34
|
+
type: :runtime
|
35
|
+
prerelease: false
|
36
|
+
version_requirements: !ruby/object:Gem::Requirement
|
37
|
+
requirements:
|
38
|
+
- - ">="
|
39
|
+
- !ruby/object:Gem::Version
|
40
|
+
version: '0'
|
27
41
|
- !ruby/object:Gem::Dependency
|
28
42
|
name: sidekiq-scheduler
|
29
43
|
requirement: !ruby/object:Gem::Requirement
|
30
44
|
requirements:
|
31
45
|
- - "~>"
|
32
46
|
- !ruby/object:Gem::Version
|
33
|
-
version: '
|
47
|
+
version: '2.0'
|
34
48
|
type: :runtime
|
35
49
|
prerelease: false
|
36
50
|
version_requirements: !ruby/object:Gem::Requirement
|
37
51
|
requirements:
|
38
52
|
- - "~>"
|
39
53
|
- !ruby/object:Gem::Version
|
40
|
-
version: '
|
54
|
+
version: '2.0'
|
41
55
|
- !ruby/object:Gem::Dependency
|
42
56
|
name: activesupport
|
43
57
|
requirement: !ruby/object:Gem::Requirement
|
@@ -114,14 +128,14 @@ dependencies:
|
|
114
128
|
requirements:
|
115
129
|
- - "~>"
|
116
130
|
- !ruby/object:Gem::Version
|
117
|
-
version: 0.
|
131
|
+
version: 0.39.0
|
118
132
|
type: :development
|
119
133
|
prerelease: false
|
120
134
|
version_requirements: !ruby/object:Gem::Requirement
|
121
135
|
requirements:
|
122
136
|
- - "~>"
|
123
137
|
- !ruby/object:Gem::Version
|
124
|
-
version: 0.
|
138
|
+
version: 0.39.0
|
125
139
|
- !ruby/object:Gem::Dependency
|
126
140
|
name: timecop
|
127
141
|
requirement: !ruby/object:Gem::Requirement
|
@@ -219,7 +233,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
219
233
|
version: '0'
|
220
234
|
requirements: []
|
221
235
|
rubyforge_project:
|
222
|
-
rubygems_version: 2.4.
|
236
|
+
rubygems_version: 2.4.8
|
223
237
|
signing_key:
|
224
238
|
specification_version: 4
|
225
239
|
summary: Common Sidekiq infrastructure for multi-host applications.
|