diff options
| author | Stefan Boberg <[email protected]> | 2025-11-07 14:49:13 +0100 |
|---|---|---|
| committer | GitHub Enterprise <[email protected]> | 2025-11-07 14:49:13 +0100 |
| commit | 24e43a913f29ac3b314354e8ce5175f135bcc64f (patch) | |
| tree | ca442937ceeb63461012b33a4576e9835099f106 /thirdparty/ryml/test/test_simple_set.cpp | |
| parent | get oplog attachments (#622) (diff) | |
| download | zen-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.cpp | 144 |
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 |