2022-05-17 00:32:25 +00:00
|
|
|
// Formatting library for C++ - tests of formatters for standard library types
|
|
|
|
//
|
|
|
|
// Copyright (c) 2012 - present, Victor Zverovich
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// For the license information refer to format.h.
|
|
|
|
|
|
|
|
#include "fmt/std.h"
|
2022-07-03 18:06:54 +00:00
|
|
|
#include "fmt/ranges.h"
|
2022-05-17 00:32:25 +00:00
|
|
|
|
2022-06-26 14:28:01 +00:00
|
|
|
#include <string>
|
2022-07-03 18:06:54 +00:00
|
|
|
#include <vector>
|
2022-06-26 14:28:01 +00:00
|
|
|
|
2022-05-17 00:32:25 +00:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
TEST(std_test, path) {
|
2022-07-10 13:26:23 +00:00
|
|
|
#ifdef __cpp_lib_filesystem
|
2022-05-18 13:04:47 +00:00
|
|
|
EXPECT_EQ(fmt::format("{:8}", std::filesystem::path("foo")), "\"foo\" ");
|
2022-05-21 15:12:32 +00:00
|
|
|
EXPECT_EQ(fmt::format("{}", std::filesystem::path("foo\"bar.txt")),
|
|
|
|
"\"foo\\\"bar.txt\"");
|
2022-05-31 14:58:49 +00:00
|
|
|
|
|
|
|
# ifdef _WIN32
|
2022-06-13 07:36:51 +00:00
|
|
|
// File.txt in Russian.
|
|
|
|
const wchar_t unicode_path[] = {0x424, 0x430, 0x439, 0x43b, 0x2e,
|
|
|
|
0x74, 0x78, 0x74, 0};
|
|
|
|
const char unicode_u8path[] = {'"', char(0xd0), char(0xa4), char(0xd0),
|
|
|
|
char(0xb0), char(0xd0), char(0xb9), char(0xd0),
|
|
|
|
char(0xbb), '.', 't', 'x',
|
|
|
|
't', '"', '\0'};
|
|
|
|
EXPECT_EQ(fmt::format("{}", std::filesystem::path(unicode_path)),
|
|
|
|
unicode_u8path);
|
2022-05-31 14:58:49 +00:00
|
|
|
# endif
|
2022-05-17 00:32:25 +00:00
|
|
|
#endif
|
|
|
|
}
|
2022-05-17 23:31:06 +00:00
|
|
|
|
2022-07-03 18:06:54 +00:00
|
|
|
TEST(ranges_std_test, format_vector_path) {
|
2022-07-10 13:26:23 +00:00
|
|
|
// Test ambiguity problem described in #2954.
|
|
|
|
#ifdef __cpp_lib_filesystem
|
2022-07-03 18:06:54 +00:00
|
|
|
auto p = std::filesystem::path("foo/bar.txt");
|
|
|
|
auto c = std::vector<std::string>{"abc", "def"};
|
|
|
|
EXPECT_EQ(fmt::format("path={}, range={}", p, c),
|
|
|
|
"path=\"foo/bar.txt\", range=[\"abc\", \"def\"]");
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2022-05-17 23:31:06 +00:00
|
|
|
TEST(std_test, thread_id) {
|
|
|
|
EXPECT_FALSE(fmt::format("{}", std::this_thread::get_id()).empty());
|
|
|
|
}
|
2022-06-26 14:28:01 +00:00
|
|
|
|
|
|
|
TEST(std_test, variant) {
|
|
|
|
#ifdef __cpp_lib_variant
|
|
|
|
EXPECT_EQ(fmt::format("{}", std::monostate{}), "monostate");
|
|
|
|
using V0 = std::variant<int, float, std::string, char>;
|
|
|
|
V0 v0(42);
|
|
|
|
V0 v1(1.5f);
|
|
|
|
V0 v2("hello");
|
|
|
|
V0 v3('i');
|
|
|
|
EXPECT_EQ(fmt::format("{}", v0), "variant(42)");
|
|
|
|
EXPECT_EQ(fmt::format("{}", v1), "variant(1.5)");
|
|
|
|
EXPECT_EQ(fmt::format("{}", v2), "variant(\"hello\")");
|
|
|
|
EXPECT_EQ(fmt::format("{}", v3), "variant('i')");
|
|
|
|
|
|
|
|
struct unformattable {};
|
|
|
|
EXPECT_FALSE((fmt::is_formattable<unformattable>::value));
|
|
|
|
EXPECT_FALSE((fmt::is_formattable<std::variant<unformattable>>::value));
|
|
|
|
EXPECT_FALSE((fmt::is_formattable<std::variant<unformattable, int>>::value));
|
|
|
|
EXPECT_FALSE((fmt::is_formattable<std::variant<int, unformattable>>::value));
|
|
|
|
EXPECT_FALSE(
|
|
|
|
(fmt::is_formattable<std::variant<unformattable, unformattable>>::value));
|
|
|
|
EXPECT_TRUE((fmt::is_formattable<std::variant<int, float>>::value));
|
|
|
|
|
|
|
|
using V1 = std::variant<std::monostate, std::string, std::string>;
|
|
|
|
V1 v4{};
|
|
|
|
V1 v5{std::in_place_index<1>, "yes, this is variant"};
|
|
|
|
|
|
|
|
EXPECT_EQ(fmt::format("{}", v4), "variant(monostate)");
|
|
|
|
EXPECT_EQ(fmt::format("{}", v5), "variant(\"yes, this is variant\")");
|
|
|
|
#endif
|
|
|
|
}
|