aboutsummaryrefslogtreecommitdiff
path: root/thirdparty/ryml/test/test_simple_set.cpp
diff options
context:
space:
mode:
authorStefan Boberg <[email protected]>2025-11-07 14:49:13 +0100
committerGitHub Enterprise <[email protected]>2025-11-07 14:49:13 +0100
commit24e43a913f29ac3b314354e8ce5175f135bcc64f (patch)
treeca442937ceeb63461012b33a4576e9835099f106 /thirdparty/ryml/test/test_simple_set.cpp
parentget oplog attachments (#622) (diff)
downloadzen-24e43a913f29ac3b314354e8ce5175f135bcc64f.tar.xz
zen-24e43a913f29ac3b314354e8ce5175f135bcc64f.zip
switch to xmake for package management (#611)
This change removes our dependency on vcpkg for package management, in favour of bringing some code in-tree in the `thirdparty` folder as well as using the xmake build-in package management feature. For the latter, all the package definitions are maintained in the zen repo itself, in the `repo` folder. It should now also be easier to build the project as it will no longer depend on having the right version of vcpkg installed, which has been a common problem for new people coming in to the codebase. Now you should only need xmake to build. * Bumps xmake requirement on github runners to 2.9.9 to resolve an issue where xmake on Windows invokes cmake with `v144` toolchain which does not exist * BLAKE3 is now in-tree at `thirdparty/blake3` * cpr is now in-tree at `thirdparty/cpr` * cxxopts is now in-tree at `thirdparty/cxxopts` * fmt is now in-tree at `thirdparty/fmt` * robin-map is now in-tree at `thirdparty/robin-map` * ryml is now in-tree at `thirdparty/ryml` * sol2 is now in-tree at `thirdparty/sol2` * spdlog is now in-tree at `thirdparty/spdlog` * utfcpp is now in-tree at `thirdparty/utfcpp` * xmake package repo definitions is in `repo` * implemented support for sanitizers. ASAN is supported on windows, TSAN, UBSAN, MSAN etc are supported on Linux/MacOS though I have not yet tested it extensively on MacOS * the zencore encryption implementation also now supports using mbedTLS which is used on MacOS, though for now we still use openssl on Linux * crashpad * bumps libcurl to 8.11.0 (from 8.8.0) which should address a rare build upload bug
Diffstat (limited to 'thirdparty/ryml/test/test_simple_set.cpp')
-rw-r--r--thirdparty/ryml/test/test_simple_set.cpp144
1 files changed, 144 insertions, 0 deletions
diff --git a/thirdparty/ryml/test/test_simple_set.cpp b/thirdparty/ryml/test/test_simple_set.cpp
new file mode 100644
index 000000000..f209c79c7
--- /dev/null
+++ b/thirdparty/ryml/test/test_simple_set.cpp
@@ -0,0 +1,144 @@
+#include "./test_group.hpp"
+
+namespace c4 {
+namespace yml {
+
+
+TEST(simple_set, emit)
+{
+ const char yaml[] = R"(!!set
+? aa
+? bb
+? cc
+)";
+ std::string expected = R"(!!set
+aa:
+bb:
+cc:
+)";
+ Tree t = parse_in_arena(yaml);
+ auto s = emitrs_yaml<std::string>(t);
+ EXPECT_EQ(expected, s);
+}
+
+
+TEST(simple_set, emit_doc)
+{
+ const char yaml[] = R"(--- !!set
+? aa
+? bb
+? cc
+)";
+ std::string expected = R"(--- !!set
+aa:
+bb:
+cc:
+)";
+ Tree t = parse_in_arena(yaml);
+ auto s = emitrs_yaml<std::string>(t);
+ EXPECT_EQ(expected, s);
+}
+
+
+//-----------------------------------------------------------------------------
+//-----------------------------------------------------------------------------
+//-----------------------------------------------------------------------------
+
+CASE_GROUP(SIMPLE_SET)
+{
+
+ADD_CASE_TO_GROUP("doc as set, missing value",
+R"(!!set
+? a
+? b
+?
+)",
+N(TL("!!set", L{N(KEYVAL, "a", {}), N(KEYVAL, "b", {}), N(KEYVAL, {}, "")}))
+);
+
+ADD_CASE_TO_GROUP("doc as set, implicit",
+R"(!!set
+? a
+? b
+)",
+N(TL("!!set", L{N(KEYVAL, "a", {}), N(KEYVAL, "b", {})}))
+);
+
+ADD_CASE_TO_GROUP("doc as set",
+R"(--- !!set
+? aa
+? bb
+? cc
+)",
+N(STREAM, L{N(DOCMAP, TL("!!set", L{
+ N(KEYVAL, "aa", /*"~"*/{}),
+ N(KEYVAL, "bb", /*"~"*/{}),
+ N(KEYVAL, "cc", /*"~"*/{})})
+)}));
+
+ADD_CASE_TO_GROUP("sets 2XXW",
+R"(
+--- !!set
+? Mark McGwire
+? Sammy Sosa
+? Ken Griff
+)",
+N(STREAM, L{N(DOCMAP, TL("!!set", L{
+ N(KEYVAL, "Mark McGwire", /*"~"*/{}),
+ N(KEYVAL, "Sammy Sosa", /*"~"*/{}),
+ N(KEYVAL, "Ken Griff", /*"~"*/{}),})
+)}));
+
+ADD_CASE_TO_GROUP("sets 2XXW, indented",
+R"(
+ --- !!set
+ ? Mark McGwire
+ ? Sammy Sosa
+ ? Ken Griff
+)",
+N(STREAM, L{N(DOCMAP, TL("!!set", L{
+ N(KEYVAL, "Mark McGwire", /*"~"*/{}),
+ N(KEYVAL, "Sammy Sosa", /*"~"*/{}),
+ N(KEYVAL, "Ken Griff", /*"~"*/{}),})
+)}));
+
+ADD_CASE_TO_GROUP("sets 2XXW, no set",
+R"(
+---
+? Mark McGwire
+? Sammy Sosa
+? Ken Griff
+)",
+N(STREAM, L{N(DOCMAP, L{
+ N(KEYVAL, "Mark McGwire", /*"~"*/{}),
+ N(KEYVAL, "Sammy Sosa", /*"~"*/{}),
+ N(KEYVAL, "Ken Griff", /*"~"*/{}),}
+)}));
+
+ADD_CASE_TO_GROUP("sets 2XXW, no doc",
+R"(!!set
+? Mark McGwire
+? Sammy Sosa
+? Ken Griff
+)",
+TL("!!set", L{
+ N(KEYVAL, "Mark McGwire", /*"~"*/{}),
+ N(KEYVAL, "Sammy Sosa", /*"~"*/{}),
+ N(KEYVAL, "Ken Griff", /*"~"*/{}),
+}));
+
+ADD_CASE_TO_GROUP("sets 2XXW, no doc, no set",
+R"(
+? Mark McGwire
+? Sammy Sosa
+? Ken Griff
+)",
+L{
+ N(KEYVAL, "Mark McGwire", /*"~"*/{}),
+ N(KEYVAL, "Sammy Sosa", /*"~"*/{}),
+ N(KEYVAL, "Ken Griff", /*"~"*/{}),
+});
+}
+
+} // namespace yml
+} // namespace c4