delayed_job_active_record 0.4.4 → 4.0.0.beta1
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.
- data/delayed_job_active_record.gemspec +3 -3
- data/lib/delayed/backend/active_record.rb +33 -32
- data/spec/delayed/backend/active_record_spec.rb +0 -15
- data/spec/helper.rb +1 -1
- metadata +12 -15
| @@ -1,8 +1,8 @@ | |
| 1 1 | 
             
            # coding: utf-8
         | 
| 2 2 |  | 
| 3 3 | 
             
            Gem::Specification.new do |spec|
         | 
| 4 | 
            -
              spec.add_dependency   'activerecord', ['>=  | 
| 5 | 
            -
              spec.add_dependency   'delayed_job', '~>  | 
| 4 | 
            +
              spec.add_dependency   'activerecord', ['>= 3.0', '< 4.1']
         | 
| 5 | 
            +
              spec.add_dependency   'delayed_job', '~> 4.0.0.beta1'
         | 
| 6 6 | 
             
              spec.authors        = ["Brian Ryckbost", "Matt Griffin", "Erik Michaels-Ober"]
         | 
| 7 7 | 
             
              spec.description    = 'ActiveRecord backend for Delayed::Job, originally authored by Tobias Lütke'
         | 
| 8 8 | 
             
              spec.email          = ['bryckbost@gmail.com', 'matt@griffinonline.org', 'sferik@gmail.com']
         | 
| @@ -15,5 +15,5 @@ Gem::Specification.new do |spec| | |
| 15 15 | 
             
              spec.require_paths  = ['lib']
         | 
| 16 16 | 
             
              spec.summary        = 'ActiveRecord backend for DelayedJob'
         | 
| 17 17 | 
             
              spec.test_files     = Dir.glob("spec/**/*")
         | 
| 18 | 
            -
              spec.version        = '0. | 
| 18 | 
            +
              spec.version        = '4.0.0.beta1'
         | 
| 19 19 | 
             
            end
         | 
| @@ -7,8 +7,7 @@ module Delayed | |
| 7 7 | 
             
                  class Job < ::ActiveRecord::Base
         | 
| 8 8 | 
             
                    include Delayed::Backend::Base
         | 
| 9 9 |  | 
| 10 | 
            -
                     | 
| 11 | 
            -
                      :failed_at, :locked_at, :locked_by
         | 
| 10 | 
            +
                    scope :by_priority, lambda { order('priority ASC, run_at ASC') }
         | 
| 12 11 |  | 
| 13 12 | 
             
                    before_save :set_default_run_at
         | 
| 14 13 |  | 
| @@ -23,10 +22,6 @@ module Delayed | |
| 23 22 | 
             
                      where('(run_at <= ? AND (locked_at IS NULL OR locked_at < ?) OR locked_by = ?) AND failed_at IS NULL', db_time_now, db_time_now - max_run_time, worker_name)
         | 
| 24 23 | 
             
                    end
         | 
| 25 24 |  | 
| 26 | 
            -
                    def self.by_priority
         | 
| 27 | 
            -
                      order('priority ASC, run_at ASC')
         | 
| 28 | 
            -
                    end
         | 
| 29 | 
            -
             | 
| 30 25 | 
             
                    def self.before_fork
         | 
| 31 26 | 
             
                      ::ActiveRecord::Base.clear_all_connections!
         | 
| 32 27 | 
             
                    end
         | 
| @@ -42,38 +37,44 @@ module Delayed | |
| 42 37 |  | 
| 43 38 | 
             
                    def self.reserve(worker, max_run_time = Worker.max_run_time)
         | 
| 44 39 | 
             
                      # scope to filter to records that are "ready to run"
         | 
| 45 | 
            -
                       | 
| 40 | 
            +
                      readyScope = self.ready_to_run(worker.name, max_run_time)
         | 
| 46 41 |  | 
| 47 42 | 
             
                      # scope to filter to the single next eligible job
         | 
| 48 | 
            -
                       | 
| 49 | 
            -
                       | 
| 50 | 
            -
                       | 
| 51 | 
            -
                       | 
| 43 | 
            +
                      readyScope = readyScope.where('priority >= ?', Worker.min_priority) if Worker.min_priority
         | 
| 44 | 
            +
                      readyScope = readyScope.where('priority <= ?', Worker.max_priority) if Worker.max_priority
         | 
| 45 | 
            +
                      readyScope = readyScope.where(:queue => Worker.queues) if Worker.queues.any?
         | 
| 46 | 
            +
                      job = readyScope.by_priority.first
         | 
| 52 47 |  | 
| 53 48 | 
             
                      now = self.db_time_now
         | 
| 54 49 |  | 
| 55 | 
            -
                       | 
| 56 | 
            -
                       | 
| 57 | 
            -
             | 
| 58 | 
            -
                         | 
| 59 | 
            -
                         | 
| 60 | 
            -
             | 
| 61 | 
            -
             | 
| 62 | 
            -
             | 
| 63 | 
            -
             | 
| 64 | 
            -
             | 
| 65 | 
            -
             | 
| 66 | 
            -
             | 
| 67 | 
            -
             | 
| 68 | 
            -
             | 
| 69 | 
            -
                         | 
| 70 | 
            -
                        self. | 
| 50 | 
            +
                      return unless job
         | 
| 51 | 
            +
                      job.with_lock do
         | 
| 52 | 
            +
                        job.locked_at = now
         | 
| 53 | 
            +
                        job.locked_by = worker.name
         | 
| 54 | 
            +
                        job.save!
         | 
| 55 | 
            +
                      end
         | 
| 56 | 
            +
                      job
         | 
| 57 | 
            +
                    end
         | 
| 58 | 
            +
             | 
| 59 | 
            +
                    # Lock this job for this worker.
         | 
| 60 | 
            +
                    # Returns true if we have the lock, false otherwise.
         | 
| 61 | 
            +
                    def lock_exclusively!(max_run_time, worker)
         | 
| 62 | 
            +
                      now = self.class.db_time_now
         | 
| 63 | 
            +
                      affected_rows = if locked_by != worker
         | 
| 64 | 
            +
                        # We don't own this job so we will update the locked_by name and the locked_at
         | 
| 65 | 
            +
                        self.class.update_all(["locked_at = ?, locked_by = ?", now, worker], ["id = ? and (locked_at is null or locked_at < ?) and (run_at <= ?)", id, (now - max_run_time.to_i), now])
         | 
| 66 | 
            +
                      else
         | 
| 67 | 
            +
                        # We already own this job, this may happen if the job queue crashes.
         | 
| 68 | 
            +
                        # Simply resume and update the locked_at
         | 
| 69 | 
            +
                        self.class.update_all(["locked_at = ?", now], ["id = ? and locked_by = ?", id, worker])
         | 
| 70 | 
            +
                      end
         | 
| 71 | 
            +
                      if affected_rows == 1
         | 
| 72 | 
            +
                        self.locked_at = now
         | 
| 73 | 
            +
                        self.locked_by = worker
         | 
| 74 | 
            +
                        self.changed_attributes.clear
         | 
| 75 | 
            +
                        return true
         | 
| 71 76 | 
             
                      else
         | 
| 72 | 
            -
                         | 
| 73 | 
            -
                        ready_scope.limit(worker.read_ahead).detect do |job|
         | 
| 74 | 
            -
                          count = ready_scope.where(:id => job.id).update_all(:locked_at => now, :locked_by => worker.name)
         | 
| 75 | 
            -
                          count == 1 && job.reload
         | 
| 76 | 
            -
                        end
         | 
| 77 | 
            +
                        return false
         | 
| 77 78 | 
             
                      end
         | 
| 78 79 | 
             
                    end
         | 
| 79 80 |  | 
| @@ -43,21 +43,6 @@ describe Delayed::Backend::ActiveRecord::Job do | |
| 43 43 | 
             
                end
         | 
| 44 44 | 
             
              end
         | 
| 45 45 |  | 
| 46 | 
            -
              context "ActiveRecord::Base.send(:attr_accessible, nil)" do
         | 
| 47 | 
            -
                before do
         | 
| 48 | 
            -
                  Delayed::Backend::ActiveRecord::Job.send(:attr_accessible, nil)
         | 
| 49 | 
            -
                end
         | 
| 50 | 
            -
             | 
| 51 | 
            -
                after do
         | 
| 52 | 
            -
                  Delayed::Backend::ActiveRecord::Job.send(:attr_accessible, *Delayed::Backend::ActiveRecord::Job.new.attributes.keys)
         | 
| 53 | 
            -
                end
         | 
| 54 | 
            -
             | 
| 55 | 
            -
                it "is still accessible" do
         | 
| 56 | 
            -
                  job = Delayed::Backend::ActiveRecord::Job.enqueue :payload_object => EnqueueJobMod.new
         | 
| 57 | 
            -
                  expect(Delayed::Backend::ActiveRecord::Job.find(job.id).handler).to_not be_blank
         | 
| 58 | 
            -
                end
         | 
| 59 | 
            -
              end
         | 
| 60 | 
            -
             | 
| 61 46 | 
             
              context "ActiveRecord::Base.table_name_prefix" do
         | 
| 62 47 | 
             
                it "when prefix is not set, use 'delayed_jobs' as table name" do
         | 
| 63 48 | 
             
                  ::ActiveRecord::Base.table_name_prefix = nil
         | 
    
        data/spec/helper.rb
    CHANGED
    
    
    
        metadata
    CHANGED
    
    | @@ -1,8 +1,8 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: delayed_job_active_record
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0. | 
| 5 | 
            -
              prerelease: 
         | 
| 4 | 
            +
              version: 4.0.0.beta1
         | 
| 5 | 
            +
              prerelease: 6
         | 
| 6 6 | 
             
            platform: ruby
         | 
| 7 7 | 
             
            authors:
         | 
| 8 8 | 
             
            - Brian Ryckbost
         | 
| @@ -11,7 +11,7 @@ authors: | |
| 11 11 | 
             
            autorequire: 
         | 
| 12 12 | 
             
            bindir: bin
         | 
| 13 13 | 
             
            cert_chain: []
         | 
| 14 | 
            -
            date: 2013- | 
| 14 | 
            +
            date: 2013-03-02 00:00:00.000000000 Z
         | 
| 15 15 | 
             
            dependencies:
         | 
| 16 16 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 17 17 | 
             
              name: activerecord
         | 
| @@ -20,10 +20,10 @@ dependencies: | |
| 20 20 | 
             
                requirements:
         | 
| 21 21 | 
             
                - - ! '>='
         | 
| 22 22 | 
             
                  - !ruby/object:Gem::Version
         | 
| 23 | 
            -
                    version:  | 
| 23 | 
            +
                    version: '3.0'
         | 
| 24 24 | 
             
                - - <
         | 
| 25 25 | 
             
                  - !ruby/object:Gem::Version
         | 
| 26 | 
            -
                    version: '4'
         | 
| 26 | 
            +
                    version: '4.1'
         | 
| 27 27 | 
             
              type: :runtime
         | 
| 28 28 | 
             
              prerelease: false
         | 
| 29 29 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| @@ -31,10 +31,10 @@ dependencies: | |
| 31 31 | 
             
                requirements:
         | 
| 32 32 | 
             
                - - ! '>='
         | 
| 33 33 | 
             
                  - !ruby/object:Gem::Version
         | 
| 34 | 
            -
                    version:  | 
| 34 | 
            +
                    version: '3.0'
         | 
| 35 35 | 
             
                - - <
         | 
| 36 36 | 
             
                  - !ruby/object:Gem::Version
         | 
| 37 | 
            -
                    version: '4'
         | 
| 37 | 
            +
                    version: '4.1'
         | 
| 38 38 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 39 39 | 
             
              name: delayed_job
         | 
| 40 40 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| @@ -42,7 +42,7 @@ dependencies: | |
| 42 42 | 
             
                requirements:
         | 
| 43 43 | 
             
                - - ~>
         | 
| 44 44 | 
             
                  - !ruby/object:Gem::Version
         | 
| 45 | 
            -
                    version:  | 
| 45 | 
            +
                    version: 4.0.0.beta1
         | 
| 46 46 | 
             
              type: :runtime
         | 
| 47 47 | 
             
              prerelease: false
         | 
| 48 48 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| @@ -50,7 +50,7 @@ dependencies: | |
| 50 50 | 
             
                requirements:
         | 
| 51 51 | 
             
                - - ~>
         | 
| 52 52 | 
             
                  - !ruby/object:Gem::Version
         | 
| 53 | 
            -
                    version:  | 
| 53 | 
            +
                    version: 4.0.0.beta1
         | 
| 54 54 | 
             
            description: ActiveRecord backend for Delayed::Job, originally authored by Tobias
         | 
| 55 55 | 
             
              Lütke
         | 
| 56 56 | 
             
            email:
         | 
| @@ -91,16 +91,13 @@ required_ruby_version: !ruby/object:Gem::Requirement | |
| 91 91 | 
             
                  version: '0'
         | 
| 92 92 | 
             
                  segments:
         | 
| 93 93 | 
             
                  - 0
         | 
| 94 | 
            -
                  hash:  | 
| 94 | 
            +
                  hash: 3791598084815033964
         | 
| 95 95 | 
             
            required_rubygems_version: !ruby/object:Gem::Requirement
         | 
| 96 96 | 
             
              none: false
         | 
| 97 97 | 
             
              requirements:
         | 
| 98 | 
            -
              - - ! ' | 
| 98 | 
            +
              - - ! '>'
         | 
| 99 99 | 
             
                - !ruby/object:Gem::Version
         | 
| 100 | 
            -
                  version:  | 
| 101 | 
            -
                  segments:
         | 
| 102 | 
            -
                  - 0
         | 
| 103 | 
            -
                  hash: 1565525879185101901
         | 
| 100 | 
            +
                  version: 1.3.1
         | 
| 104 101 | 
             
            requirements: []
         | 
| 105 102 | 
             
            rubyforge_project: 
         | 
| 106 103 | 
             
            rubygems_version: 1.8.25
         |