sidejobs 4.0.0.2 → 5.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.
- checksums.yaml +4 -4
- data/MIT-LICENSE +1 -1
- data/README.md +5 -5
- data/Rakefile +1 -3
- data/lib/sidejobs.rb +2 -1
- data/lib/sidejobs/daemon.rb +35 -33
- data/lib/sidejobs/extensions/active_job/queue_adapter.rb +29 -31
- data/lib/sidejobs/loggable.rb +7 -0
- data/lib/sidejobs/processor.rb +1 -6
- data/lib/sidejobs/queue.rb +1 -1
- data/lib/sidejobs/version.rb +1 -1
- metadata +16 -125
- data/test/daemon_test.rb +0 -71
- data/test/dummy/Rakefile +0 -5
- data/test/dummy/app/assets/javascripts/application.js +0 -13
- data/test/dummy/app/assets/stylesheets/application.css +0 -15
- data/test/dummy/app/controllers/application_controller.rb +0 -5
- data/test/dummy/app/helpers/application_helper.rb +0 -2
- data/test/dummy/app/jobs/charge_subscriptions_job.rb +0 -8
- data/test/dummy/app/jobs/clear_guest_users_job.rb +0 -8
- data/test/dummy/app/jobs/send_newsletters_job.rb +0 -8
- data/test/dummy/app/jobs/share_products_job.rb +0 -8
- data/test/dummy/app/jobs/update_exchanges_job.rb +0 -8
- data/test/dummy/app/mailers/user_mailer.rb +0 -7
- data/test/dummy/app/views/layouts/application.html.erb +0 -12
- data/test/dummy/app/views/user_mailer/invite.text.erb +0 -1
- data/test/dummy/bin/bundle +0 -4
- data/test/dummy/bin/rails +0 -5
- data/test/dummy/bin/rake +0 -5
- data/test/dummy/bin/setup +0 -30
- data/test/dummy/config.ru +0 -4
- data/test/dummy/config/application.rb +0 -25
- data/test/dummy/config/boot.rb +0 -5
- data/test/dummy/config/database.yml +0 -10
- data/test/dummy/config/database.yml.travis +0 -3
- data/test/dummy/config/environment.rb +0 -5
- data/test/dummy/config/environments/development.rb +0 -44
- data/test/dummy/config/environments/production.rb +0 -79
- data/test/dummy/config/environments/test.rb +0 -45
- data/test/dummy/config/initializers/assets.rb +0 -11
- data/test/dummy/config/initializers/backtrace_silencers.rb +0 -7
- data/test/dummy/config/initializers/cookies_serializer.rb +0 -3
- data/test/dummy/config/initializers/filter_parameter_logging.rb +0 -4
- data/test/dummy/config/initializers/inflections.rb +0 -16
- data/test/dummy/config/initializers/mime_types.rb +0 -4
- data/test/dummy/config/initializers/session_store.rb +0 -3
- data/test/dummy/config/initializers/sidejobs.rb +0 -7
- data/test/dummy/config/initializers/wrap_parameters.rb +0 -14
- data/test/dummy/config/locales/en.yml +0 -23
- data/test/dummy/config/routes.rb +0 -56
- data/test/dummy/config/secrets.yml +0 -22
- data/test/dummy/db/migrate/20161022211612_create_sidejobs.rb +0 -21
- data/test/dummy/db/schema.rb +0 -37
- data/test/dummy/log/development.log +0 -23
- data/test/dummy/log/sidejobs.log +0 -739
- data/test/dummy/log/test.log +0 -3903
- data/test/dummy/public/404.html +0 -61
- data/test/dummy/public/422.html +0 -61
- data/test/dummy/public/500.html +0 -60
- data/test/dummy/public/favicon.ico +0 -0
- data/test/generator_test.rb +0 -19
- data/test/processor_test.rb +0 -49
- data/test/queue_test.rb +0 -69
- data/test/test_helper.rb +0 -14
data/test/dummy/public/404.html
DELETED
@@ -1,61 +0,0 @@
|
|
1
|
-
<!DOCTYPE html>
|
2
|
-
<html>
|
3
|
-
<head>
|
4
|
-
<title>The page you were looking for doesn't exist (404)</title>
|
5
|
-
<meta name="viewport" content="width=device-width,initial-scale=1">
|
6
|
-
<style>
|
7
|
-
body {
|
8
|
-
background-color: #EFEFEF;
|
9
|
-
color: #2E2F30;
|
10
|
-
text-align: center;
|
11
|
-
font-family: arial, sans-serif;
|
12
|
-
margin: 0;
|
13
|
-
}
|
14
|
-
div.dialog {
|
15
|
-
width: 95%;
|
16
|
-
max-width: 33em;
|
17
|
-
margin: 4em auto 0;
|
18
|
-
}
|
19
|
-
div.dialog > div {
|
20
|
-
border: 1px solid #CCC;
|
21
|
-
border-right-color: #999;
|
22
|
-
border-left-color: #999;
|
23
|
-
border-bottom-color: #BBB;
|
24
|
-
border-top: #B00100 solid 4px;
|
25
|
-
border-top-left-radius: 9px;
|
26
|
-
border-top-right-radius: 9px;
|
27
|
-
background-color: white;
|
28
|
-
padding: 7px 12% 0;
|
29
|
-
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
30
|
-
}
|
31
|
-
h1 {
|
32
|
-
font-size: 100%;
|
33
|
-
color: #730E15;
|
34
|
-
line-height: 1.5em;
|
35
|
-
}
|
36
|
-
div.dialog > p {
|
37
|
-
margin: 0 0 1em;
|
38
|
-
padding: 1em;
|
39
|
-
background-color: #F7F7F7;
|
40
|
-
border: 1px solid #CCC;
|
41
|
-
border-right-color: #999;
|
42
|
-
border-left-color: #999;
|
43
|
-
border-bottom-color: #999;
|
44
|
-
border-bottom-left-radius: 4px;
|
45
|
-
border-bottom-right-radius: 4px;
|
46
|
-
border-top-color: #DADADA;
|
47
|
-
color: #666;
|
48
|
-
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
49
|
-
}
|
50
|
-
</style>
|
51
|
-
</head>
|
52
|
-
<body>
|
53
|
-
<div class="dialog">
|
54
|
-
<div>
|
55
|
-
<h1>The page you were looking for doesn't exist.</h1>
|
56
|
-
<p>You may have mistyped the address or the page may have moved.</p>
|
57
|
-
</div>
|
58
|
-
<p>If you are the application owner check the logs for more information.</p>
|
59
|
-
</div>
|
60
|
-
</body>
|
61
|
-
</html>
|
data/test/dummy/public/422.html
DELETED
@@ -1,61 +0,0 @@
|
|
1
|
-
<!DOCTYPE html>
|
2
|
-
<html>
|
3
|
-
<head>
|
4
|
-
<title>The change you wanted was rejected (422)</title>
|
5
|
-
<meta name="viewport" content="width=device-width,initial-scale=1">
|
6
|
-
<style>
|
7
|
-
body {
|
8
|
-
background-color: #EFEFEF;
|
9
|
-
color: #2E2F30;
|
10
|
-
text-align: center;
|
11
|
-
font-family: arial, sans-serif;
|
12
|
-
margin: 0;
|
13
|
-
}
|
14
|
-
div.dialog {
|
15
|
-
width: 95%;
|
16
|
-
max-width: 33em;
|
17
|
-
margin: 4em auto 0;
|
18
|
-
}
|
19
|
-
div.dialog > div {
|
20
|
-
border: 1px solid #CCC;
|
21
|
-
border-right-color: #999;
|
22
|
-
border-left-color: #999;
|
23
|
-
border-bottom-color: #BBB;
|
24
|
-
border-top: #B00100 solid 4px;
|
25
|
-
border-top-left-radius: 9px;
|
26
|
-
border-top-right-radius: 9px;
|
27
|
-
background-color: white;
|
28
|
-
padding: 7px 12% 0;
|
29
|
-
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
30
|
-
}
|
31
|
-
h1 {
|
32
|
-
font-size: 100%;
|
33
|
-
color: #730E15;
|
34
|
-
line-height: 1.5em;
|
35
|
-
}
|
36
|
-
div.dialog > p {
|
37
|
-
margin: 0 0 1em;
|
38
|
-
padding: 1em;
|
39
|
-
background-color: #F7F7F7;
|
40
|
-
border: 1px solid #CCC;
|
41
|
-
border-right-color: #999;
|
42
|
-
border-left-color: #999;
|
43
|
-
border-bottom-color: #999;
|
44
|
-
border-bottom-left-radius: 4px;
|
45
|
-
border-bottom-right-radius: 4px;
|
46
|
-
border-top-color: #DADADA;
|
47
|
-
color: #666;
|
48
|
-
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
49
|
-
}
|
50
|
-
</style>
|
51
|
-
</head>
|
52
|
-
<body>
|
53
|
-
<div class="dialog">
|
54
|
-
<div>
|
55
|
-
<h1>The change you wanted was rejected.</h1>
|
56
|
-
<p>Maybe you tried to change something you didn't have access to.</p>
|
57
|
-
</div>
|
58
|
-
<p>If you are the application owner check the logs for more information.</p>
|
59
|
-
</div>
|
60
|
-
</body>
|
61
|
-
</html>
|
data/test/dummy/public/500.html
DELETED
@@ -1,60 +0,0 @@
|
|
1
|
-
<!DOCTYPE html>
|
2
|
-
<html>
|
3
|
-
<head>
|
4
|
-
<title>We're sorry, but something went wrong (500)</title>
|
5
|
-
<meta name="viewport" content="width=device-width,initial-scale=1">
|
6
|
-
<style>
|
7
|
-
body {
|
8
|
-
background-color: #EFEFEF;
|
9
|
-
color: #2E2F30;
|
10
|
-
text-align: center;
|
11
|
-
font-family: arial, sans-serif;
|
12
|
-
margin: 0;
|
13
|
-
}
|
14
|
-
div.dialog {
|
15
|
-
width: 95%;
|
16
|
-
max-width: 33em;
|
17
|
-
margin: 4em auto 0;
|
18
|
-
}
|
19
|
-
div.dialog > div {
|
20
|
-
border: 1px solid #CCC;
|
21
|
-
border-right-color: #999;
|
22
|
-
border-left-color: #999;
|
23
|
-
border-bottom-color: #BBB;
|
24
|
-
border-top: #B00100 solid 4px;
|
25
|
-
border-top-left-radius: 9px;
|
26
|
-
border-top-right-radius: 9px;
|
27
|
-
background-color: white;
|
28
|
-
padding: 7px 12% 0;
|
29
|
-
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
30
|
-
}
|
31
|
-
h1 {
|
32
|
-
font-size: 100%;
|
33
|
-
color: #730E15;
|
34
|
-
line-height: 1.5em;
|
35
|
-
}
|
36
|
-
div.dialog > p {
|
37
|
-
margin: 0 0 1em;
|
38
|
-
padding: 1em;
|
39
|
-
background-color: #F7F7F7;
|
40
|
-
border: 1px solid #CCC;
|
41
|
-
border-right-color: #999;
|
42
|
-
border-left-color: #999;
|
43
|
-
border-bottom-color: #999;
|
44
|
-
border-bottom-left-radius: 4px;
|
45
|
-
border-bottom-right-radius: 4px;
|
46
|
-
border-top-color: #DADADA;
|
47
|
-
color: #666;
|
48
|
-
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
49
|
-
}
|
50
|
-
</style>
|
51
|
-
</head>
|
52
|
-
<body>
|
53
|
-
<div class="dialog">
|
54
|
-
<div>
|
55
|
-
<h1>We're sorry, but something went wrong.</h1>
|
56
|
-
</div>
|
57
|
-
<p>If you are the application owner check the logs for more information.</p>
|
58
|
-
</div>
|
59
|
-
</body>
|
60
|
-
</html>
|
File without changes
|
data/test/generator_test.rb
DELETED
@@ -1,19 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
require 'rails/generators'
|
3
|
-
require 'generators/sidejobs/install/install_generator'
|
4
|
-
|
5
|
-
class GeneratorsTest < Rails::Generators::TestCase
|
6
|
-
destination Rails.root.join('tmp')
|
7
|
-
|
8
|
-
teardown do
|
9
|
-
FileUtils.rm_rf destination_root
|
10
|
-
end
|
11
|
-
|
12
|
-
test 'install' do
|
13
|
-
self.class.tests Sidejobs::Generators::InstallGenerator
|
14
|
-
run_generator
|
15
|
-
assert_file 'config/initializers/sidejobs.rb'
|
16
|
-
assert_migration 'db/migrate/create_sidejobs.rb'
|
17
|
-
end
|
18
|
-
|
19
|
-
end
|
data/test/processor_test.rb
DELETED
@@ -1,49 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
class ProcessorTest < ActiveSupport::TestCase
|
4
|
-
|
5
|
-
setup do
|
6
|
-
@processor = Sidejobs::Processor.new
|
7
|
-
@batch_size = Sidejobs.configuration.batch_size
|
8
|
-
@max_attempts = Sidejobs.configuration.max_attempts
|
9
|
-
end
|
10
|
-
|
11
|
-
test 'process' do
|
12
|
-
UserMailer.invite('test@mail.com').deliver_later
|
13
|
-
@processor.process
|
14
|
-
job = Sidejobs::Job.last
|
15
|
-
assert job.complete?
|
16
|
-
assert_nil job.error
|
17
|
-
assert_equal 1, job.attempts
|
18
|
-
assert_operator job.completed_at, :>, job.processed_at
|
19
|
-
end
|
20
|
-
|
21
|
-
test 'batch' do
|
22
|
-
(@batch_size + 4).times do
|
23
|
-
UserMailer.invite('test@mail.com').deliver_later
|
24
|
-
end
|
25
|
-
@processor.process
|
26
|
-
assert_equal @batch_size, Sidejobs::Job.complete.count
|
27
|
-
assert_equal 0, Sidejobs::Job.processing.count
|
28
|
-
assert_equal 4, Sidejobs::Job.pending.count
|
29
|
-
|
30
|
-
Sidejobs::Job.last.update status: 'processing', processed_at: Time.now
|
31
|
-
@processor.process
|
32
|
-
assert_equal (@batch_size + 3), Sidejobs::Job.complete.count
|
33
|
-
assert_equal 1, Sidejobs::Job.processing.count
|
34
|
-
assert_equal 0, Sidejobs::Job.pending.count
|
35
|
-
end
|
36
|
-
|
37
|
-
test 'retries' do
|
38
|
-
ShareProductsJob.perform_later
|
39
|
-
(@max_attempts + 1).times do
|
40
|
-
@processor.process
|
41
|
-
end
|
42
|
-
job = Sidejobs::Job.last
|
43
|
-
assert job.failing?
|
44
|
-
assert_equal 'Social network unavailable', job.error
|
45
|
-
assert_equal @max_attempts, job.attempts
|
46
|
-
assert_operator job.failed_at, :>, job.processed_at
|
47
|
-
end
|
48
|
-
|
49
|
-
end
|
data/test/queue_test.rb
DELETED
@@ -1,69 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
class QueueTest < ActiveSupport::TestCase
|
4
|
-
|
5
|
-
test 'enqueue' do
|
6
|
-
UserMailer.invite('test@mail.com').deliver_later
|
7
|
-
job = Sidejobs::Job.last
|
8
|
-
assert_equal 'mailers', job.queue
|
9
|
-
assert_equal 80, job.priority
|
10
|
-
assert_nil job.scheduled_at
|
11
|
-
|
12
|
-
ChargeSubscriptionsJob.perform_later
|
13
|
-
job = Sidejobs::Job.last
|
14
|
-
assert_equal 'high_priority', job.queue
|
15
|
-
assert_equal 60, job.priority
|
16
|
-
assert_nil job.scheduled_at
|
17
|
-
|
18
|
-
SendNewslettersJob.perform_later
|
19
|
-
job = Sidejobs::Job.last
|
20
|
-
assert_equal 'default', job.queue
|
21
|
-
assert_equal 40, job.priority
|
22
|
-
assert_nil job.scheduled_at
|
23
|
-
|
24
|
-
UpdateExchangesJob.perform_later
|
25
|
-
job = Sidejobs::Job.last
|
26
|
-
assert_equal 'low_priority', job.queue
|
27
|
-
assert_equal 20, job.priority
|
28
|
-
assert_nil job.scheduled_at
|
29
|
-
|
30
|
-
ClearGuestUsersJob.perform_later
|
31
|
-
job = Sidejobs::Job.last
|
32
|
-
assert_equal 'other', job.queue
|
33
|
-
assert_equal 0, job.priority
|
34
|
-
assert_nil job.scheduled_at
|
35
|
-
|
36
|
-
time = 10.hours.from_now
|
37
|
-
|
38
|
-
UserMailer.invite('test@mail.com').deliver_later wait_until: time
|
39
|
-
job = Sidejobs::Job.last
|
40
|
-
assert_equal 'mailers', job.queue
|
41
|
-
assert_equal 80, job.priority
|
42
|
-
assert_equal time.to_i, job.scheduled_at.to_i
|
43
|
-
|
44
|
-
ChargeSubscriptionsJob.set(wait_until: time).perform_later
|
45
|
-
job = Sidejobs::Job.last
|
46
|
-
assert_equal 'high_priority', job.queue
|
47
|
-
assert_equal 60, job.priority
|
48
|
-
assert_equal time.to_i, job.scheduled_at.to_i
|
49
|
-
|
50
|
-
SendNewslettersJob.set(wait_until: time).perform_later
|
51
|
-
job = Sidejobs::Job.last
|
52
|
-
assert_equal 'default', job.queue
|
53
|
-
assert_equal 40, job.priority
|
54
|
-
assert_equal time.to_i, job.scheduled_at.to_i
|
55
|
-
|
56
|
-
UpdateExchangesJob.set(wait_until: time).perform_later
|
57
|
-
job = Sidejobs::Job.last
|
58
|
-
assert_equal 'low_priority', job.queue
|
59
|
-
assert_equal 20, job.priority
|
60
|
-
assert_equal time.to_i, job.scheduled_at.to_i
|
61
|
-
|
62
|
-
ClearGuestUsersJob.set(wait_until: time).perform_later
|
63
|
-
job = Sidejobs::Job.last
|
64
|
-
assert_equal 'other', job.queue
|
65
|
-
assert_equal 0, job.priority
|
66
|
-
assert_equal time.to_i, job.scheduled_at.to_i
|
67
|
-
end
|
68
|
-
|
69
|
-
end
|
data/test/test_helper.rb
DELETED
@@ -1,14 +0,0 @@
|
|
1
|
-
# Configure Rails Environment
|
2
|
-
ENV['RAILS_ENV'] = 'test'
|
3
|
-
|
4
|
-
require File.expand_path('../../test/dummy/config/environment.rb', __FILE__)
|
5
|
-
ActiveRecord::Migrator.migrations_paths = [File.expand_path('../../test/dummy/db/migrate', __FILE__)]
|
6
|
-
require 'rails/test_help'
|
7
|
-
require 'mocha/mini_test'
|
8
|
-
|
9
|
-
# Filter out Minitest backtrace while allowing backtrace from other libraries
|
10
|
-
# to be shown.
|
11
|
-
Minitest.backtrace_filter = Minitest::BacktraceFilter.new
|
12
|
-
|
13
|
-
# Load support files
|
14
|
-
Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f }
|