historian_djdm 1.0.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 6ef0a12da533f81fbae28bc99ad19803e2d79bf2
4
+ data.tar.gz: dbc173667ce35fcb34242bc1085166ab1ce40de0
5
+ SHA512:
6
+ metadata.gz: a1476418b98a2c8e2ae3054d98206985c4b82c41474a625337a103fea2612613a68b8c73beaff2a2a606afb99404e88ca984834bc388b70d296933f3eb751eff
7
+ data.tar.gz: 0bc9d7a6f56086e935d972e16dd7496c56e4df58fb37e8bc3765f912e327601e4ed02137be0e8388953faceabf23f873f7fde601e36302af729dc98ee95c06e1
data/LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright © 2010 Collective Idea
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,15 @@
1
+ # delayed_job DataMapper backend
2
+
3
+ ## Installation
4
+
5
+ Add the gems to you Gemfile:
6
+
7
+ gem 'delayed_job', '2.1.0.pre2'
8
+ gem 'delayed_job_data_mapper', '1.0.0.rc'
9
+
10
+ Add this in an initializer:
11
+
12
+ # config/initializers/delayed_job.rb
13
+ Delayed::Worker.backend.auto_upgrade!
14
+
15
+ That's it. Use [delayed_job as normal](http://github.com/collectiveidea/delayed_job).
@@ -0,0 +1,105 @@
1
+ module Delayed
2
+ module Backend
3
+ module DataMapper
4
+ class Job
5
+ include ::DataMapper::Resource
6
+ include Delayed::Backend::Base
7
+
8
+ storage_names[:default] = 'delayed_jobs'
9
+
10
+ property :id, Serial
11
+ property :priority, Integer, :default => 0, :index => :run_at_priority
12
+ property :attempts, Integer, :default => 0
13
+ property :handler, Text, :lazy => false
14
+ property :run_at, Time, :index => :run_at_priority
15
+ property :locked_at, Time, :index => true
16
+ property :locked_by, String
17
+ property :failed_at, Time
18
+ property :last_error, Text
19
+
20
+ def self.db_time_now
21
+ Time.now
22
+ end
23
+
24
+ def self.find_available(worker_name, limit = 5, max_run_time = Worker.max_run_time)
25
+
26
+ simple_conditions = { :run_at.lte => db_time_now, :limit => limit, :failed_at => nil, :order => [:priority.asc, :run_at.asc] }
27
+
28
+ # respect priorities
29
+ simple_conditions[:priority.gte] = Worker.min_priority if Worker.min_priority
30
+ simple_conditions[:priority.lte] = Worker.max_priority if Worker.max_priority
31
+
32
+ # lockable
33
+ lockable = (
34
+ # not locked or past the max time
35
+ ( all(:locked_at => nil ) | all(:locked_at.lt => db_time_now - max_run_time)) |
36
+
37
+ # OR locked by our worker
38
+ all(:locked_by => worker_name))
39
+
40
+ # plus some other boring junk
41
+ (lockable).all( simple_conditions )
42
+ end
43
+
44
+ # When a worker is exiting, make sure we don't have any locked jobs.
45
+ def self.clear_locks!(worker_name)
46
+ all(:locked_by => worker_name).update(:locked_at => nil, :locked_by => nil)
47
+ end
48
+
49
+ # Lock this job for this worker.
50
+ # Returns true if we have the lock, false otherwise.
51
+ def lock_exclusively!(max_run_time, worker = worker_name)
52
+
53
+ now = self.class.db_time_now
54
+ overtime = now - max_run_time
55
+
56
+ # FIXME - this is a bit gross
57
+ # DM doesn't give us the number of rows affected by a collection update
58
+ # so we have to circumvent some niceness in DM::Collection here
59
+ collection = locked_by != worker ?
60
+ (self.class.all(:id => id, :run_at.lte => now) & ( self.class.all(:locked_at => nil) | self.class.all(:locked_at.lt => overtime) ) ) :
61
+ self.class.all(:id => id, :locked_by => worker)
62
+
63
+ attributes = collection.model.new(:locked_at => now, :locked_by => worker).dirty_attributes
64
+ affected_rows = self.repository.update(attributes, collection)
65
+
66
+ if affected_rows == 1
67
+ self.locked_at = now
68
+ self.locked_by = worker
69
+ return true
70
+ else
71
+ return false
72
+ end
73
+ end
74
+
75
+ # these are common to the other backends, so we provide an implementation
76
+ def self.delete_all
77
+ Delayed::Job.auto_migrate!
78
+ end
79
+
80
+ def self.find id
81
+ get id
82
+ end
83
+
84
+ def update_attributes(attributes)
85
+ attributes.each do |k,v|
86
+ self[k] = v
87
+ end
88
+ self.save
89
+ end
90
+
91
+
92
+ end
93
+
94
+ class JobObserver
95
+ include ::DataMapper::Observer
96
+
97
+ observe Job
98
+
99
+ before :save do
100
+ self.run_at ||= self.class.db_time_now
101
+ end
102
+ end
103
+ end
104
+ end
105
+ end
@@ -0,0 +1,11 @@
1
+ DataMapper::Resource.class_eval do
2
+ yaml_as "tag:ruby.yaml.org,2002:DataMapper"
3
+
4
+ def self.yaml_new(klass, tag, val)
5
+ klass.find(val['id'])
6
+ end
7
+
8
+ def to_yaml_properties
9
+ ['@id']
10
+ end
11
+ end
@@ -0,0 +1,8 @@
1
+ require 'dm-core'
2
+ require 'dm-observer'
3
+ require 'dm-aggregates'
4
+ require 'delayed_job'
5
+ require 'delayed/serialization/data_mapper'
6
+ require 'delayed/backend/data_mapper'
7
+
8
+ Delayed::Worker.backend = :data_mapper
@@ -0,0 +1,5 @@
1
+ require 'spec_helper'
2
+
3
+ describe Delayed::Backend::DataMapper::Job do
4
+ it_should_behave_like 'a delayed_job backend'
5
+ end
@@ -0,0 +1 @@
1
+ --color
@@ -0,0 +1,29 @@
1
+ require 'rubygems'
2
+ require 'bundler/setup'
3
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
4
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
5
+ require 'spec'
6
+ require 'spec/autorun'
7
+ require 'delayed_job_data_mapper'
8
+ require 'delayed/backend/shared_spec'
9
+
10
+ Spec::Runner.configure do |config|
11
+
12
+ end
13
+
14
+ require 'dm-migrations'
15
+ DataMapper.setup(:default, "sqlite3::memory:")
16
+
17
+ class Story
18
+ include DataMapper::Resource
19
+ property :id, Serial
20
+ property :text, String
21
+ def tell; text; end
22
+ def whatever(n, _); tell*n; end
23
+ def self.count; end
24
+
25
+ handle_asynchronously :whatever
26
+ end
27
+
28
+ DataMapper.auto_migrate!
29
+
metadata ADDED
@@ -0,0 +1,126 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: historian_djdm
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Brandon Keepers
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-03-08 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: dm-core
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: 1.2.0
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: 1.2.0
27
+ - !ruby/object:Gem::Dependency
28
+ name: dm-observer
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: 1.2.0
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: 1.2.0
41
+ - !ruby/object:Gem::Dependency
42
+ name: dm-aggregates
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: 1.2.0
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: 1.2.0
55
+ - !ruby/object:Gem::Dependency
56
+ name: delayed_job
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '2.1'
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '2.1'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rspec
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: 1.2.9
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: 1.2.9
83
+ description:
84
+ email: brandon@collectiveidea.com
85
+ executables: []
86
+ extensions: []
87
+ extra_rdoc_files:
88
+ - LICENSE
89
+ - README.md
90
+ files:
91
+ - LICENSE
92
+ - README.md
93
+ - lib/delayed/backend/data_mapper.rb
94
+ - lib/delayed/serialization/data_mapper.rb
95
+ - lib/delayed_job_data_mapper.rb
96
+ - spec/delayed_job_data_mapper_spec.rb
97
+ - spec/spec.opts
98
+ - spec/spec_helper.rb
99
+ homepage: http://github.com/l33t-historian/historian_djdm
100
+ licenses: []
101
+ metadata: {}
102
+ post_install_message:
103
+ rdoc_options:
104
+ - "--charset=UTF-8"
105
+ require_paths:
106
+ - lib
107
+ required_ruby_version: !ruby/object:Gem::Requirement
108
+ requirements:
109
+ - - ">="
110
+ - !ruby/object:Gem::Version
111
+ version: '0'
112
+ required_rubygems_version: !ruby/object:Gem::Requirement
113
+ requirements:
114
+ - - ">="
115
+ - !ruby/object:Gem::Version
116
+ version: '0'
117
+ requirements: []
118
+ rubyforge_project:
119
+ rubygems_version: 2.4.8
120
+ signing_key:
121
+ specification_version: 4
122
+ summary: 'Historian Version: DataMapper backend for delayed_job'
123
+ test_files:
124
+ - spec/spec_helper.rb
125
+ - spec/spec.opts
126
+ - spec/delayed_job_data_mapper_spec.rb