From 716422c048ad37e5012e9152a3c96bf369fd9b91 Mon Sep 17 00:00:00 2001 From: Tim Rakowski Date: Sat, 14 Oct 2017 12:05:42 +0200 Subject: [PATCH 1/2] Extended iterate_bag test to ensure that closing & reusing works * ... even with different bags --- .../src/create_and_iterate_bag.cpp | 59 +++++++++++++++++-- 1 file changed, 53 insertions(+), 6 deletions(-) diff --git a/test/test_rosbag_storage/src/create_and_iterate_bag.cpp b/test/test_rosbag_storage/src/create_and_iterate_bag.cpp index 23c91dcd86..35228b9e46 100644 --- a/test/test_rosbag_storage/src/create_and_iterate_bag.cpp +++ b/test/test_rosbag_storage/src/create_and_iterate_bag.cpp @@ -1,7 +1,10 @@ #include "ros/time.h" #include "rosbag/bag.h" #include "rosbag/view.h" +#include "std_msgs/Int8.h" +#include "std_msgs/UInt16.h" #include "std_msgs/Int32.h" +#include "std_msgs/UInt64.h" #include "std_msgs/String.h" #include @@ -10,24 +13,40 @@ #include "boost/foreach.hpp" #include +template +T make_std_msg(const typename T::_data_type& data) { + T msg; + msg.data = data; + return msg; +} + void create_test_bag(const std::string &filename) { rosbag::Bag bag; bag.open(filename, rosbag::bagmode::Write); - std_msgs::String str; - str.data = std::string("foo"); + bag.write("chatter", ros::Time::now(), make_std_msg("foo")); + bag.write("numbers", ros::Time::now(), make_std_msg(42)); - std_msgs::Int32 i; - i.data = 42; + bag.close(); +} - bag.write("chatter", ros::Time::now(), str); - bag.write("numbers", ros::Time::now(), i); +void create_a_different_test_bag(const std::string &filename) +{ + rosbag::Bag bag; + bag.open(filename, rosbag::bagmode::Write); + + bag.write("a", ros::Time::now(), make_std_msg("Hello World!")); + bag.write("b", ros::Time::now(), make_std_msg(1)); + bag.write("c", ros::Time::now(), make_std_msg(2)); + bag.write("d", ros::Time::now(), make_std_msg(3)); + bag.write("e", ros::Time::now(), make_std_msg(4)); bag.close(); } const char* bag_filename = "/tmp/rosbag_storage_create_and_iterate_bag.bag"; +const char* bag_filename2 = "/tmp/rosbag_storage_create_and_iterate_bag2.bag"; TEST(rosbag_storage, iterator_copy_constructor) { @@ -105,9 +124,37 @@ TEST(rosbag_storage, iterate_bag) bag.close(); } +void serialize_bag(rosbag::Bag& bag, const char* filename) +{ + bag.open(filename); + + rosbag::View bag_view(bag); + std::vector buffer; + + BOOST_FOREACH(const rosbag::MessageInstance& msg_instance, bag_view) + { + const size_t msg_size = msg_instance.size(); + buffer.resize(msg_size); + ros::serialization::OStream stream(buffer.data(), buffer.size()); + msg_instance.write(stream); + + printf("reading: %s\n", msg_instance.getTopic().c_str() ); + } + bag.close(); +} + +TEST(rosbag_storage, reuse_bag) +{ + rosbag::Bag bag; + + serialize_bag(bag, bag_filename); + serialize_bag(bag, bag_filename2); +} + int main(int argc, char **argv) { ros::Time::init(); create_test_bag(bag_filename); + create_a_different_test_bag(bag_filename2); testing::InitGoogleTest(&argc, argv); return RUN_ALL_TESTS(); From abb84914a922a474cc2922cb158997e8e34041dd Mon Sep 17 00:00:00 2001 From: Tim Rakowski Date: Tue, 17 Oct 2017 21:58:19 +0200 Subject: [PATCH 2/2] Fixed corrupted messages when reopening a rosbag with a different file * Bag::decompressed_chunk_ was not reset in close(). decompressed_chunk_ stores the offset (within the file) of the compressed chunk whose decompressed content is currently stored in decompress_buffer_. Since it wasn't reset in close(), if the offset is the same as that of the first chunk in the file opened next, Bag::decompressChunk() assumed that it had already decompressed that chunk in the new file and just returned. As a result, some member functions of Bag worked on the decompressed chunk of the old bag. * Cleaned up more state in Bag::close() and ChunkedFile::close() --- tools/rosbag_storage/src/bag.cpp | 2 ++ tools/rosbag_storage/src/chunked_file.cpp | 2 ++ 2 files changed, 4 insertions(+) diff --git a/tools/rosbag_storage/src/bag.cpp b/tools/rosbag_storage/src/bag.cpp index a428ff91fe..9655e8541c 100644 --- a/tools/rosbag_storage/src/bag.cpp +++ b/tools/rosbag_storage/src/bag.cpp @@ -180,6 +180,8 @@ void Bag::close() { chunks_.clear(); connection_indexes_.clear(); curr_chunk_connection_indexes_.clear(); + + init(); } void Bag::closeWrite() { diff --git a/tools/rosbag_storage/src/chunked_file.cpp b/tools/rosbag_storage/src/chunked_file.cpp index 9eb665826f..1a59de7e07 100644 --- a/tools/rosbag_storage/src/chunked_file.cpp +++ b/tools/rosbag_storage/src/chunked_file.cpp @@ -148,6 +148,8 @@ void ChunkedFile::close() { filename_.clear(); clearUnused(); + offset_ = 0; + compressed_in_ = 0; } // Read/write modes