aboutsummaryrefslogtreecommitdiffstats
path: root/nihil.ucl/tests/emit.cc
diff options
context:
space:
mode:
Diffstat (limited to 'nihil.ucl/tests/emit.cc')
-rw-r--r--nihil.ucl/tests/emit.cc93
1 files changed, 0 insertions, 93 deletions
diff --git a/nihil.ucl/tests/emit.cc b/nihil.ucl/tests/emit.cc
deleted file mode 100644
index a7dcd71..0000000
--- a/nihil.ucl/tests/emit.cc
+++ /dev/null
@@ -1,93 +0,0 @@
-/*
- * This source code is released into the public domain.
- */
-
-#include <format>
-#include <sstream>
-
-#include <catch2/catch_test_macros.hpp>
-
-import nihil.ucl;
-
-TEST_CASE("ucl: emit to std::ostream", "[ucl]")
-{
- using namespace std::literals;
-
- auto obj = nihil::ucl::parse("int = [1, 42, 666]"sv);
- REQUIRE(obj);
-
- auto strm = std::ostringstream();
- strm << *obj;
-
- // The ostream emitter produces JSON.
- REQUIRE(strm.str() == std::format("{:j}", *obj));
-}
-
-TEST_CASE("ucl: emit JSON with std::format", "[ucl]")
-{
- using namespace std::literals;
-
- auto obj = nihil::ucl::parse("int = [1, 42, 666]"sv);
- REQUIRE(obj);
-
- auto str = std::format("{:j}", *obj);
-
- REQUIRE(str ==
-"{\n"
-" \"int\": [\n"
-" 1,\n"
-" 42,\n"
-" 666\n"
-" ]\n"
-"}");
-
- // Make sure JSON is the default format.
- auto str2 = std::format("{}", *obj);
- REQUIRE(str == str2);
-}
-
-TEST_CASE("ucl: emit compact JSON with std::format", "[ucl]")
-{
- using namespace std::literals;
-
- auto obj = nihil::ucl::parse("int = [1, 42, 666]"sv);
- REQUIRE(obj);
-
- auto str = std::format("{:J}", *obj);
-
- REQUIRE(str == "{\"int\":[1,42,666]}");
-}
-
-TEST_CASE("ucl: emit configuration with std::format", "[ucl]")
-{
- using namespace std::literals;
-
- auto obj = nihil::ucl::parse("int = [1, 42, 666]"sv);
- REQUIRE(obj);
-
- auto str = std::format("{:c}", *obj);
-
- REQUIRE(str ==
-"int [\n"
-" 1,\n"
-" 42,\n"
-" 666,\n"
-"]\n");
-}
-
-TEST_CASE("ucl: emit YAML with std::format", "[ucl]")
-{
- using namespace std::literals;
-
- auto obj = nihil::ucl::parse("int = [1, 42, 666]"sv);
- REQUIRE(obj);
-
- auto str = std::format("{:y}", *obj);
-
- REQUIRE(str ==
-"int: [\n"
-" 1,\n"
-" 42,\n"
-" 666\n"
-"]");
-}