Sha256: b755c95e8966fc1fdeb2c26a2ee4292c5f00f5aaf7586f6a9aea6afd6fc3f47b

Contents?: true

Size: 1.26 KB

Versions: 55

Compression:

Stored size: 1.26 KB

Contents

# -*- coding: utf-8 -*-
require "spec_helper"

unless ENV["CI"]
  describe "x-consistent-hash exchange" do
    let(:connection) do
      c = Bunny.new(:user => "bunny_gem", :password => "bunny_password", :vhost => "bunny_testbed")
      c.start
      c
    end

    after :each do
      connection.close
    end

    let(:list) { Range.new(0, 6).to_a.map(&:to_s) }

    let(:m) { 1500 }

    it "distributes messages between queues bound with the same routing key" do
      ch   = connection.create_channel
      body = "сообщение"
      # requires the consistent hash exchange plugin,
      # enable it with
      #
      # $ [sudo] rabbitmq-plugins enable rabbitmq_consistent_hash_exchange
      x    = ch.exchange("bunny.stress.concurrent.consumers", :type => "x-consistent-hash", :durable => true)

      qs = []

      q1 = ch.queue("", :exclusive => true).bind(x, :routing_key => "5")
      q2 = ch.queue("", :exclusive => true).bind(x, :routing_key => "5")

      sleep 1.0

      5.times do |i|
        m.times do
          x.publish(body, :routing_key => list.sample)
        end
        puts "Published #{(i + 1) * m} tiny messages..."
      end

      sleep 2.0
      q1.message_count.should be > 100
      q2.message_count.should be > 100

      ch.close
    end
  end
end

Version data entries

55 entries across 55 versions & 1 rubygems

Version Path
bunny-1.7.1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.7.0 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.6.3 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.6.2 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.6.1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.6.0 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.5.1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.6.0.rc2 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.6.0.rc1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.6.0.pre1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.5.0 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.5.0.pre2 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.5.0.pre1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.4.1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.4.0 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.3.1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.3.0 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.2.2 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.2.1 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb
bunny-1.2.0 spec/higher_level_api/integration/consistent_hash_exchange_spec.rb