Sha256: 0a2a39643c7450782b541ce2ec7c16bcc3da9ab39628608556e52fdaa1b16368

Contents?: true

Size: 1.2 KB

Versions: 5

Compression:

Stored size: 1.2 KB

Contents

module RedisFailover
  class NodeManagerStub < NodeManager
    attr_accessor :master
    public :current_nodes

    def discover_nodes
      master = Node.new(:host => 'master')
      slave = Node.new(:host => 'slave')
      [master, slave].each { |node| node.extend(RedisStubSupport) }
      master.make_master!
      slave.make_slave!(master)
      @master = master
      @slaves = [slave]
    end

    def slaves
      @slaves
    end

    def start_processing
      @thread = Thread.new { start }
    end

    def stop_processing
      @queue << nil
      @thread.value
    end

    def force_unavailable(node)
      start_processing
      node.redis.make_unavailable!
      notify_state_change(node, :unavailable)
      stop_processing
    end

    def force_available(node)
      start_processing
      node.redis.make_available!
      notify_state_change(node, :available)
      stop_processing
    end

    def force_syncing(node, serve_stale_reads)
      start_processing
      node.redis.force_sync_with_master(serve_stale_reads)
      notify_state_change(node, :syncing)
      stop_processing
    end

    def initialize_path; end
    def delete_path; end
    def create_path; end
    def write_state; end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
redis_failover-0.5.4 spec/support/node_manager_stub.rb
redis_failover-0.5.3 spec/support/node_manager_stub.rb
redis_failover-0.5.2 spec/support/node_manager_stub.rb
redis_failover-0.5.1 spec/support/node_manager_stub.rb
redis_failover-0.5.0 spec/support/node_manager_stub.rb