Sha256: 225f900128c5be2c4d985a6d09e7c3e7e26d5acc910f35ad023c98876b1471b4

Contents?: true

Size: 1.62 KB

Versions: 4

Compression:

Stored size: 1.62 KB

Contents

# frozen_string_literal: true

require "spec_helper"

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

  describe '#create_result' do
    let(:pending_handle) { false }
    let(:report) { subject.create_result }

    context 'when response is 0' do
      it { expect(report.error).to eq(nil) }
    end

    context 'when response is not 0' do
      let(:response) { 1 }

      it { expect(report.error).to eq(Rdkafka::RdkafkaError.new(response)) }
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
karafka-rdkafka-0.13.8 spec/rdkafka/producer/delivery_handle_spec.rb
karafka-rdkafka-0.13.7 spec/rdkafka/producer/delivery_handle_spec.rb
karafka-rdkafka-0.13.6 spec/rdkafka/producer/delivery_handle_spec.rb
karafka-rdkafka-0.13.5 spec/rdkafka/producer/delivery_handle_spec.rb