activejob-resque-disconnect 0.1.0

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.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: dc9af47d06d09561e4b9124c2d997eaa44d19d00
4
+ data.tar.gz: c29fe167d1ddb0ceba7641f4d3d8f1e9f6cc5b84
5
+ SHA512:
6
+ metadata.gz: d2a9ea10fd546914a395b6591f1c9c902ba99d10cc62b99a895f386980bdc0d1aa890864605d6338767efc825ab0accddf5d623f349a5f403f3ddd56d547c3eb
7
+ data.tar.gz: 5e10aec03c72d6fa5a1d0932dc6b6486f090a48caa621254fad10d9edd2349a98406a2391e7348202cd499cb28fcf6fc75e2f310e536d0b731490968a7a441d2
data/Gemfile ADDED
@@ -0,0 +1,8 @@
1
+ source 'https://rubygems.org'
2
+
3
+ gemspec
4
+
5
+ group :test, :integration do
6
+ gem 'resque', require: false
7
+ gem 'resque-scheduler', require: false
8
+ end
@@ -0,0 +1,109 @@
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ activejob-resque-disconnect (0.1.0)
5
+ activejob (>= 4.2)
6
+ activerecord (>= 4.2)
7
+ resque
8
+ resque-scheduler
9
+
10
+ GEM
11
+ remote: https://rubygems.org/
12
+ specs:
13
+ activejob (4.2.0)
14
+ activesupport (= 4.2.0)
15
+ globalid (>= 0.3.0)
16
+ activemodel (4.2.0)
17
+ activesupport (= 4.2.0)
18
+ builder (~> 3.1)
19
+ activerecord (4.2.0)
20
+ activemodel (= 4.2.0)
21
+ activesupport (= 4.2.0)
22
+ arel (~> 6.0)
23
+ activesupport (4.2.0)
24
+ i18n (~> 0.7)
25
+ json (~> 1.7, >= 1.7.7)
26
+ minitest (~> 5.1)
27
+ thread_safe (~> 0.3, >= 0.3.4)
28
+ tzinfo (~> 1.1)
29
+ arel (6.0.0)
30
+ ast (2.0.0)
31
+ astrolabe (1.3.0)
32
+ parser (>= 2.2.0.pre.3, < 3.0)
33
+ builder (3.2.2)
34
+ diff-lcs (1.2.5)
35
+ globalid (0.3.0)
36
+ activesupport (>= 4.1.0)
37
+ i18n (0.7.0)
38
+ json (1.8.2)
39
+ minitest (5.5.1)
40
+ mono_logger (1.1.0)
41
+ multi_json (1.10.1)
42
+ parser (2.2.0.2)
43
+ ast (>= 1.1, < 3.0)
44
+ powerpack (0.0.9)
45
+ rack (1.6.0)
46
+ rack-protection (1.5.3)
47
+ rack
48
+ rainbow (2.0.0)
49
+ rake (10.4.2)
50
+ redis (3.2.0)
51
+ redis-namespace (1.5.1)
52
+ redis (~> 3.0, >= 3.0.4)
53
+ resque (1.25.2)
54
+ mono_logger (~> 1.0)
55
+ multi_json (~> 1.0)
56
+ redis-namespace (~> 1.3)
57
+ sinatra (>= 0.9.2)
58
+ vegas (~> 0.1.2)
59
+ resque-scheduler (4.0.0)
60
+ mono_logger (~> 1.0)
61
+ redis (~> 3.0)
62
+ resque (~> 1.25)
63
+ rufus-scheduler (~> 3.0)
64
+ rspec (3.1.0)
65
+ rspec-core (~> 3.1.0)
66
+ rspec-expectations (~> 3.1.0)
67
+ rspec-mocks (~> 3.1.0)
68
+ rspec-core (3.1.7)
69
+ rspec-support (~> 3.1.0)
70
+ rspec-expectations (3.1.2)
71
+ diff-lcs (>= 1.2.0, < 2.0)
72
+ rspec-support (~> 3.1.0)
73
+ rspec-its (1.1.0)
74
+ rspec-core (>= 3.0.0)
75
+ rspec-expectations (>= 3.0.0)
76
+ rspec-mocks (3.1.3)
77
+ rspec-support (~> 3.1.0)
78
+ rspec-support (3.1.2)
79
+ rubocop (0.28.0)
80
+ astrolabe (~> 1.3)
81
+ parser (>= 2.2.0.pre.7, < 3.0)
82
+ powerpack (~> 0.0.6)
83
+ rainbow (>= 1.99.1, < 3.0)
84
+ ruby-progressbar (~> 1.4)
85
+ ruby-progressbar (1.7.1)
86
+ rufus-scheduler (3.0.9)
87
+ tzinfo
88
+ sinatra (1.4.5)
89
+ rack (~> 1.4)
90
+ rack-protection (~> 1.4)
91
+ tilt (~> 1.3, >= 1.3.4)
92
+ thread_safe (0.3.4)
93
+ tilt (1.4.1)
94
+ tzinfo (1.2.2)
95
+ thread_safe (~> 0.1)
96
+ vegas (0.1.11)
97
+ rack (>= 1.0.0)
98
+
99
+ PLATFORMS
100
+ ruby
101
+
102
+ DEPENDENCIES
103
+ activejob-resque-disconnect!
104
+ rake (>= 10.3)
105
+ resque
106
+ resque-scheduler
107
+ rspec
108
+ rspec-its
109
+ rubocop
@@ -0,0 +1,14 @@
1
+ # ActiveJob::QueueAdapters::ResqueDisconnectAdapter
2
+
3
+ ActiveJob adapter for Resque which disconnects when the worker has finished.
4
+
5
+ By default the connection will be left open until the database times it out, which eats up
6
+ database connections for no good reason.
7
+
8
+ ```ruby
9
+ require 'active_job/queue_adapters/resque_disconnect_adapter'
10
+
11
+ MyApp::Application.configure do
12
+ config.active_job.queue_adapter = ActiveJob::QueueAdapters::ResqueDisconnectAdapter
13
+ end
14
+ ```
@@ -0,0 +1,32 @@
1
+ require File.expand_path('../lib/version', __FILE__)
2
+
3
+ Gem::Specification.new do |s|
4
+ s.name = 'activejob-resque-disconnect'
5
+ s.version = ActiveJob::QueueAdapters::RESQUE_DISCONNECT_ADAPTER_VERSION
6
+ s.date = Date.today.strftime('%Y-%m-%d')
7
+ s.authors = ['Isaac Seymour']
8
+ s.email = ['isaac@isaacseymour.co.uk']
9
+ s.summary = 'ActiveJob Resque adapter which disconnects when the job is complete'
10
+ s.description = <<-EOL
11
+ If you're using ActiveRecord with Resque, a new database connection will get opened
12
+ for each worker process. When the worker completes, this connection is left open by
13
+ default, which is pretty bad. This adapter closes the connection when the job has_rdoc
14
+ finished executing.
15
+ EOL
16
+ s.homepage = 'http://github.com/gocardless/activejob-resque-disconnect'
17
+ s.license = 'MIT'
18
+
19
+ s.has_rdoc = false
20
+ s.files = `git ls-files`.split($INPUT_RECORD_SEPARATOR)
21
+ s.require_paths = %w(lib)
22
+
23
+ s.add_dependency('activejob', '>= 4.2')
24
+ s.add_dependency('activerecord', '>= 4.2')
25
+ s.add_dependency('resque')
26
+ s.add_dependency('resque-scheduler')
27
+
28
+ s.add_development_dependency('rake', ' >= 10.3')
29
+ s.add_development_dependency('rspec')
30
+ s.add_development_dependency('rspec-its')
31
+ s.add_development_dependency('rubocop')
32
+ end
@@ -0,0 +1,51 @@
1
+ require 'resque'
2
+ require 'active_job'
3
+ require 'active_record'
4
+ require 'active_support/core_ext/enumerable'
5
+ require 'active_support/core_ext/array/access'
6
+
7
+ begin
8
+ require 'resque-scheduler'
9
+ rescue LoadError
10
+ begin
11
+ require 'resque_scheduler'
12
+ rescue LoadError
13
+ false
14
+ end
15
+ end
16
+
17
+ module ActiveJob
18
+ module QueueAdapters
19
+ # == Resque adapter for Active Job which disconnects when the job is done
20
+ #
21
+ # require 'active_job/queue_adapters/resque_disconnect_adapter'
22
+ # Rails.application.config.active_job.queue_adapter = ActiveJob::QueueAdapters::ResqueDisconnectAdapter
23
+ class ResqueDisconnectAdapter
24
+ class << self
25
+ def enqueue(job)
26
+ Resque.enqueue_to(job.queue_name, JobWrapper, job.serialize)
27
+ end
28
+
29
+ def enqueue_at(job, timestamp)
30
+ unless Resque.respond_to?(:enqueue_at_with_queue)
31
+ raise NotImplementedError,
32
+ "To be able to schedule jobs with Resque you need the " \
33
+ "resque-scheduler gem. Please add it to your Gemfile and run bundle " \
34
+ "install"
35
+ end
36
+ Resque.enqueue_at_with_queue(job.queue_name, timestamp, JobWrapper, job.serialize)
37
+ end
38
+ end
39
+
40
+ class JobWrapper
41
+ class << self
42
+ def perform(job_data)
43
+ ActiveJob::Base.execute(job_data)
44
+ ensure
45
+ ActiveRecord::Base.connection.disconnect!
46
+ end
47
+ end
48
+ end
49
+ end
50
+ end
51
+ end
@@ -0,0 +1,5 @@
1
+ module ActiveJob
2
+ module QueueAdapters
3
+ RESQUE_DISCONNECT_ADAPTER_VERSION = '0.1.0'.freeze
4
+ end
5
+ end
@@ -0,0 +1,29 @@
1
+ require 'spec_helper'
2
+
3
+ RSpec.describe ActiveJob::QueueAdapters::ResqueDisconnectAdapter::JobWrapper do
4
+ subject(:perform) { described_class.perform(job_data) }
5
+ let(:job_data) { { 'job' => 'data' } }
6
+
7
+ let(:connection) { double(disconnect!: true) }
8
+ before { allow(ActiveJob::Base).to receive(:execute) }
9
+ before { allow(ActiveRecord::Base).to receive(:connection).and_return(connection) }
10
+
11
+ it "executes the job" do
12
+ expect(ActiveJob::Base).to receive(:execute).with('job' => 'data')
13
+ perform
14
+ end
15
+
16
+ it "disconnects from the database" do
17
+ expect(connection).to receive(:disconnect!)
18
+ perform
19
+ end
20
+
21
+ context "when the job raises" do
22
+ before { expect(ActiveJob::Base).to receive(:execute).and_raise('hell') }
23
+
24
+ it "still disconnects" do
25
+ expect(connection).to receive(:disconnect!)
26
+ expect { perform }.to raise_error(RuntimeError, 'hell')
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,28 @@
1
+ require 'spec_helper'
2
+
3
+ RSpec.describe ActiveJob::QueueAdapters::ResqueDisconnectAdapter do
4
+ let(:job) { double(queue_name: :queue, serialize: { 'job' => 'params' }) }
5
+
6
+ describe ".enqueue" do
7
+ subject(:enqueue) { described_class.enqueue(job) }
8
+
9
+ it "enqueues to Resque" do
10
+ expect(Resque).to receive(:enqueue_to).
11
+ with(:queue, described_class::JobWrapper, { 'job' => 'params' })
12
+
13
+ enqueue
14
+ end
15
+ end
16
+
17
+ describe ".enqueue_at" do
18
+ subject(:enqueue_at) { described_class.enqueue_at(job, timestamp) }
19
+ let(:timestamp) { 'time to work' }
20
+
21
+ it "enqueues to Resque" do
22
+ expect(Resque).to receive(:enqueue_at_with_queue).
23
+ with(:queue, timestamp, described_class::JobWrapper, { 'job' => 'params' })
24
+
25
+ enqueue_at
26
+ end
27
+ end
28
+ end
@@ -0,0 +1,20 @@
1
+ require 'active_job/queue_adapters/resque_disconnect_adapter'
2
+ require 'rspec/its'
3
+
4
+ RSpec.configure do |config|
5
+ config.expect_with :rspec do |expectations|
6
+ expectations.include_chain_clauses_in_custom_matcher_descriptions = true
7
+ end
8
+
9
+ config.mock_with :rspec do |mocks|
10
+ mocks.verify_partial_doubles = true
11
+ end
12
+
13
+ config.disable_monkey_patching!
14
+
15
+ config.warnings = true
16
+
17
+ config.order = :random
18
+
19
+ Kernel.srand config.seed
20
+ end
metadata ADDED
@@ -0,0 +1,170 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: activejob-resque-disconnect
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Isaac Seymour
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-01-16 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: activejob
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - '>='
18
+ - !ruby/object:Gem::Version
19
+ version: '4.2'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - '>='
25
+ - !ruby/object:Gem::Version
26
+ version: '4.2'
27
+ - !ruby/object:Gem::Dependency
28
+ name: activerecord
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - '>='
32
+ - !ruby/object:Gem::Version
33
+ version: '4.2'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - '>='
39
+ - !ruby/object:Gem::Version
40
+ version: '4.2'
41
+ - !ruby/object:Gem::Dependency
42
+ name: resque
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - '>='
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - '>='
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: resque-scheduler
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - '>='
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rake
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - '>='
74
+ - !ruby/object:Gem::Version
75
+ version: '10.3'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - '>='
81
+ - !ruby/object:Gem::Version
82
+ version: '10.3'
83
+ - !ruby/object:Gem::Dependency
84
+ name: rspec
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - '>='
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - '>='
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: rspec-its
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - '>='
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - '>='
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: rubocop
113
+ requirement: !ruby/object:Gem::Requirement
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
+ requirements:
122
+ - - '>='
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ description: |2
126
+ If you're using ActiveRecord with Resque, a new database connection will get opened
127
+ for each worker process. When the worker completes, this connection is left open by
128
+ default, which is pretty bad. This adapter closes the connection when the job has_rdoc
129
+ finished executing.
130
+ email:
131
+ - isaac@isaacseymour.co.uk
132
+ executables: []
133
+ extensions: []
134
+ extra_rdoc_files: []
135
+ files:
136
+ - Gemfile
137
+ - Gemfile.lock
138
+ - README.md
139
+ - activejob-resque-disconnect.gemspec
140
+ - lib/active_job/queue_adapters/resque_disconnect_adapter.rb
141
+ - lib/version.rb
142
+ - spec/job_wrapper_spec.rb
143
+ - spec/resque_disconnect_adapter_spec.rb
144
+ - spec/spec_helper.rb
145
+ homepage: http://github.com/gocardless/activejob-resque-disconnect
146
+ licenses:
147
+ - MIT
148
+ metadata: {}
149
+ post_install_message:
150
+ rdoc_options: []
151
+ require_paths:
152
+ - lib
153
+ required_ruby_version: !ruby/object:Gem::Requirement
154
+ requirements:
155
+ - - '>='
156
+ - !ruby/object:Gem::Version
157
+ version: '0'
158
+ required_rubygems_version: !ruby/object:Gem::Requirement
159
+ requirements:
160
+ - - '>='
161
+ - !ruby/object:Gem::Version
162
+ version: '0'
163
+ requirements: []
164
+ rubyforge_project:
165
+ rubygems_version: 2.4.1
166
+ signing_key:
167
+ specification_version: 4
168
+ summary: ActiveJob Resque adapter which disconnects when the job is complete
169
+ test_files: []
170
+ has_rdoc: false