diff --git a/doc/design/draft/named-segments.md b/doc/design/draft/named-segments.md index 2969a7ba886..218bfd42a3a 100644 --- a/doc/design/draft/named-segments.md +++ b/doc/design/draft/named-segments.md @@ -206,7 +206,7 @@ In order to determine which segments to map: ## Development Roadmap -- [ ] Extend the RouDi config to support specifying segment names to be added to the `SegmentConfig` +- [x] Extend the RouDi config to support specifying segment names to be added to the `SegmentConfig` - [ ] Add the name to the `MePooSegment` data structure and allow multiple write-access segments to be mapped. - [ ] Update producer options structs to include segment names - [ ] Update producer segment selection logic to take the segment name into account diff --git a/doc/website/advanced/configuration-guide.md b/doc/website/advanced/configuration-guide.md index 1775986021e..32a6b0b0534 100644 --- a/doc/website/advanced/configuration-guide.md +++ b/doc/website/advanced/configuration-guide.md @@ -195,7 +195,7 @@ int main(int argc, char* argv[]) mepooConfig.addMemPool({265, 10000}); auto currentGroup = iox::PosixGroup::getGroupOfCurrentProcess(); - roudiConfig.m_sharedMemorySegments.push_back({currentGroup.getName(), currentGroup.getName(), mepooConfig}); + roudiConfig.m_sharedMemorySegments.emplace_back(currentGroup.getName(), currentGroup.getName(), currentGroup.getName(), mepooConfig); // configure the chunk count for the introspection; each introspection topic gets this number of chunks roudiConfig.introspectionChunkCount = 10; diff --git a/iceoryx_examples/ice_access_control/README.md b/iceoryx_examples/ice_access_control/README.md index b8264039a04..85bee850118 100644 --- a/iceoryx_examples/ice_access_control/README.md +++ b/iceoryx_examples/ice_access_control/README.md @@ -89,9 +89,9 @@ iox::mepoo::MePooConfig mepooConfig; mepooConfig.addMemPool({128, 1000}); // Create an entry for a new shared memory segment from the mempooConfig and add it to the roudiConfig -// Parameters are {"ReaderGroup", "WriterGroup", MemoryPoolConfig} -roudiConfig.m_sharedMemorySegments.push_back({"unprivileged", "privileged", mepooConfig}); -roudiConfig.m_sharedMemorySegments.push_back({"infotainment", "infotainment", mepooConfig}); +// Parameters are {"SegmentName", "ReaderGroup", "WriterGroup", MemoryPoolConfig} +roudiConfig.m_sharedMemorySegments.emplace_back("privileged", "unprivileged", "privileged", mepooConfig); +roudiConfig.m_sharedMemorySegments.emplace_back("infotainment", "infotainment", "infotainment", mepooConfig); ``` The `roudiConfig` is composed of a memory pool config called `mepooConfig`. When the segment is created, one needs to diff --git a/iceoryx_examples/ice_access_control/roudi_main_static_segments.cpp b/iceoryx_examples/ice_access_control/roudi_main_static_segments.cpp index c46304b7396..c45766f0f3c 100644 --- a/iceoryx_examples/ice_access_control/roudi_main_static_segments.cpp +++ b/iceoryx_examples/ice_access_control/roudi_main_static_segments.cpp @@ -42,9 +42,9 @@ int main(int argc, char* argv[]) mepooConfig.addMemPool({128, 1000}); // Create an entry for a new shared memory segment from the mempooConfig and add it to the roudiConfig - // Parameters are {"ReaderGroup", "WriterGroup", MemoryPoolConfig} - roudiConfig.m_sharedMemorySegments.push_back({"unprivileged", "privileged", mepooConfig}); - roudiConfig.m_sharedMemorySegments.push_back({"infotainment", "infotainment", mepooConfig}); + // Parameters are {"SegmentName", "ReaderGroup", "WriterGroup", MemoryPoolConfig} + roudiConfig.m_sharedMemorySegments.emplace_back("privileged", "unprivileged", "privileged", mepooConfig); + roudiConfig.m_sharedMemorySegments.emplace_back("infotainment", "infotainment", "infotainment", mepooConfig); //! [config] IceOryxRouDiApp roudi(cmdLineArgs.value(), roudiConfig); diff --git a/iceoryx_examples/iceperf/roudi_main_static_config.cpp b/iceoryx_examples/iceperf/roudi_main_static_config.cpp index ef9de3c3f3b..02e40358959 100644 --- a/iceoryx_examples/iceperf/roudi_main_static_config.cpp +++ b/iceoryx_examples/iceperf/roudi_main_static_config.cpp @@ -1,4 +1,5 @@ // Copyright (c) 2021 by Apex.AI Inc. All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -53,19 +54,17 @@ int main(int argc, char* argv[]) auto currentGroup = iox::PosixGroup::getGroupOfCurrentProcess(); /// Create an Entry for a new Shared Memory Segment from the MempoolConfig and add it to the RouDiConfig - roudiConfig.m_sharedMemorySegments.push_back({currentGroup.getName(), currentGroup.getName(), mepooConfig}); + roudiConfig.m_sharedMemorySegments.emplace_back(currentGroup.getName(), currentGroup.getName(), currentGroup.getName(), mepooConfig); /// For the case that you want to give accessrights to the shm segments, you need to set groupnames as fixed string. /// These names defines groups whose members are either to read/write from/to the respective shared memory segment. /// @note the groups needs to be registered in /etc/groups. /// @code - /// iox::PosixGroup::string_t readerGroup{iox::TruncateToCapacity, "readerGroup"}; - /// iox::PosixGroup::string_t writerGroup{iox::TruncateToCapacity, "writerGroup"}; - /// iox::mepoo::SegmentConfig::SegmentEntry segentry({readerGroup, writerGroup, mepooConfig}); - /// roudiConfig.m_sharedMemorySegments.push_back( - /// {iox::PosixGroup::string_t(iox::TruncateToCapacity, reader), - /// iox::PosixGroup::string_t(iox::TruncateToCapacity, writer), - /// mempoolConfig}) + /// roudiConfig.m_sharedMemorySegments.emplace_back( + /// "segmentName", + /// "readerGroup", + /// "writerGroup", + /// mempoolConfig) /// @endcode /// configure the chunk count for the introspection; each introspection topic gets this number of chunks diff --git a/iceoryx_posh/include/iceoryx_posh/mepoo/segment_config.hpp b/iceoryx_posh/include/iceoryx_posh/mepoo/segment_config.hpp index ef27a85e731..d82d909f466 100644 --- a/iceoryx_posh/include/iceoryx_posh/mepoo/segment_config.hpp +++ b/iceoryx_posh/include/iceoryx_posh/mepoo/segment_config.hpp @@ -1,4 +1,5 @@ // Copyright (c) 2019 by Robert Bosch GmbH. All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -31,11 +32,13 @@ struct SegmentConfig { struct SegmentEntry { - SegmentEntry(const PosixGroup::groupName_t& readerGroup, + SegmentEntry(const ShmName_t& name, + const PosixGroup::groupName_t& readerGroup, const PosixGroup::groupName_t& writerGroup, const MePooConfig& memPoolConfig, iox::mepoo::MemoryInfo memoryInfo = iox::mepoo::MemoryInfo()) noexcept - : m_readerGroup(readerGroup) + : m_name(name) + , m_readerGroup(readerGroup) , m_writerGroup(writerGroup) , m_mempoolConfig(memPoolConfig) , m_memoryInfo(memoryInfo) @@ -43,6 +46,7 @@ struct SegmentConfig { } + ShmName_t m_name; PosixGroup::groupName_t m_readerGroup; PosixGroup::groupName_t m_writerGroup; MePooConfig m_mempoolConfig; diff --git a/iceoryx_posh/include/iceoryx_posh/roudi/roudi_config_file_provider.hpp b/iceoryx_posh/include/iceoryx_posh/roudi/roudi_config_file_provider.hpp index 114d4ae3534..3227f4800a6 100644 --- a/iceoryx_posh/include/iceoryx_posh/roudi/roudi_config_file_provider.hpp +++ b/iceoryx_posh/include/iceoryx_posh/roudi/roudi_config_file_provider.hpp @@ -1,5 +1,6 @@ // Copyright (c) 2019 by Robert Bosch GmbH. All rights reserved. // Copyright (c) 2021 by Apex.AI Inc. All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -35,6 +36,8 @@ namespace roudi /// MAX_NUMBER_OF_MEMPOOLS_PER_SEGMENT_EXCEEDED - the max number of mempools per segment is exceeded /// MEMPOOL_WITHOUT_CHUNK_SIZE - chunk size not specified for the mempool /// MEMPOOL_WITHOUT_CHUNK_COUNT - chunk count not specified for the mempool +/// EXCEPTION_IN_PARSER - An exception occurred in the toml file parsing library +/// NAMED_SEGMENT_IN_V1_CONFIG - A segment name was specified in a v1 config enum class RouDiConfigFileParseError { FILE_OPEN_FAILED, @@ -46,7 +49,11 @@ enum class RouDiConfigFileParseError MAX_NUMBER_OF_MEMPOOLS_PER_SEGMENT_EXCEEDED, MEMPOOL_WITHOUT_CHUNK_SIZE, MEMPOOL_WITHOUT_CHUNK_COUNT, - EXCEPTION_IN_PARSER + EXCEPTION_IN_PARSER, + NAMED_SEGMENT_IN_V1_CONFIG, + SEGMENT_NAME_EXCEEDS_MAX_LENGTH, + WRITER_GROUP_NAME_EXCEEDS_MAX_LENGTH, + READER_GROUP_NAME_EXCEEDS_MAX_LENGTH }; constexpr const char* ROUDI_CONFIG_FILE_PARSE_ERROR_STRINGS[] = {"FILE_OPEN_FAILED", @@ -58,7 +65,11 @@ constexpr const char* ROUDI_CONFIG_FILE_PARSE_ERROR_STRINGS[] = {"FILE_OPEN_FAIL "MAX_NUMBER_OF_MEMPOOLS_PER_SEGMENT_EXCEEDED", "MEMPOOL_WITHOUT_CHUNK_SIZE", "MEMPOOL_WITHOUT_CHUNK_COUNT", - "EXCEPTION_IN_PARSER"}; + "EXCEPTION_IN_PARSER", + "NAMED_SEGMENT_IN_V1_CONFIG", + "SEGMENT_NAME_EXCEEDS_MAX_LENGTH", + "WRITER_GROUP_NAME_EXCEEDS_MAX_LENGTH", + "READER_GROUP_NAME_EXCEEDS_MAX_LENGTH"}; /// @brief Base class for a config file provider. class RouDiConfigFileProvider diff --git a/iceoryx_posh/roudi_env/source/minimal_roudi_config.cpp b/iceoryx_posh/roudi_env/source/minimal_roudi_config.cpp index 32442f3085e..b3e81815f4b 100644 --- a/iceoryx_posh/roudi_env/source/minimal_roudi_config.cpp +++ b/iceoryx_posh/roudi_env/source/minimal_roudi_config.cpp @@ -1,4 +1,5 @@ // Copyright (c) 2023 by Mathias Kraus . All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -26,7 +27,7 @@ RouDiConfig_t MinimalRouDiConfigBuilder::create() const noexcept mepoo::MePooConfig mepooConfig; mepooConfig.addMemPool({m_payloadChunkSize, m_payloadChunkCount}); auto currentGroup = PosixGroup::getGroupOfCurrentProcess(); - roudiConfig.m_sharedMemorySegments.push_back({currentGroup.getName(), currentGroup.getName(), mepooConfig}); + roudiConfig.m_sharedMemorySegments.emplace_back(currentGroup.getName(), currentGroup.getName(), currentGroup.getName(), mepooConfig); roudiConfig.introspectionChunkCount = m_introspectionChunkCount; roudiConfig.discoveryChunkCount = m_discoveryChunkCount; diff --git a/iceoryx_posh/source/mepoo/segment_config.cpp b/iceoryx_posh/source/mepoo/segment_config.cpp index b7cb7ec8389..05157f1fbc2 100644 --- a/iceoryx_posh/source/mepoo/segment_config.cpp +++ b/iceoryx_posh/source/mepoo/segment_config.cpp @@ -1,4 +1,5 @@ // Copyright (c) 2019 by Robert Bosch GmbH. All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -24,7 +25,7 @@ namespace mepoo SegmentConfig& SegmentConfig::setDefaults() noexcept { auto groupName = PosixGroup::getGroupOfCurrentProcess().getName(); - m_sharedMemorySegments.push_back({groupName, groupName, MePooConfig().setDefaults()}); + m_sharedMemorySegments.emplace_back(groupName, groupName, groupName, MePooConfig().setDefaults()); return *this; } diff --git a/iceoryx_posh/source/roudi/roudi_config_toml_file_provider.cpp b/iceoryx_posh/source/roudi/roudi_config_toml_file_provider.cpp index ef124146696..6548fc66106 100644 --- a/iceoryx_posh/source/roudi/roudi_config_toml_file_provider.cpp +++ b/iceoryx_posh/source/roudi/roudi_config_toml_file_provider.cpp @@ -1,6 +1,7 @@ // Copyright (c) 2019 by Robert Bosch GmbH. All rights reserved. // Copyright (c) 2022 by Apex AI Inc. All rights reserved. // Copyright (c) 2022 by NXP. All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -108,7 +109,7 @@ TomlRouDiConfigFileProvider::parse(std::istream& stream) noexcept return iox::err(iox::roudi::RouDiConfigFileParseError::NO_GENERAL_SECTION); } auto configFileVersion = general->get_as("version"); - if (!configFileVersion || *configFileVersion != 1) + if (!configFileVersion || *configFileVersion == 0 || *configFileVersion > 2U) { return iox::err(iox::roudi::RouDiConfigFileParseError::INVALID_CONFIG_FILE_VERSION); } @@ -128,8 +129,29 @@ TomlRouDiConfigFileProvider::parse(std::istream& stream) noexcept iox::RouDiConfig_t parsedConfig; for (auto segment : *segments) { + auto maybe_name = segment->get_as("name"); + if (maybe_name && *configFileVersion == 1U) + { + return iox::err(iox::roudi::RouDiConfigFileParseError::NAMED_SEGMENT_IN_V1_CONFIG); + } + auto name = maybe_name.value_or(into(groupOfCurrentProcess)); + if (name.size() > ShmName_t::capacity()) + { + return iox::err(iox::roudi::RouDiConfigFileParseError::SEGMENT_NAME_EXCEEDS_MAX_LENGTH); + } + auto writer = segment->get_as("writer").value_or(into(groupOfCurrentProcess)); + if (writer.size() > PosixGroup::groupName_t::capacity()) + { + return iox::err(iox::roudi::RouDiConfigFileParseError::WRITER_GROUP_NAME_EXCEEDS_MAX_LENGTH); + } + auto reader = segment->get_as("reader").value_or(into(groupOfCurrentProcess)); + if (reader.size() > PosixGroup::groupName_t::capacity()) + { + return iox::err(iox::roudi::RouDiConfigFileParseError::READER_GROUP_NAME_EXCEEDS_MAX_LENGTH); + } + iox::mepoo::MePooConfig mempoolConfig; auto mempools = segment->get_table_array("mempool"); if (!mempools) @@ -156,10 +178,11 @@ TomlRouDiConfigFileProvider::parse(std::istream& stream) noexcept } mempoolConfig.addMemPool({*chunkSize, *chunkCount}); } - parsedConfig.m_sharedMemorySegments.push_back( - {PosixGroup::groupName_t(iox::TruncateToCapacity, reader.c_str(), reader.size()), - PosixGroup::groupName_t(iox::TruncateToCapacity, writer.c_str(), writer.size()), - mempoolConfig}); + parsedConfig.m_sharedMemorySegments.emplace_back( + ShmName_t(iox::TruncateToCapacity, name.c_str(), name.size()), + PosixGroup::groupName_t(iox::TruncateToCapacity, reader.c_str(), reader.size()), + PosixGroup::groupName_t(iox::TruncateToCapacity, writer.c_str(), writer.size()), + mempoolConfig); } return iox::ok(parsedConfig); diff --git a/iceoryx_posh/test/integrationtests/test_posh_mepoo.cpp b/iceoryx_posh/test/integrationtests/test_posh_mepoo.cpp index a5d16a21734..cf124323f13 100644 --- a/iceoryx_posh/test/integrationtests/test_posh_mepoo.cpp +++ b/iceoryx_posh/test/integrationtests/test_posh_mepoo.cpp @@ -100,8 +100,8 @@ class Mepoo_IntegrationTest : public Test auto currentGroup = iox::PosixGroup::getGroupOfCurrentProcess(); iox::RouDiConfig_t roudiConfig; - roudiConfig.m_sharedMemorySegments.push_back( - {currentGroup.getName(), currentGroup.getName(), mempoolConfig}); + roudiConfig.m_sharedMemorySegments.emplace_back( + currentGroup.getName(), currentGroup.getName(), currentGroup.getName(), mempoolConfig); return roudiConfig; } else diff --git a/iceoryx_posh/test/moduletests/test_mepoo_segment_management.cpp b/iceoryx_posh/test/moduletests/test_mepoo_segment_management.cpp index 736cc9bf214..25d51ab43da 100644 --- a/iceoryx_posh/test/moduletests/test_mepoo_segment_management.cpp +++ b/iceoryx_posh/test/moduletests/test_mepoo_segment_management.cpp @@ -1,5 +1,6 @@ // Copyright (c) 2019 by Robert Bosch GmbH. All rights reserved. // Copyright (c) 2021 - 2022 by Apex.AI Inc. All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -68,16 +69,16 @@ class SegmentManager_test : public Test SegmentConfig getSegmentConfig() { SegmentConfig config; - config.m_sharedMemorySegments.push_back({"iox_roudi_test1", "iox_roudi_test2", mepooConfig}); - config.m_sharedMemorySegments.push_back({"iox_roudi_test2", "iox_roudi_test3", mepooConfig}); + config.m_sharedMemorySegments.emplace_back("segment_name1", "iox_roudi_test1", "iox_roudi_test2", mepooConfig); + config.m_sharedMemorySegments.emplace_back("segment_name2", "iox_roudi_test2", "iox_roudi_test3", mepooConfig); return config; } SegmentConfig getInvalidSegmentConfig() { SegmentConfig config; - config.m_sharedMemorySegments.push_back({"iox_roudi_test1", "iox_roudi_test1", mepooConfig}); - config.m_sharedMemorySegments.push_back({"iox_roudi_test3", "iox_roudi_test1", mepooConfig}); + config.m_sharedMemorySegments.emplace_back("segment_name1", "iox_roudi_test1", "iox_roudi_test1", mepooConfig); + config.m_sharedMemorySegments.emplace_back("segment_name2", "iox_roudi_test3", "iox_roudi_test1", mepooConfig); return config; } @@ -86,7 +87,7 @@ class SegmentManager_test : public Test SegmentConfig config; for (uint64_t i = 0U; i < iox::MAX_SHM_SEGMENTS; ++i) { - config.m_sharedMemorySegments.push_back({"iox_roudi_test1", "iox_roudi_test1", mepooConfig}); + config.m_sharedMemorySegments.emplace_back("segment_name1", "iox_roudi_test1", "iox_roudi_test1", mepooConfig); } return config; } diff --git a/iceoryx_posh/test/moduletests/test_roudi_config_toml_file_provider.cpp b/iceoryx_posh/test/moduletests/test_roudi_config_toml_file_provider.cpp index f1a1093dacd..004e1b3159e 100644 --- a/iceoryx_posh/test/moduletests/test_roudi_config_toml_file_provider.cpp +++ b/iceoryx_posh/test/moduletests/test_roudi_config_toml_file_provider.cpp @@ -1,5 +1,6 @@ // Copyright (c) 2021 by Robert Bosch GmbH. All rights reserved. // Copyright (c) 2021 by Apex.AI. All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -67,7 +68,20 @@ TEST_F(RoudiConfigTomlFileProvider_test, InvalidPathResultsInError) [](const auto& error) { EXPECT_THAT(error, Eq(iox::roudi::RouDiConfigFileParseError::FILE_OPEN_FAILED)); }); } -TEST_F(RoudiConfigTomlFileProvider_test, ParsingFileIsSuccessful) +constexpr const char* CONFIG_V1_SIMPLE = R"( + [general] + version = 1 + + [[segment]] + writer = "writer" + reader = "reader" + + [[segment.mempool]] + size = 128 + count = 1 +)"; + +TEST_F(RoudiConfigTomlFileProvider_test, ParsingV1FileIsSuccessful) { ::testing::Test::RecordProperty("TEST_ID", "37f5a397-a289-4bc1-86a7-d95851a5ab47"); @@ -76,15 +90,44 @@ TEST_F(RoudiConfigTomlFileProvider_test, ParsingFileIsSuccessful) std::fstream tempFile{tempFilePath, std::ios_base::trunc | std::ios_base::out}; ASSERT_TRUE(tempFile.is_open()); - tempFile << R"([general] - version = 1 + tempFile << CONFIG_V1_SIMPLE; + tempFile.close(); - [[segment]] + cmdLineArgs.configFilePath = + iox::roudi::ConfigFilePathString_t(iox::TruncateToCapacity, tempFilePath.u8string().c_str()); - [[segment.mempool]] - size = 128 - count = 1 - )"; + iox::config::TomlRouDiConfigFileProvider sut(cmdLineArgs); + + sut.parse().and_then([](const auto&) { GTEST_SUCCEED() << "We got a config!"; }).or_else([](const auto& error) { + GTEST_FAIL() << "Expected a config but got error: " + << iox::roudi::ROUDI_CONFIG_FILE_PARSE_ERROR_STRINGS[static_cast(error)]; + }); +} + +constexpr const char* CONFIG_V2_SIMPLE = R"( + [general] + version = 2 + + [[segment]] + name = "name" + writer = "writer" + reader = "reader" + + [[segment.mempool]] + size = 128 + count = 1 +)"; + +TEST_F(RoudiConfigTomlFileProvider_test, ParsingV2FileIsSuccessful) +{ + ::testing::Test::RecordProperty("TEST_ID", "f1a7517e-7612-4eb8-84ad-3ff934f64efd"); + + auto tempFilePath = std::filesystem::temp_directory_path(); + tempFilePath.append("test_roudi_config.toml"); + + std::fstream tempFile{tempFilePath, std::ios_base::trunc | std::ios_base::out}; + ASSERT_TRUE(tempFile.is_open()); + tempFile << CONFIG_V2_SIMPLE; tempFile.close(); cmdLineArgs.configFilePath = @@ -183,6 +226,72 @@ constexpr const char* CONFIG_MEMPOOL_WITHOUT_CHUNK_COUNT = R"( constexpr const char* CONFIG_EXCEPTION_IN_PARSER = R"(🐔)"; +constexpr const char* CONFIG_NAMED_SEGMENT_IN_V1_CONFIG = R"( + [general] + version = 1 + + [[segment]] + name = "name" + + [[segment.mempool]] + size = 128 + count = 1 +)"; + +const std::string CONFIG_NAME_EXCEEDS_MAX_LENGTH = [] { + std::string config = R"( + [general] + version = 2 + + [[segment]] + )"; + config.append("name = \""); + config.append(iox::ShmName_t::capacity() + 1, 'f'); + config.append("\"\n"); + config.append(R"( + [[segment.mempool]] + size = 128 + count = 1 + )"); + return config; +}(); + +const std::string CONFIG_WRITER_GROUP_EXCEEDS_MAX_LENGTH = [] { + std::string config = R"( + [general] + version = 2 + + [[segment]] + )"; + config.append("writer = \""); + config.append(iox::PosixGroup::groupName_t::capacity() + 1, 'f'); + config.append("\"\n"); + config.append(R"( + [[segment.mempool]] + size = 128 + count = 1 + )"); + return config; +}(); + +const std::string CONFIG_READER_GROUP_EXCEEDS_MAX_LENGTH = [] { + std::string config = R"( + [general] + version = 2 + + [[segment]] + )"; + config.append("reader = \""); + config.append(iox::PosixGroup::groupName_t::capacity() + 1, 'f'); + config.append("\"\n"); + config.append(R"( + [[segment.mempool]] + size = 128 + count = 1 + )"); + return config; +}(); + INSTANTIATE_TEST_SUITE_P( ParseAllMalformedInputConfigFiles, RoudiConfigTomlFileProvider_test, @@ -201,7 +310,15 @@ INSTANTIATE_TEST_SUITE_P( ParseErrorInputFile_t{iox::roudi::RouDiConfigFileParseError::MEMPOOL_WITHOUT_CHUNK_COUNT, CONFIG_MEMPOOL_WITHOUT_CHUNK_COUNT}, ParseErrorInputFile_t{iox::roudi::RouDiConfigFileParseError::EXCEPTION_IN_PARSER, - CONFIG_EXCEPTION_IN_PARSER})); + CONFIG_EXCEPTION_IN_PARSER}, + ParseErrorInputFile_t{iox::roudi::RouDiConfigFileParseError::NAMED_SEGMENT_IN_V1_CONFIG, + CONFIG_NAMED_SEGMENT_IN_V1_CONFIG}, + ParseErrorInputFile_t{iox::roudi::RouDiConfigFileParseError::SEGMENT_NAME_EXCEEDS_MAX_LENGTH, + CONFIG_NAME_EXCEEDS_MAX_LENGTH}, + ParseErrorInputFile_t{iox::roudi::RouDiConfigFileParseError::WRITER_GROUP_NAME_EXCEEDS_MAX_LENGTH, + CONFIG_WRITER_GROUP_EXCEEDS_MAX_LENGTH}, + ParseErrorInputFile_t{iox::roudi::RouDiConfigFileParseError::READER_GROUP_NAME_EXCEEDS_MAX_LENGTH, + CONFIG_READER_GROUP_EXCEEDS_MAX_LENGTH})); TEST_P(RoudiConfigTomlFileProvider_test, ParseMalformedInputFileCausesError) diff --git a/iceoryx_posh/test/moduletests/test_roudi_iceoryx_roudi_app.cpp b/iceoryx_posh/test/moduletests/test_roudi_iceoryx_roudi_app.cpp index ee0ad415abb..b88c7f954a7 100644 --- a/iceoryx_posh/test/moduletests/test_roudi_iceoryx_roudi_app.cpp +++ b/iceoryx_posh/test/moduletests/test_roudi_iceoryx_roudi_app.cpp @@ -1,5 +1,6 @@ // Copyright (c) 2021 by Robert Bosch GmbH. All rights reserved. // Copyright (c) 2021 by Apex.AI. All rights reserved. +// Copyright (c) 2024 by Latitude AI. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -249,7 +250,7 @@ TEST_F(IceoryxRoudiApp_test, VerifyConstructorUsingConfigWithSegmentWithoutMemPo iox::RouDiConfig_t roudiConfig; - roudiConfig.m_sharedMemorySegments.push_back({currentGroup.getName(), currentGroup.getName(), mempoolConfig}); + roudiConfig.m_sharedMemorySegments.emplace_back("segment_name1", currentGroup.getName(), currentGroup.getName(), mempoolConfig); IceoryxRoudiApp_Child roudi(cmdLineArgs.value(), roudiConfig);