From 0d1a52c3dbc756a72ab7c6f6a5391dd65628d76f Mon Sep 17 00:00:00 2001 From: ToruNiina Date: Wed, 26 Mar 2025 23:55:34 +0900 Subject: [PATCH] test: add toml::find for optinal --- tests/test_user_defined_conversion.cpp | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/tests/test_user_defined_conversion.cpp b/tests/test_user_defined_conversion.cpp index 2266f6d..9f27b63 100644 --- a/tests/test_user_defined_conversion.cpp +++ b/tests/test_user_defined_conversion.cpp @@ -735,5 +735,27 @@ TEST_CASE("test_optional_conversion_via_macro") CHECK(v2 == v); } } + +TEST_CASE("test_optional_conversion_via_find") +{ + { + const toml::value v(toml::table{ + {"foo", toml::value(toml::table{{"a", 42}}) } + }); + + const auto foo = toml::find(v, "foo"); + CHECK(foo.a.value() == 42); + CHECK(foo.b == std::nullopt); + } + { + const toml::ordered_value v(toml::ordered_table{ + { "foo", toml::ordered_value(toml::ordered_table{{"b", "baz"}}) } + }); + + const auto foo = toml::find(v, "foo"); + CHECK(foo.a == std::nullopt); + CHECK(foo.b.value() == "baz"); + } +} #endif // TOML11_HAS_OPTIONAL #endif // TOML11_WITHOUT_DEFINE_NON_INTRUSIVE