resque-serializer 0.1.2 → 0.2.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/.travis.yml +7 -1
- data/README.md +2 -0
- data/lib/resque-serializer.rb +15 -0
- data/lib/resque-serializer/configuration.rb +17 -0
- data/lib/resque-serializer/serializers/both.rb +10 -4
- data/lib/resque-serializer/serializers/combined.rb +9 -3
- data/lib/resque-serializer/serializers/job.rb +9 -3
- data/lib/resque-serializer/serializers/queue.rb +9 -3
- data/lib/resque-serializer/version.rb +1 -1
- data/resque-serializer.gemspec +1 -1
- data/spec/lib/resque-serializer/configuration_spec.rb +20 -0
- data/spec/lib/resque-serializer/monkey_patches/resque_spec.rb +26 -20
- metadata +8 -5
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA1:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: e19f511e3d84751b8359d10bc720553f12913441
         | 
| 4 | 
            +
              data.tar.gz: 61f90b030888dc87b9d48f80fbbb055d8a146d8a
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 69f66ddd96c466cbd26003cebe46fcb5d8b4fd01a74699c420f24b5a5ca45b792a346a76f150c6ca3c3f4e337d67cef8e83a3c13c909f4faea0b2e4acbae11dd
         | 
| 7 | 
            +
              data.tar.gz: 2dee6c43493e437631f57d5e19f709463c34bca7412f0ce53d6964cf71a92e907686d1c9e66ab0626e897b7e2a5e4b36d4e0dd62d0ca3a16502c463a84f1010f
         | 
    
        data/.travis.yml
    CHANGED
    
    
    
        data/README.md
    CHANGED
    
    | @@ -1,5 +1,7 @@ | |
| 1 1 | 
             
            # Resque::Serializer
         | 
