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 end end describe ".register and .remove" do let(:pending_handle) { true } it "should register and remove a delivery handle" do Rdkafka::Producer::DeliveryHandle.register(subject.to_ptr.address, subject) removed = Rdkafka::Producer::DeliveryHandle.remove(subject.to_ptr.address) expect(removed).to eq subject expect(Rdkafka::Producer::DeliveryHandle::REGISTRY).to be_empty end end describe "#pending?" do context "when true" do let(:pending_handle) { true } it "should be true" do expect(subject.pending?).to be true end end context "when not true" do let(:pending_handle) { false } it "should be false" do expect(subject.pending?).to be false end 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 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) 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) end end context "when not pending anymore and there was an error" do let(:pending_handle) { false } let(:response) { 20 } it "should raise an rdkafka error" do expect { subject.wait }.to raise_error Rdkafka::RdkafkaError end end end end