Sha256: 5dd2021a9e2cb086636ead887bbb017d115437028d4572e56d35c7add721dea0

Contents?: true

Size: 1.48 KB

Versions: 6

Compression:

Stored size: 1.48 KB

Contents

module RedisFailover
  class NodeManagerStub < NodeManager
    attr_accessor :master
    # HACK - this will go away once we refactor the tests to use a real ZK/Redis server.
    public :current_nodes, :guess_master

    def discover_nodes
      # only discover nodes once in testing
      return true if @nodes_discovered

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

    def setup_zk
      @zk = NullObject.new
    end

    def slaves
      @slaves
    end

    def start_processing
      @thread = Thread.new { start }
      sleep(1.5)
    end

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

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

    def force_available(node)
      start_processing
      node.redis.make_available!
      notify_state(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(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

6 entries across 6 versions & 2 rubygems

Version Path
redis_failover-0.9.7.2 spec/support/node_manager_stub.rb
redis_failover-0.9.7.1 spec/support/node_manager_stub.rb
nogara-redis_failover-0.9.7 spec/support/node_manager_stub.rb
redis_failover-0.9.7 spec/support/node_manager_stub.rb
redis_failover-0.9.6 spec/support/node_manager_stub.rb
redis_failover-0.9.5 spec/support/node_manager_stub.rb