File: issue78_spec.rb

package info (click to toggle)
ruby-bunny 2.23.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,644 kB
  • sloc: ruby: 10,256; sh: 70; makefile: 8
file content (72 lines) | stat: -rw-r--r-- 1,825 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
require "spec_helper"

unless ENV["CI"]
  describe Bunny::Queue, "#subscribe" do
    before :all do
      @connection1 = Bunny.new(:user => "bunny_gem", password:  "bunny_password", :vhost => "bunny_testbed")
      @connection1.start
      @connection2 = Bunny.new(:user => "bunny_gem", password:  "bunny_password", :vhost => "bunny_testbed")
      @connection2.start
    end

    after :all do
      [@connection1, @connection2].select { |c| !!c }.each do |c|
        c.close if c.open?
      end
    end


    context "with an empty queue" do
      it "consumes messages" do
        delivered_data = []

        ch1 = @connection1.create_channel
        ch2 = @connection1.create_channel

        q   = ch1.queue("", exclusive: true)
        q.subscribe(manual_ack: false) do |delivery_info, properties, payload|
          delivered_data << payload
        end
        sleep 0.5

        x = ch2.default_exchange
        x.publish("abc", routing_key:  q.name)
        sleep 0.7

        expect(delivered_data).to eq ["abc"]

        ch1.close
        ch2.close
      end
    end

    context "with a non-empty queue" do
      let(:queue_name) { "queue#{rand}" }

      it "consumes messages" do
        delivered_data = []

        ch1 = @connection1.create_channel
        ch2 = @connection1.create_channel

        q   = ch1.queue(queue_name, exclusive: true)
        x = ch2.default_exchange
        3.times do |i|
          x.publish("data#{i}", routing_key:  queue_name)
        end
        sleep 0.7
        expect(q.message_count).to eq 3

        q.subscribe(manual_ack: false) do |delivery_info, properties, payload|
          delivered_data << payload
        end
        sleep 0.7

        expect(delivered_data).to eq ["data0", "data1", "data2"]

        ch1.close
        ch2.close
      end
    end
  end
end