| 2 2 |  | 
| 3 | 
            +
            [](https://travis-ci.org/rringler/resque-serializer)
         | 
| 4 | 
            +
             | 
| 3 5 | 
             
            A Resque plugin which ensures for a given queue, that only one worker is executing a job at any given time.
         | 
| 4 6 |  | 
| 5 7 | 
             
            It is slightly more flexible than [Resque::LonelyJob](https://github.com/wallace/resque-lonely_job).
         | 
    
        data/lib/resque-serializer.rb
    CHANGED
    
    | @@ -1,3 +1,5 @@ | |
| 1 | 
            +
            require 'resque'
         | 
| 2 | 
            +
            require 'resque-serializer/configuration'
         | 
| 1 3 | 
             
            require 'resque-serializer/version'
         | 
| 2 4 | 
             
            require 'resque-serializer/monkey_patches/resque'
         | 
| 3 5 | 
             
            require 'resque-serializer/mutex'
         | 
| @@ -9,6 +11,16 @@ require 'resque-serializer/serializers/queue' | |
| 9 11 | 
             
            module Resque
         | 
| 10 12 | 
             
              module Plugins
         | 
| 11 13 | 
             
                module Serializer
         | 
| 14 | 
            +
                  class << self
         | 
| 15 | 
            +
                    attr_accessor :configuration
         | 
| 16 | 
            +
             | 
| 17 | 
            +
                    def configure(&block)
         | 
| 18 | 
            +
                      self.configuration ||= Configuration.instance
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                      yield(configuration)
         | 
| 21 | 
            +
                    end
         | 
| 22 | 
            +
                  end
         | 
| 23 | 
            +
             | 
| 12 24 | 
             
                  def serialize(resource)
         | 
| 13 25 | 
             
                    case resource
         | 
| 14 26 | 
             
                    when :job      then extend(Serializers::Job)
         | 
| @@ -31,3 +43,6 @@ module Resque | |
| 31 43 | 
             
                end
         | 
| 32 44 | 
             
              end
         | 
| 33 45 | 
             
            end
         | 
| 46 | 
            +
             | 
| 47 | 
            +
            # Use default configuration
         | 
| 48 | 
            +
            Resque::Plugins::Serializer.configure {}
         | 
| @@ -0,0 +1,17 @@ | |
| 1 | 
            +
            module Resque
         | 
| 2 | 
            +
              module Plugins
         | 
| 3 | 
            +
                module Serializer
         | 
| 4 | 
            +
                  class Configuration
         | 
| 5 | 
            +
                    include Singleton
         | 
| 6 | 
            +
             | 
| 7 | 
            +
                    attr_accessor :mutex_generator
         | 
| 8 | 
            +
             | 
| 9 | 
            +
                    DEFAULT_MUTEX_GENERATOR = ->(key) { Serializer::Mutex.new(key) }
         | 
| 10 | 
            +
             | 
| 11 | 
            +
                    def initialize
         | 
| 12 | 
            +
                      @mutex_generator = DEFAULT_MUTEX_GENERATOR
         | 
| 13 | 
            +
                    end
         | 
| 14 | 
            +
                  end
         | 
| 15 | 
            +
                end
         | 
| 16 | 
            +
              end
         | 
| 17 | 
            +
            end
         | 
| @@ -32,16 +32,22 @@ module Resque | |
| 32 32 | 
             
                        job_mutex(args).unlock
         | 
| 33 33 | 
             
                      end
         | 
| 34 34 |  | 
| 35 | 
            +
                      private
         | 
| 36 | 
            +
             | 
| 37 | 
            +
                      delegate :configuration,
         | 
| 38 | 
            +
                        to: Resque::Plugins::Serializer
         | 
| 39 | 
            +
             | 
| 40 | 
            +
                      delegate :mutex_generator,
         | 
| 41 | 
            +
                        to: :configuration
         | 
| 42 | 
            +
             | 
| 35 43 | 
             
                      def queue_mutex(args)
         | 
| 36 | 
            -
                         | 
| 44 | 
            +
                        mutex_generator.call(queue_key(args))
         | 
| 37 45 | 
             
                      end
         | 
| 38 46 |  | 
| 39 47 | 
             
                      def job_mutex(args)
         | 
| 40 | 
            -
                         | 
| 48 | 
            +
                        mutex_generator.call(job_key(args))
         | 
| 41 49 | 
             
                      end
         | 
| 42 50 |  | 
| 43 | 
            -
                      private
         | 
| 44 | 
            -
             | 
| 45 51 | 
             
                      def queue_key(args)
         | 
| 46 52 | 
             
                        klass = self.name.tableize.singularize
         | 
| 47 53 | 
             
                        args  = args.map(&:to_s).join(',')
         | 
| @@ -24,12 +24,18 @@ module Resque | |
| 24 24 | 
             
                        mutex(args).unlock
         | 
| 25 25 | 
             
                      end
         | 
| 26 26 |  | 
| 27 | 
            +
                      private
         | 
| 28 | 
            +
             | 
| 29 | 
            +
                      delegate :configuration,
         | 
| 30 | 
            +
                        to: Resque::Plugins::Serializer
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                      delegate :mutex_generator,
         | 
| 33 | 
            +
                        to: :configuration
         | 
| 34 | 
            +
             | 
| 27 35 | 
             
                      def mutex(args)
         | 
| 28 | 
            -
                         | 
| 36 | 
            +
                        mutex_generator.call(key(args))
         | 
| 29 37 | 
             
                      end
         | 
| 30 38 |  | 
| 31 | 
            -
                      private
         | 
| 32 | 
            -
             | 
| 33 39 | 
             
                      def key(args)
         | 
| 34 40 | 
             
                        klass = self.name.tableize.singularize
         | 
| 35 41 | 
             
                        args  = args.map(&:to_s).join(',')
         | 
| @@ -24,12 +24,18 @@ module Resque | |
| 24 24 | 
             
                        mutex(args).unlock
         | 
| 25 25 | 
             
                      end
         | 
| 26 26 |  | 
| 27 | 
            +
                      private
         | 
| 28 | 
            +
             | 
| 29 | 
            +
                      delegate :configuration,
         | 
| 30 | 
            +
                        to: Resque::Plugins::Serializer
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                      delegate :mutex_generator,
         | 
| 33 | 
            +
                        to: :configuration
         | 
| 34 | 
            +
             | 
| 27 35 | 
             
                      def mutex(args)
         | 
| 28 | 
            -
                         | 
| 36 | 
            +
                        mutex_generator.call(key(args))
         | 
| 29 37 | 
             
                      end
         | 
| 30 38 |  | 
| 31 | 
            -
                      private
         | 
| 32 | 
            -
             | 
| 33 39 | 
             
                      def key(args)
         | 
| 34 40 | 
             
                        klass = self.name.tableize.singularize
         | 
| 35 41 | 
             
                        args  = args.map(&:to_s).join(',')
         | 
| @@ -22,12 +22,18 @@ module Resque | |
| 22 22 | 
             
                        mutex(args).unlock
         | 
| 23 23 | 
             
                      end
         | 
| 24 24 |  | 
| 25 | 
            +
                      private
         | 
| 26 | 
            +
             | 
| 27 | 
            +
                      delegate :configuration,
         | 
| 28 | 
            +
                        to: Resque::Plugins::Serializer
         | 
| 29 | 
            +
             | 
| 30 | 
            +
                      delegate :mutex_generator,
         | 
| 31 | 
            +
                        to: :configuration
         | 
| 32 | 
            +
             | 
| 25 33 | 
             
                      def mutex(args)
         | 
| 26 | 
            -
                         | 
| 34 | 
            +
                        mutex_generator.call(key(args))
         | 
| 27 35 | 
             
                      end
         | 
| 28 36 |  | 
| 29 | 
            -
                      private
         | 
| 30 | 
            -
             | 
| 31 37 | 
             
                      def key(args)
         | 
| 32 38 | 
             
                        klass = self.name.tableize.singularize
         | 
| 33 39 | 
             
                        args  = args.map(&:to_s).join(',')
         | 
    
        data/resque-serializer.gemspec
    CHANGED
    
    | @@ -20,7 +20,7 @@ Gem::Specification.new do |gem| | |
| 20 20 | 
             
              gem.add_dependency 'activesupport'
         | 
| 21 21 | 
             
              gem.add_dependency 'resque'
         | 
| 22 22 |  | 
| 23 | 
            -
              gem.add_development_dependency 'bundler', '~>  | 
| 23 | 
            +
              gem.add_development_dependency 'bundler', '~> 2.0'
         | 
| 24 24 | 
             
              gem.add_development_dependency 'bump', '~> 0.7'
         | 
| 25 25 | 
             
              gem.add_development_dependency 'mock_redis'
         | 
| 26 26 | 
             
              gem.add_development_dependency 'pry-byebug'
         | 
| @@ -0,0 +1,20 @@ | |
| 1 | 
            +
            require 'spec_helper'
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            describe Resque::Plugins::Serializer::Configuration do
         | 
| 4 | 
            +
              describe 'instance methods' do
         | 
| 5 | 
            +
                describe '#mutex_generator' do
         | 
| 6 | 
            +
                  let(:instance) { described_class.instance }
         | 
| 7 | 
            +
                  let(:key)      { 'key' }
         | 
| 8 | 
            +
             | 
| 9 | 
            +
                  context 'when called' do
         | 
| 10 | 
            +
                    subject { instance.mutex_generator.call(key) }
         | 
| 11 | 
            +
             | 
| 12 | 
            +
                    it 'returns an instance of the mutex' do
         | 
| 13 | 
            +
                      expect(subject).to be_a(Resque::Plugins::Serializer::Mutex)
         | 
| 14 | 
            +
             | 
| 15 | 
            +
                      expect(subject).to have_attributes(key: key)
         | 
| 16 | 
            +
                    end
         | 
| 17 | 
            +
                  end
         | 
| 18 | 
            +
                end
         | 
| 19 | 
            +
              end
         | 
| 20 | 
            +
            end
         | 
| @@ -10,25 +10,31 @@ class ResqueDequeueHookJob | |
| 10 10 | 
             
              def self.perform(*args); end
         | 
| 11 11 | 
             
            end
         | 
| 12 12 |  | 
| 13 | 
            -
            RSpec.describe  | 
| 14 | 
            -
               | 
| 15 | 
            -
             | 
| 16 | 
            -
             | 
| 17 | 
            -
             | 
| 18 | 
            -
             | 
| 19 | 
            -
             | 
| 20 | 
            -
             | 
| 21 | 
            -
                   | 
| 22 | 
            -
             | 
| 23 | 
            -
             | 
| 24 | 
            -
                   | 
| 25 | 
            -
             | 
| 26 | 
            -
             | 
| 27 | 
            -
             | 
| 28 | 
            -
             | 
| 29 | 
            -
                 | 
| 30 | 
            -
             | 
| 31 | 
            -
             | 
| 32 | 
            -
             | 
| 13 | 
            +
            RSpec.describe ResqueSerializer::MonkeyPatches::Resque do
         | 
| 14 | 
            +
              describe 'when prepended' do
         | 
| 15 | 
            +
                let(:args)          { %w[arg1 arg2] }
         | 
| 16 | 
            +
                let(:queue_name)    { :default }
         | 
| 17 | 
            +
                let(:dequeue_hooks) { [] }
         | 
| 18 | 
            +
                let(:worker)        { Resque::Worker.new(queue_name) }
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                before do
         | 
| 21 | 
            +
                  allow(Resque::Plugin)
         | 
| 22 | 
            +
                    .to receive(:before_dequeue_hooks)
         | 
| 23 | 
            +
                    .and_return(dequeue_hooks)
         | 
| 24 | 
            +
                  allow(Resque::Plugin)
         | 
| 25 | 
            +
                    .to receive(:after_dequeue_hooks)
         | 
| 26 | 
            +
                    .and_return(dequeue_hooks)
         | 
| 27 | 
            +
             | 
| 28 | 
            +
                  Resque.enqueue(ResqueDequeueHookJob)
         | 
| 29 | 
            +
                end
         | 
| 30 | 
            +
             | 
| 31 | 
            +
                subject(:execute_job) { worker.reserve }
         | 
| 32 | 
            +
             | 
| 33 | 
            +
                it 'executes the dequeue hooks' do
         | 
| 34 | 
            +
                  expect(::Resque::Plugin).to receive(:before_dequeue_hooks).ordered
         | 
| 35 | 
            +
                  expect(::Resque::Plugin).to receive(:after_dequeue_hooks).ordered
         | 
| 36 | 
            +
             | 
| 37 | 
            +
                  execute_job
         | 
| 38 | 
            +
                end
         | 
| 33 39 | 
             
              end
         | 
| 34 40 | 
             
            end
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: resque-serializer
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0. | 
| 4 | 
            +
              version: 0.2.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Ryan Ringler
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date:  | 
| 11 | 
            +
            date: 2019-05-16 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: activesupport
         | 
| @@ -44,14 +44,14 @@ dependencies: | |
| 44 44 | 
             
                requirements:
         | 
| 45 45 | 
             
                - - "~>"
         | 
| 46 46 | 
             
                  - !ruby/object:Gem::Version
         | 
| 47 | 
            -
                    version: ' | 
| 47 | 
            +
                    version: '2.0'
         | 
| 48 48 | 
             
              type: :development
         | 
| 49 49 | 
             
              prerelease: false
         | 
| 50 50 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 51 51 | 
             
                requirements:
         | 
| 52 52 | 
             
                - - "~>"
         | 
| 53 53 | 
             
                  - !ruby/object:Gem::Version
         | 
| 54 | 
            -
                    version: ' | 
| 54 | 
            +
                    version: '2.0'
         | 
| 55 55 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 56 56 | 
             
              name: bump
         | 
| 57 57 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| @@ -158,6 +158,7 @@ files: | |
| 158 158 | 
             
            - bin/console
         | 
| 159 159 | 
             
            - bin/setup
         | 
| 160 160 | 
             
            - lib/resque-serializer.rb
         | 
| 161 | 
            +
            - lib/resque-serializer/configuration.rb
         | 
| 161 162 | 
             
            - lib/resque-serializer/monkey_patches/resque.rb
         | 
| 162 163 | 
             
            - lib/resque-serializer/mutex.rb
         | 
| 163 164 | 
             
            - lib/resque-serializer/serializers/both.rb
         | 
| @@ -166,6 +167,7 @@ files: | |
| 166 167 | 
             
            - lib/resque-serializer/serializers/queue.rb
         | 
| 167 168 | 
             
            - lib/resque-serializer/version.rb
         | 
| 168 169 | 
             
            - resque-serializer.gemspec
         | 
| 170 | 
            +
            - spec/lib/resque-serializer/configuration_spec.rb
         | 
| 169 171 | 
             
            - spec/lib/resque-serializer/monkey_patches/resque_spec.rb
         | 
| 170 172 | 
             
            - spec/lib/resque-serializer/mutex_spec.rb
         | 
| 171 173 | 
             
            - spec/lib/resque-serializer/serializers/both_spec.rb
         | 
| @@ -194,11 +196,12 @@ required_rubygems_version: !ruby/object:Gem::Requirement | |
| 194 196 | 
             
                  version: '0'
         | 
| 195 197 | 
             
            requirements: []
         | 
| 196 198 | 
             
            rubyforge_project: 
         | 
| 197 | 
            -
            rubygems_version: 2.6.14. | 
| 199 | 
            +
            rubygems_version: 2.6.14.3
         | 
| 198 200 | 
             
            signing_key: 
         | 
| 199 201 | 
             
            specification_version: 4
         | 
| 200 202 | 
             
            summary: Serializes Resque jobs
         | 
| 201 203 | 
             
            test_files:
         | 
| 204 | 
            +
            - spec/lib/resque-serializer/configuration_spec.rb
         | 
| 202 205 | 
             
            - spec/lib/resque-serializer/monkey_patches/resque_spec.rb
         | 
| 203 206 | 
             
            - spec/lib/resque-serializer/mutex_spec.rb
         | 
| 204 207 | 
             
            - spec/lib/resque-serializer/serializers/both_spec.rb
         |