Sha256: eae472e9a571469f158cbf450644db43660a77683cd394f60f6b70405c92562c

Contents?: true

Size: 1.29 KB

Versions: 35

Compression:

Stored size: 1.29 KB

Contents

$LOAD_PATH.unshift File.expand_path(File.dirname(__FILE__) + '/../../lib')
require 'riak'

# This is not a formal spec yet. It's designed to be run agains a local dev
# cluster while you bring nodes up and down.
[
  {:protocol => 'pbc', :protobuffs_backend => :Beefcake},
  {:protocol => 'http', :http_backend => :NetHTTP},
  {:protocol => 'http', :http_backend => :Excon}
].each do |opts|
  @client = Riak::Client.new(
    {
      :nodes => (1..3).map { |i|
        {
          :http_port => 8090 + i,
          :pb_port => 8080 + i
        }
      }
    }.merge(opts)
  )

  errors = []
  p opts

  n = 10
  c = 1000

  (0...n).map do |t|
    Thread.new do
      # Generate a stream of put reqs. Put a . for each success, an X for
      # each failure.
      c.times do |i|
        begin
          o = @client['test'].new("#{t}:#{i}")
          o.content_type = 'text/plain'
          o.data = i.to_s
          o.store
          o2 = @client['test'].get("#{t}:#{i}")
          o2.data == i.to_s or raise "wrong data"
          print '.'
        rescue => e
          print 'X'
          errors << e
        end
      end
    end
  end.each do |thread|
    thread.join
  end

  # Put errors
  puts
  errors.each do |e|
    puts e.inspect
    puts e.backtrace.map { |x| "  #{x}" }.join("\n")
  end

  puts "\n\n"
end

Version data entries

35 entries across 25 versions & 2 rubygems

Version Path
riak-client-2.5.0 spec/failover/failover.rb
riak-client-2.3.0 spec/failover/failover.rb
riak-client-2.2.2 spec/failover/failover.rb
riak-client-2.2.1 spec/failover/failover.rb
riak-client-noenc-1.0.0 spec/failover/failover.rb
riak-client-2.2.0 spec/failover/failover.rb
riak-client-2.2.0.pre1 spec/failover/failover.rb
riak-client-2.1.0 spec/failover/failover.rb
riak-client-1.4.5 spec/failover/failover.rb
riak-client-2.0.0 spec/failover/failover.rb
riak-client-2.0.0.rc2 spec/failover/failover.rb
riak-client-2.0.0.rc1 spec/failover/failover.rb
riak-client-1.4.4.1 spec/failover/failover.rb
riak-client-1.4.4 spec/failover/failover.rb
riak-client-1.4.3 spec/failover/failover.rb
riak-client-1.4.2 spec/failover/failover.rb
riak-client-1.4.1 spec/failover/failover.rb
riak-client-1.4.0 spec/failover/failover.rb
riak-client-1.2.0 spec/failover/failover.rb
riak-client-1.1.1 spec/failover/failover.rb