Sha256: ad9b8ccca7010f3eda16def3c178866e61ea2a651693b1199ca6407c3451c11f

Contents?: true

Size: 1.25 KB

Versions: 7

Compression:

Stored size: 1.25 KB

Contents

# frozen_string_literal: true

describe Rdkafka::Producer::DeliveryHandle do
  let(:response) { 0 }

  subject do
    Rdkafka::Producer::DeliveryHandle.new.tap do |handle|
      handle[:pending] = pending_handle
      handle[:response] = response
      handle[:partition] = 2
      handle[:offset] = 100
      handle[:topic_name] = FFI::MemoryPointer.from_string("produce_test_topic")
    end
  end

  describe "#wait" do
    let(:pending_handle) { true }

    it "should wait until the timeout and then raise an error" do
      expect {
        subject.wait(max_wait_timeout: 0.1)
      }.to raise_error Rdkafka::Producer::DeliveryHandle::WaitTimeoutError, /delivery/
    end

    context "when not pending anymore and no error" do
      let(:pending_handle) { false }

      it "should return a delivery report" do
        report = subject.wait

        expect(report.partition).to eq(2)
        expect(report.offset).to eq(100)
        expect(report.topic_name).to eq("produce_test_topic")
      end

      it "should wait without a timeout" do
        report = subject.wait(max_wait_timeout: nil)

        expect(report.partition).to eq(2)
        expect(report.offset).to eq(100)
        expect(report.topic_name).to eq("produce_test_topic")
      end
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
rdkafka-0.14.1 spec/rdkafka/producer/delivery_handle_spec.rb
rdkafka-0.15.2 spec/rdkafka/producer/delivery_handle_spec.rb
rdkafka-0.16.0.beta1 spec/rdkafka/producer/delivery_handle_spec.rb
rdkafka-0.15.1 spec/rdkafka/producer/delivery_handle_spec.rb
rdkafka-0.15.0 spec/rdkafka/producer/delivery_handle_spec.rb
rdkafka-0.14.0 spec/rdkafka/producer/delivery_handle_spec.rb
rdkafka-0.14.0.rc1 spec/rdkafka/producer/delivery_handle_spec.rb