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