diff --git a/src/internal_modules/roc_audio/packetizer.cpp b/src/internal_modules/roc_audio/packetizer.cpp index 82618b85f..365462643 100644 --- a/src/internal_modules/roc_audio/packetizer.cpp +++ b/src/internal_modules/roc_audio/packetizer.cpp @@ -161,12 +161,17 @@ status::StatusCode Packetizer::end_packet_() { // Fill protocol-specific fields. sequencer_.next(*packet_, packet_cts_, (packet::stream_timestamp_t)packet_pos_); + status::StatusCode code = status::StatusOK; // Apply padding if needed. if (packet_pos_ < samples_per_packet_) { - pad_packet_(written_payload_size); + code = pad_packet_(written_payload_size); } - const status::StatusCode code = writer_.write(packet_); + if (code != status::StatusOK) { + return code; + } + + code = writer_.write(packet_); if (code != status::StatusOK) { return code; } @@ -196,9 +201,10 @@ status::StatusCode Packetizer::create_packet_() { return status::StatusNoMem; } - if (!composer_.prepare(*pp, buffer, payload_size_)) { + status::StatusCode status = composer_.prepare(*pp, buffer, payload_size_); + if (status != status::StatusOK) { roc_log(LogError, "packetizer: can't prepare packet"); - return status::StatusNoMem; + return status; } pp->add_flags(packet::Packet::FlagPrepared); @@ -208,15 +214,18 @@ status::StatusCode Packetizer::create_packet_() { return status::StatusOK; } -void Packetizer::pad_packet_(size_t written_payload_size) { +status::StatusCode Packetizer::pad_packet_(size_t written_payload_size) { if (written_payload_size == payload_size_) { - return; + return status::StatusOK; } - if (!composer_.pad(*packet_, payload_size_ - written_payload_size)) { - roc_panic("packetizer: can't pad packet: orig_size=%lu actual_size=%lu", - (unsigned long)payload_size_, (unsigned long)written_payload_size); + status::StatusCode status = + composer_.pad(*packet_, payload_size_ - written_payload_size); + if (status != status::StatusOK) { + roc_log(LogError, "packetizer: can't pad packet: orig_size=%lu actual_size=%lu", + (unsigned long)payload_size_, (unsigned long)written_payload_size); } + return status; } } // namespace audio diff --git a/src/internal_modules/roc_audio/packetizer.h b/src/internal_modules/roc_audio/packetizer.h index e718c2a79..c7b2553e8 100644 --- a/src/internal_modules/roc_audio/packetizer.h +++ b/src/internal_modules/roc_audio/packetizer.h @@ -80,7 +80,7 @@ class Packetizer : public IFrameWriter, public core::NonCopyable<> { status::StatusCode end_packet_(); status::StatusCode create_packet_(); - void pad_packet_(size_t written_payload_size); + status::StatusCode pad_packet_(size_t written_payload_size); packet::IWriter& writer_; packet::IComposer& composer_; diff --git a/src/internal_modules/roc_fec/block_writer.cpp b/src/internal_modules/roc_fec/block_writer.cpp index 8f720e28f..52676d1dd 100644 --- a/src/internal_modules/roc_fec/block_writer.cpp +++ b/src/internal_modules/roc_fec/block_writer.cpp @@ -223,9 +223,10 @@ status::StatusCode BlockWriter::write_source_packet_(const packet::PacketPtr& pp fill_packet_fec_fields_(pp, (packet::seqnum_t)cur_packet_); - if (!source_composer_.compose(*pp)) { - // TODO(gh-183): forward status from composer - return status::StatusBadBuffer; + status::StatusCode status = source_composer_.compose(*pp); + if (status != status::StatusOK) { + roc_log(LogError, "fec block writer: can't compose packet"); + return status; } pp->add_flags(packet::Packet::FlagComposed); @@ -261,16 +262,17 @@ status::StatusCode BlockWriter::make_repair_packet_(packet::seqnum_t pack_n, return status::StatusNoMem; } - if (!repair_composer_.align(buffer, 0, block_encoder_.buffer_alignment())) { + status::StatusCode status = + repair_composer_.align(buffer, 0, block_encoder_.buffer_alignment()); + if (status != status::StatusOK) { roc_log(LogError, "fec block writer: can't align packet buffer"); - // TODO(gh-183): forward status from composer - return status::StatusBadBuffer; + return status; } - if (!repair_composer_.prepare(*packet, buffer, cur_payload_size_)) { + status = repair_composer_.prepare(*packet, buffer, cur_payload_size_); + if (status != status::StatusOK) { roc_log(LogError, "fec block writer: can't prepare packet"); - // TODO(gh-183): forward status from composer - return status::StatusBadBuffer; + return status; } packet->add_flags(packet::Packet::FlagPrepared); @@ -304,9 +306,10 @@ status::StatusCode BlockWriter::compose_repair_packets_() { continue; } - if (!repair_composer_.compose(*rp)) { - // TODO(gh-183): forward status from composer - return status::StatusBadBuffer; + status::StatusCode status = repair_composer_.compose(*rp); + if (status != status::StatusOK) { + roc_log(LogError, "fec block writer: can't compose packet"); + return status; } rp->add_flags(packet::Packet::FlagComposed); } diff --git a/src/internal_modules/roc_fec/composer.h b/src/internal_modules/roc_fec/composer.h index 78b9ff107..ffc9754f6 100644 --- a/src/internal_modules/roc_fec/composer.h +++ b/src/internal_modules/roc_fec/composer.h @@ -36,12 +36,12 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { } //! Check if the object was successfully constructed. - virtual status::StatusCode init_status() const { + ROC_ATTR_NODISCARD virtual status::StatusCode init_status() const { return status::StatusOK; } //! Adjust buffer to align payload. - virtual bool + ROC_ATTR_NODISCARD virtual status::StatusCode align(core::Slice& buffer, size_t header_size, size_t payload_alignment) { if ((unsigned long)buffer.data() % payload_alignment != 0) { roc_panic("fec composer: unexpected non-aligned buffer"); @@ -59,18 +59,18 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { LogDebug, "fec composer: not enough space for alignment: padding=%lu cap=%lu", (unsigned long)padding, (unsigned long)buffer.capacity()); - return false; + return status::StatusBadBuffer; } buffer.reslice(padding, padding); - return true; + return status::StatusOK; } else { return inner_composer_->align(buffer, header_size, payload_alignment); } } //! Prepare buffer for composing a packet. - virtual bool + ROC_ATTR_NODISCARD virtual status::StatusCode prepare(packet::Packet& packet, core::Slice& buffer, size_t payload_size) { core::Slice payload_id = buffer.subslice(0, 0); @@ -80,7 +80,7 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { "fec composer: not enough space for fec header: size=%lu cap=%lu", (unsigned long)sizeof(PayloadID), (unsigned long)payload_id.capacity()); - return false; + return status::StatusBadBuffer; } payload_id.reslice(0, sizeof(PayloadID)); } @@ -89,8 +89,10 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { payload_id.subslice(payload_id.size(), payload_id.size()); if (inner_composer_) { - if (!inner_composer_->prepare(packet, payload, payload_size)) { - return false; + status::StatusCode result = + inner_composer_->prepare(packet, payload, payload_size); + if (result != status::StatusOK) { + return result; } } else { payload.reslice(0, payload_size); @@ -104,7 +106,7 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { "fec composer: not enough space for fec header: size=%lu cap=%lu", (unsigned long)sizeof(PayloadID), (unsigned long)payload_id.capacity()); - return false; + return status::StatusBadBuffer; } payload_id.reslice(0, sizeof(PayloadID)); } @@ -123,21 +125,22 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { buffer.reslice(0, payload_id.size() + payload.size()); - return true; + return status::StatusOK; } //! Pad packet. - virtual bool pad(packet::Packet& packet, size_t padding_size) { + ROC_ATTR_NODISCARD virtual status::StatusCode pad(packet::Packet& packet, + size_t padding_size) { if (inner_composer_) { return inner_composer_->pad(packet, padding_size); } // padding not supported - return false; + return status::StatusBadOperation; } //! Compose packet to buffer. - virtual bool compose(packet::Packet& packet) { + ROC_ATTR_NODISCARD virtual status::StatusCode compose(packet::Packet& packet) { if (!packet.fec()) { roc_panic("fec composer: unexpected non-fec packet"); } @@ -167,7 +170,7 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { return inner_composer_->compose(packet); } - return true; + return status::StatusOK; } private: diff --git a/src/internal_modules/roc_packet/icomposer.h b/src/internal_modules/roc_packet/icomposer.h index 311b1ccf3..d37ba2316 100644 --- a/src/internal_modules/roc_packet/icomposer.h +++ b/src/internal_modules/roc_packet/icomposer.h @@ -32,7 +32,7 @@ class IComposer : public core::ArenaAllocation { //! @returns //! status::StatusOK if composer was initialized correctly, //! or error code otherwise. - virtual status::StatusCode init_status() const = 0; + ROC_ATTR_NODISCARD virtual status::StatusCode init_status() const = 0; //! Adjust buffer to align payload. //! @remarks @@ -42,7 +42,7 @@ class IComposer : public core::ArenaAllocation { //! @returns //! true if the buffer was successfully adjusted or false if the @p buffer //! capacity is not enough. - virtual bool + ROC_ATTR_NODISCARD virtual status::StatusCode align(core::Slice& buffer, size_t header_size, size_t payload_alignment) = 0; //! Prepare buffer for composing a packet. @@ -55,7 +55,7 @@ class IComposer : public core::ArenaAllocation { //! @returns //! true if the packet was successfully prepared or false if the @p buffer //! capacity is not enough. - virtual bool + ROC_ATTR_NODISCARD virtual status::StatusCode prepare(Packet& packet, core::Slice& buffer, size_t payload_size) = 0; //! Pad packet. @@ -66,7 +66,8 @@ class IComposer : public core::ArenaAllocation { //! @returns //! true if the packet was successfully padded or false if parameters //! are invalid or padding is not supported. - virtual bool pad(Packet& packet, size_t padding_size) = 0; + ROC_ATTR_NODISCARD virtual status::StatusCode pad(Packet& packet, + size_t padding_size) = 0; //! Compose packet to buffer. //! @remarks @@ -74,7 +75,7 @@ class IComposer : public core::ArenaAllocation { //! a previous prepare() call. //! @returns //! true if the packet was successfully composed or false if an error occurred. - virtual bool compose(Packet& packet) = 0; + ROC_ATTR_NODISCARD virtual status::StatusCode compose(Packet& packet) = 0; }; } // namespace packet diff --git a/src/internal_modules/roc_packet/shipper.cpp b/src/internal_modules/roc_packet/shipper.cpp index d7c16918c..3f7542e2b 100644 --- a/src/internal_modules/roc_packet/shipper.cpp +++ b/src/internal_modules/roc_packet/shipper.cpp @@ -46,9 +46,10 @@ status::StatusCode Shipper::write(const PacketPtr& packet) { } if (!packet->has_flags(Packet::FlagComposed)) { - if (!composer_.compose(*packet)) { + status::StatusCode status = composer_.compose(*packet); + if (status != status::StatusOK) { roc_log(LogError, "shipper: can't compose packet"); - return status::StatusNoMem; + return status; } packet->add_flags(Packet::FlagComposed); } diff --git a/src/internal_modules/roc_rtcp/communicator.cpp b/src/internal_modules/roc_rtcp/communicator.cpp index 70b9a48d7..864836414 100644 --- a/src/internal_modules/roc_rtcp/communicator.cpp +++ b/src/internal_modules/roc_rtcp/communicator.cpp @@ -576,9 +576,10 @@ status::StatusCode Communicator::generate_packet_(PacketType packet_type, packet_buffer.reslice(0, 0); // Prepare packet to be able to hold our RTCP packet data - if (!packet_composer_.prepare(*packet, packet_buffer, payload_buffer.size())) { + status = packet_composer_.prepare(*packet, packet_buffer, payload_buffer.size()); + if (status != status::StatusOK) { roc_log(LogError, "rtcp communicator: can't prepare packet"); - return status::StatusNoMem; + return status; } packet->add_flags(packet::Packet::FlagPrepared); diff --git a/src/internal_modules/roc_rtcp/composer.cpp b/src/internal_modules/roc_rtcp/composer.cpp index eb53c0d85..01063064c 100644 --- a/src/internal_modules/roc_rtcp/composer.cpp +++ b/src/internal_modules/roc_rtcp/composer.cpp @@ -18,13 +18,13 @@ Composer::Composer(core::IArena& arena) : IComposer(arena) { } -status::StatusCode Composer::init_status() const { +ROC_ATTR_NODISCARD status::StatusCode Composer::init_status() const { return status::StatusOK; } -bool Composer::align(core::Slice& buffer, - size_t header_size, - size_t payload_alignment) { +ROC_ATTR_NODISCARD status::StatusCode Composer::align(core::Slice& buffer, + size_t header_size, + size_t payload_alignment) { if ((unsigned long)buffer.data() % payload_alignment != 0) { roc_panic("rtcp composer: unexpected non-aligned buffer"); } @@ -35,16 +35,16 @@ bool Composer::align(core::Slice& buffer, roc_log(LogDebug, "rtcp composer: not enough space for alignment: padding=%lu cap=%lu", (unsigned long)padding, (unsigned long)buffer.capacity()); - return false; + return status::StatusBadBuffer; } buffer.reslice(padding, padding); - return true; + return status::StatusOK; } -bool Composer::prepare(packet::Packet& packet, - core::Slice& buffer, - size_t payload_size) { +ROC_ATTR_NODISCARD status::StatusCode Composer::prepare(packet::Packet& packet, + core::Slice& buffer, + size_t payload_size) { buffer.reslice(0, payload_size); packet.add_flags(packet::Packet::FlagControl); @@ -52,34 +52,33 @@ bool Composer::prepare(packet::Packet& packet, packet.rtcp()->payload = buffer; - return true; + return status::StatusOK; } -bool Composer::pad(packet::Packet& packet, size_t padding_size) { +ROC_ATTR_NODISCARD status::StatusCode Composer::pad(packet::Packet& packet, + size_t padding_size) { // not supported (void)packet; (void)padding_size; - return false; + return status::StatusBadOperation; } -bool Composer::compose(packet::Packet& packet) { +ROC_ATTR_NODISCARD status::StatusCode Composer::compose(packet::Packet& packet) { if (!packet.rtcp()) { roc_panic("rtcp composer: unexpected non-rctp packet"); } if (!packet.rtcp()->payload) { - roc_log(LogError, "rtcp composer: unexpected null data"); - return false; + roc_panic("rtcp composer: unexpected null data"); } if (packet.rtcp()->payload.size() == 0) { - roc_log(LogError, "rtcp composer: unexpected zero data"); - return false; + roc_panic("rtcp composer: unexpected zero data"); } - return true; + return status::StatusOK; } } // namespace rtcp diff --git a/src/internal_modules/roc_rtcp/composer.h b/src/internal_modules/roc_rtcp/composer.h index 8af74e5e7..e02b28b58 100644 --- a/src/internal_modules/roc_rtcp/composer.h +++ b/src/internal_modules/roc_rtcp/composer.h @@ -30,21 +30,22 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { explicit Composer(core::IArena& arena); //! Check if the object was successfully constructed. - virtual status::StatusCode init_status() const; + ROC_ATTR_NODISCARD virtual status::StatusCode init_status() const; //! Adjust buffer to align payload. - virtual bool + ROC_ATTR_NODISCARD virtual status::StatusCode align(core::Slice& buffer, size_t header_size, size_t payload_alignment); //! Prepare buffer for composing a packet. - virtual bool + ROC_ATTR_NODISCARD virtual status::StatusCode prepare(packet::Packet& packet, core::Slice& buffer, size_t payload_size); //! Pad packet. - virtual bool pad(packet::Packet& packet, size_t padding_size); + ROC_ATTR_NODISCARD virtual status::StatusCode pad(packet::Packet& packet, + size_t padding_size); //! Compose packet to buffer. - virtual bool compose(packet::Packet& packet); + ROC_ATTR_NODISCARD virtual status::StatusCode compose(packet::Packet& packet); }; } // namespace rtcp diff --git a/src/internal_modules/roc_rtp/composer.cpp b/src/internal_modules/roc_rtp/composer.cpp index 4ab52cc96..6d528474d 100644 --- a/src/internal_modules/roc_rtp/composer.cpp +++ b/src/internal_modules/roc_rtp/composer.cpp @@ -20,13 +20,13 @@ Composer::Composer(packet::IComposer* inner_composer, core::IArena& arena) , inner_composer_(inner_composer) { } -status::StatusCode Composer::init_status() const { +ROC_ATTR_NODISCARD status::StatusCode Composer::init_status() const { return status::StatusOK; } -bool Composer::align(core::Slice& buffer, - size_t header_size, - size_t payload_alignment) { +ROC_ATTR_NODISCARD status::StatusCode Composer::align(core::Slice& buffer, + size_t header_size, + size_t payload_alignment) { if ((unsigned long)buffer.data() % payload_alignment != 0) { roc_panic("rtp composer: unexpected non-aligned buffer"); } @@ -40,26 +40,26 @@ bool Composer::align(core::Slice& buffer, roc_log(LogDebug, "rtp composer: not enough space for alignment: padding=%lu cap=%lu", (unsigned long)padding, (unsigned long)buffer.capacity()); - return false; + return status::StatusBadBuffer; } buffer.reslice(padding, padding); - return true; + return status::StatusOK; } else { return inner_composer_->align(buffer, header_size, payload_alignment); } } -bool Composer::prepare(packet::Packet& packet, - core::Slice& buffer, - size_t payload_size) { +ROC_ATTR_NODISCARD status::StatusCode Composer::prepare(packet::Packet& packet, + core::Slice& buffer, + size_t payload_size) { core::Slice header = buffer.subslice(0, 0); if (header.capacity() < sizeof(Header)) { roc_log(LogDebug, "rtp composer: not enough space for rtp header: size=%lu cap=%lu", (unsigned long)sizeof(Header), (unsigned long)header.capacity()); - return false; + return status::StatusBadBuffer; } header.reslice(0, sizeof(Header)); @@ -70,12 +70,14 @@ bool Composer::prepare(packet::Packet& packet, roc_log(LogDebug, "rtp composer: not enough space for rtp payload: size=%lu cap=%lu", (unsigned long)payload_size, (unsigned long)payload.capacity()); - return false; + return status::StatusBadBuffer; } payload.reslice(0, payload_size); } else { - if (!inner_composer_->prepare(packet, payload, payload_size)) { - return false; + status::StatusCode status = + inner_composer_->prepare(packet, payload, payload_size); + if (status != status::StatusOK) { + return status; } } @@ -88,10 +90,11 @@ bool Composer::prepare(packet::Packet& packet, buffer.reslice(0, header.size() + payload.size()); - return true; + return status::StatusOK; } -bool Composer::pad(packet::Packet& packet, size_t padding_size) { +ROC_ATTR_NODISCARD status::StatusCode Composer::pad(packet::Packet& packet, + size_t padding_size) { if (inner_composer_) { return inner_composer_->pad(packet, padding_size); } @@ -112,16 +115,16 @@ bool Composer::pad(packet::Packet& packet, size_t padding_size) { "rtp composer: padding is larger than payload size:" " payload_size=%lu padding_size=%lu", (unsigned long)rtp->payload.size(), (unsigned long)padding_size); - return false; + return status::StatusBadBuffer; } rtp->padding = rtp->payload.subslice(payload_size - padding_size, payload_size); rtp->payload = rtp->payload.subslice(0, payload_size - padding_size); - return true; + return status::StatusOK; } -bool Composer::compose(packet::Packet& packet) { +ROC_ATTR_NODISCARD status::StatusCode Composer::compose(packet::Packet& packet) { packet::RTP* rtp = packet.rtp(); if (!rtp) { roc_panic("rtp composer: unexpected non-rtp packet"); @@ -152,7 +155,7 @@ bool Composer::compose(packet::Packet& packet) { "rtp composer: padding is larger than supported by rtp:" " pad_size=%lu max_size=%lu", (unsigned long)padding_size, (unsigned long)(uint8_t)-1); - return false; + return status::StatusBadBuffer; } if (padding_size > 1) { @@ -165,7 +168,7 @@ bool Composer::compose(packet::Packet& packet) { return inner_composer_->compose(packet); } - return true; + return status::StatusOK; } } // namespace rtp diff --git a/src/internal_modules/roc_rtp/composer.h b/src/internal_modules/roc_rtp/composer.h index cce2a04dd..75d413878 100644 --- a/src/internal_modules/roc_rtp/composer.h +++ b/src/internal_modules/roc_rtp/composer.h @@ -28,21 +28,22 @@ class Composer : public packet::IComposer, public core::NonCopyable<> { Composer(packet::IComposer* inner_composer, core::IArena& arena); //! Check if the object was successfully constructed. - virtual status::StatusCode init_status() const; + ROC_ATTR_NODISCARD virtual status::StatusCode init_status() const; //! Adjust buffer to align payload. - virtual bool + ROC_ATTR_NODISCARD virtual status::StatusCode align(core::Slice& buffer, size_t header_size, size_t payload_alignment); //! Prepare buffer for composing a packet. - virtual bool + ROC_ATTR_NODISCARD virtual status::StatusCode prepare(packet::Packet& packet, core::Slice& buffer, size_t payload_size); //! Pad packet. - virtual bool pad(packet::Packet& packet, size_t padding_size); + ROC_ATTR_NODISCARD virtual status::StatusCode pad(packet::Packet& packet, + size_t padding_size); //! Compose packet to buffer. - virtual bool compose(packet::Packet& packet); + ROC_ATTR_NODISCARD virtual status::StatusCode compose(packet::Packet& packet); private: packet::IComposer* inner_composer_; diff --git a/src/tests/roc_audio/test_depacketizer.cpp b/src/tests/roc_audio/test_depacketizer.cpp index d24edd48c..29812ba8f 100644 --- a/src/tests/roc_audio/test_depacketizer.cpp +++ b/src/tests/roc_audio/test_depacketizer.cpp @@ -62,7 +62,9 @@ packet::PacketPtr new_packet(IFrameEncoder& encoder, core::Slice bp = packet_factory.new_packet_buffer(); CHECK(bp); - CHECK(rtp_composer.prepare(*pp, bp, encoder.encoded_byte_count(SamplesPerPacket))); + LONGS_EQUAL( + status::StatusOK, + rtp_composer.prepare(*pp, bp, encoder.encoded_byte_count(SamplesPerPacket))); pp->set_buffer(bp); @@ -82,7 +84,7 @@ packet::PacketPtr new_packet(IFrameEncoder& encoder, encoder.end_frame(); - CHECK(rtp_composer.compose(*pp)); + LONGS_EQUAL(status::StatusOK, rtp_composer.compose(*pp)); return pp; } diff --git a/src/tests/roc_fec/test_block_writer_reader.cpp b/src/tests/roc_fec/test_block_writer_reader.cpp index 3304138d6..be1f2614a 100644 --- a/src/tests/roc_fec/test_block_writer_reader.cpp +++ b/src/tests/roc_fec/test_block_writer_reader.cpp @@ -119,9 +119,9 @@ TEST_GROUP(block_writer_reader) { void recompose_packet(const packet::PacketPtr& p) { if (p->flags() & packet::Packet::FlagRepair) { - CHECK(repair_composer().compose(*p)); + LONGS_EQUAL(status::StatusOK, repair_composer().compose(*p)); } else { - CHECK(source_composer().compose(*p)); + LONGS_EQUAL(status::StatusOK, source_composer().compose(*p)); } } @@ -145,7 +145,7 @@ TEST_GROUP(block_writer_reader) { if (!composer) { composer = &source_composer(); } - CHECK(composer->prepare(*pp, bp, rtp_payload_size)); + LONGS_EQUAL(status::StatusOK, composer->prepare(*pp, bp, rtp_payload_size)); pp->set_buffer(bp); @@ -1651,7 +1651,7 @@ TEST(block_writer_reader, zero_repair_packets) { // two blocks with NES == SBL if ((n_block == 2 || n_block == 4) && (i >= NumSourcePackets)) { p->fec()->block_length = NumSourcePackets; - ldpc_repair_composer.compose(*p); + LONGS_EQUAL(status::StatusOK, ldpc_repair_composer.compose(*p)); } LONGS_EQUAL(status::StatusOK, dispatcher.write(p)); @@ -2499,7 +2499,7 @@ TEST(block_writer_reader, reader_oversized_source_block) { if (i == 0) { // violates: SBL <= MAX_BLEN (for source packets) p->fec()->source_block_length = encoder->max_block_length() + 1; - ldpc_source_composer.compose(*p); + LONGS_EQUAL(status::StatusOK, ldpc_source_composer.compose(*p)); } LONGS_EQUAL(status::StatusOK, dispatcher.write(p)); @@ -2570,7 +2570,7 @@ TEST(block_writer_reader, reader_oversized_repair_block) { if (i == NumSourcePackets) { // violates: BLEN <= MAX_BLEN (for repair packets) p->fec()->block_length = encoder->max_block_length() + 1; - ldpc_repair_composer.compose(*p); + LONGS_EQUAL(status::StatusOK, ldpc_repair_composer.compose(*p)); } LONGS_EQUAL(status::StatusOK, dispatcher.write(p)); diff --git a/src/tests/roc_fec/test_block_writer_reader_duration.cpp b/src/tests/roc_fec/test_block_writer_reader_duration.cpp index 4e9e6da2c..7f8ae589d 100644 --- a/src/tests/roc_fec/test_block_writer_reader_duration.cpp +++ b/src/tests/roc_fec/test_block_writer_reader_duration.cpp @@ -96,7 +96,9 @@ TEST_GROUP(block_writer_reader_duration) { core::Slice bp = packet_factory.new_packet_buffer(); CHECK(bp); - CHECK(source_composer.prepare(*pp, bp, FECPayloadSize - sizeof(rtp::Header))); + LONGS_EQUAL( + status::StatusOK, + source_composer.prepare(*pp, bp, FECPayloadSize - sizeof(rtp::Header))); pp->set_buffer(bp); pp->add_flags(packet::Packet::FlagAudio | packet::Packet::FlagPrepared); diff --git a/src/tests/roc_fec/test_block_writer_reader_errors.cpp b/src/tests/roc_fec/test_block_writer_reader_errors.cpp index 0333aa6ab..a2307ca8c 100644 --- a/src/tests/roc_fec/test_block_writer_reader_errors.cpp +++ b/src/tests/roc_fec/test_block_writer_reader_errors.cpp @@ -87,7 +87,9 @@ TEST_GROUP(block_writer_reader_errors) { core::Slice bp = packet_factory.new_packet_buffer(); CHECK(bp); - CHECK(source_composer.prepare(*pp, bp, FECPayloadSize - sizeof(rtp::Header))); + LONGS_EQUAL( + status::StatusOK, + source_composer.prepare(*pp, bp, FECPayloadSize - sizeof(rtp::Header))); pp->set_buffer(bp); pp->add_flags(packet::Packet::FlagAudio | packet::Packet::FlagPrepared); diff --git a/src/tests/roc_fec/test_block_writer_reader_peek.cpp b/src/tests/roc_fec/test_block_writer_reader_peek.cpp index fc47958f0..c732771c4 100644 --- a/src/tests/roc_fec/test_block_writer_reader_peek.cpp +++ b/src/tests/roc_fec/test_block_writer_reader_peek.cpp @@ -96,7 +96,9 @@ TEST_GROUP(block_writer_reader_peek) { core::Slice bp = packet_factory.new_packet_buffer(); CHECK(bp); - CHECK(source_composer.prepare(*pp, bp, FECPayloadSize - sizeof(rtp::Header))); + LONGS_EQUAL( + status::StatusOK, + source_composer.prepare(*pp, bp, FECPayloadSize - sizeof(rtp::Header))); pp->set_buffer(bp); pp->add_flags(packet::Packet::FlagAudio | packet::Packet::FlagPrepared); diff --git a/src/tests/roc_fec/test_composer.cpp b/src/tests/roc_fec/test_composer.cpp index a4bfa9b08..c7288e55b 100644 --- a/src/tests/roc_fec/test_composer.cpp +++ b/src/tests/roc_fec/test_composer.cpp @@ -42,7 +42,7 @@ TEST(composer, align_footer) { UNSIGNED_LONGS_EQUAL((unsigned long)buffer->data(), slice.data()); Composer composer(NULL, arena); - CHECK(composer.align(slice, 0, Alignment)); + LONGS_EQUAL(status::StatusOK, composer.align(slice, 0, Alignment)); UNSIGNED_LONGS_EQUAL(0, slice.size()); UNSIGNED_LONGS_EQUAL(BufferSize, slice.capacity()); @@ -65,7 +65,7 @@ TEST(composer, align_header) { CHECK(((unsigned long)slice.data() + sizeof(RS8M_PayloadID)) % Alignment != 0); Composer composer(NULL, arena); - CHECK(composer.align(slice, 0, Alignment)); + LONGS_EQUAL(status::StatusOK, composer.align(slice, 0, Alignment)); UNSIGNED_LONGS_EQUAL(0, slice.size()); UNSIGNED_LONGS_EQUAL(BufferSize - (Alignment - sizeof(RS8M_PayloadID)), @@ -93,7 +93,7 @@ TEST(composer, align_outer_header) { != 0); Composer composer(NULL, arena); - CHECK(composer.align(slice, OuterHeader, Alignment)); + LONGS_EQUAL(status::StatusOK, composer.align(slice, OuterHeader, Alignment)); UNSIGNED_LONGS_EQUAL(0, slice.size()); UNSIGNED_LONGS_EQUAL(BufferSize @@ -117,12 +117,12 @@ TEST(composer, packet_size) { Composer composer(NULL, arena); - CHECK(composer.align(buffer, 0, Alignment)); - CHECK(composer.prepare(*packet, buffer, PayloadSize)); + LONGS_EQUAL(status::StatusOK, composer.align(buffer, 0, Alignment)); + LONGS_EQUAL(status::StatusOK, composer.prepare(*packet, buffer, PayloadSize)); packet->set_buffer(buffer); - CHECK(composer.compose(*packet)); + LONGS_EQUAL(status::StatusOK, composer.compose(*packet)); UNSIGNED_LONGS_EQUAL(sizeof(RS8M_PayloadID) + PayloadSize, packet->buffer().size()); } diff --git a/src/tests/roc_fec/test_composer_parser.cpp b/src/tests/roc_fec/test_composer_parser.cpp index cc3cb0cf1..8e9057dfc 100644 --- a/src/tests/roc_fec/test_composer_parser.cpp +++ b/src/tests/roc_fec/test_composer_parser.cpp @@ -169,13 +169,14 @@ void test_compose(const PacketTest& test) { packet::PacketPtr packet = packet_factory.new_packet(); CHECK(packet); - CHECK(test.composer->prepare(*packet, buffer, Test_payload_size)); + LONGS_EQUAL(status::StatusOK, + test.composer->prepare(*packet, buffer, Test_payload_size)); packet->set_buffer(buffer); fill_packet(*packet, test.is_rtp); - CHECK(test.composer->compose(*packet)); + LONGS_EQUAL(status::StatusOK, test.composer->compose(*packet)); UNSIGNED_LONGS_EQUAL(test.reference_size, packet->buffer().size()); for (size_t i = 0; i < test.reference_size; i++) { @@ -209,13 +210,14 @@ void test_compose_parse(const PacketTest& test) { packet::PacketPtr packet1 = packet_factory.new_packet(); CHECK(packet1); - CHECK(test.composer->prepare(*packet1, buffer, Test_payload_size)); + LONGS_EQUAL(status::StatusOK, + test.composer->prepare(*packet1, buffer, Test_payload_size)); packet1->set_buffer(buffer); fill_packet(*packet1, test.is_rtp); - CHECK(test.composer->compose(*packet1)); + LONGS_EQUAL(status::StatusOK, test.composer->compose(*packet1)); packet::PacketPtr packet2 = packet_factory.new_packet(); CHECK(packet2); diff --git a/src/tests/roc_packet/test_shipper.cpp b/src/tests/roc_packet/test_shipper.cpp index 1901fb30f..72552529a 100644 --- a/src/tests/roc_packet/test_shipper.cpp +++ b/src/tests/roc_packet/test_shipper.cpp @@ -13,6 +13,7 @@ #include "roc_packet/packet_factory.h" #include "roc_packet/shipper.h" #include "roc_rtp/headers.h" +#include "roc_status/status_code.h" namespace roc { namespace packet { @@ -58,25 +59,27 @@ struct MockComposer : public IComposer, public core::NonCopyable<> { , compose_call_count(0) { } - virtual status::StatusCode init_status() const { + ROC_ATTR_NODISCARD virtual status::StatusCode init_status() const { return status::StatusOK; } - virtual bool align(core::Slice&, size_t, size_t) { - return true; + ROC_ATTR_NODISCARD virtual status::StatusCode + align(core::Slice&, size_t, size_t) { + return status::StatusOK; } - virtual bool prepare(Packet&, core::Slice&, size_t) { - return true; + ROC_ATTR_NODISCARD virtual status::StatusCode + prepare(Packet&, core::Slice&, size_t) { + return status::StatusOK; } - virtual bool pad(Packet&, size_t) { - return true; + ROC_ATTR_NODISCARD virtual status::StatusCode pad(Packet&, size_t) { + return status::StatusOK; } - virtual bool compose(Packet&) { + ROC_ATTR_NODISCARD virtual status::StatusCode compose(Packet&) { ++compose_call_count; - return true; + return status::StatusOK; } unsigned compose_call_count; diff --git a/src/tests/roc_pipeline/test_helpers/packet_writer.h b/src/tests/roc_pipeline/test_helpers/packet_writer.h index c291bf74c..58f977956 100644 --- a/src/tests/roc_pipeline/test_helpers/packet_writer.h +++ b/src/tests/roc_pipeline/test_helpers/packet_writer.h @@ -242,8 +242,10 @@ class PacketWriter : public core::NonCopyable<> { core::Slice bp = packet_factory_.new_packet_buffer(); CHECK(bp); - CHECK(source_composer_->prepare( - *pp, bp, payload_encoder_->encoded_byte_count(samples_per_packet))); + LONGS_EQUAL( + status::StatusOK, + source_composer_->prepare( + *pp, bp, payload_encoder_->encoded_byte_count(samples_per_packet))); pp->set_buffer(bp); @@ -290,12 +292,12 @@ class PacketWriter : public core::NonCopyable<> { packet::PacketPtr fp; while (fec_queue_.read(fp, packet::ModeFetch) == status::StatusOK) { if (fp->has_flags(packet::Packet::FlagAudio)) { - CHECK(source_composer_->compose(*fp)); + LONGS_EQUAL(status::StatusOK, source_composer_->compose(*fp)); LONGS_EQUAL( status::StatusOK, source_writer_->write(prepare_for_delivery_(fp, sample_spec))); } else { - CHECK(repair_composer_->compose(*fp)); + LONGS_EQUAL(status::StatusOK, repair_composer_->compose(*fp)); LONGS_EQUAL( status::StatusOK, repair_writer_->write(prepare_for_delivery_(fp, sample_spec))); @@ -303,7 +305,7 @@ class PacketWriter : public core::NonCopyable<> { } } else { // compose and "deliver" packet - CHECK(source_composer_->compose(*pp)); + LONGS_EQUAL(status::StatusOK, source_composer_->compose(*pp)); LONGS_EQUAL(status::StatusOK, source_writer_->write(prepare_for_delivery_(pp, sample_spec))); } diff --git a/src/tests/roc_rtp/test_packet_formats.cpp b/src/tests/roc_rtp/test_packet_formats.cpp index a1711ffcc..a5bc46ed0 100644 --- a/src/tests/roc_rtp/test_packet_formats.cpp +++ b/src/tests/roc_rtp/test_packet_formats.cpp @@ -202,17 +202,18 @@ void check_compose_encode(const test::PacketInfo& pi) { Composer composer(NULL, arena); - CHECK(composer.prepare(*packet, buffer, pi.payload_size + pi.padding_size)); + LONGS_EQUAL(status::StatusOK, + composer.prepare(*packet, buffer, pi.payload_size + pi.padding_size)); packet->set_buffer(buffer); encode_samples(*encoder, *packet, pi); set_packet_fields(*packet, pi); if (pi.padding_size != 0) { - composer.pad(*packet, pi.padding_size); + LONGS_EQUAL(status::StatusOK, composer.pad(*packet, pi.padding_size)); } - CHECK(composer.compose(*packet)); + LONGS_EQUAL(status::StatusOK, composer.compose(*packet)); check_format_info(*encoding, pi); check_packet_fields(*packet, pi);