diff options
author | Ryan Harrison <rharrison@chromium.org> | 2017-06-28 15:57:51 -0400 |
---|---|---|
committer | Chromium commit bot <commit-bot@chromium.org> | 2017-06-28 20:12:34 +0000 |
commit | 297f161a02d79cef88f55906722534bee2da730b (patch) | |
tree | 41299229003dceb2d06b6acbb84fc68770604788 /core/fxcrt/cfx_bytestring_unittest.cpp | |
parent | 9ba8fbc02e86a6b7cb5c4142d9481ae3238c1ec4 (diff) | |
download | pdfium-297f161a02d79cef88f55906722534bee2da730b.tar.xz |
Add << overload for CFX_StringCTemplate classeschromium/3144
BUG=pdfium:790
Change-Id: I4a3623dc0daac6ff8407c09cd00e9f2e4e5dd2d7
Reviewed-on: https://pdfium-review.googlesource.com/7051
Commit-Queue: Ryan Harrison <rharrison@chromium.org>
Reviewed-by: Tom Sepez <tsepez@chromium.org>
Diffstat (limited to 'core/fxcrt/cfx_bytestring_unittest.cpp')
-rw-r--r-- | core/fxcrt/cfx_bytestring_unittest.cpp | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/core/fxcrt/cfx_bytestring_unittest.cpp b/core/fxcrt/cfx_bytestring_unittest.cpp index b0265038d5..f5d9413b7d 100644 --- a/core/fxcrt/cfx_bytestring_unittest.cpp +++ b/core/fxcrt/cfx_bytestring_unittest.cpp @@ -1308,3 +1308,74 @@ TEST(fxcrt, OStreamByteStringOverload) { stream << str1 << str2; EXPECT_EQ("abcdef", stream.str()); } + +TEST(fxcrt, OStreamByteStringCOverload) { + // Basic case, empty string + { + std::ostringstream stream; + CFX_ByteStringC str; + stream << str; + EXPECT_EQ("", stream.str()); + } + + // Basic case, non-empty string + { + std::ostringstream stream; + CFX_ByteStringC str("def"); + stream << "abc" << str << "ghi"; + EXPECT_EQ("abcdefghi", stream.str()); + } + + // Changing the CFX_ByteStringC does not change the stream it was written to. + { + std::ostringstream stream; + CFX_ByteStringC str("abc"); + stream << str; + str = "123"; + EXPECT_EQ("abc", stream.str()); + } + + // Writing it again to the stream will use the latest value. + { + std::ostringstream stream; + CFX_ByteStringC str("abc"); + stream << str; + stream.str(""); + str = "123"; + stream << str; + EXPECT_EQ("123", stream.str()); + } + + // Writing a CFX_ByteStringC with nulls and no specified length treats it as + // a C-style null-terminated string. + { + std::ostringstream stream; + char stringWithNulls[]{'x', 'y', '\0', 'z'}; + CFX_ByteStringC str(stringWithNulls); + EXPECT_EQ(2, str.GetLength()); + stream << str; + EXPECT_EQ(2u, stream.tellp()); + str = ""; + } + + // Writing a CFX_ByteStringC with nulls but specifying its length treats it as + // a C++-style string. + { + std::ostringstream stream; + char stringWithNulls[]{'x', 'y', '\0', 'z'}; + CFX_ByteStringC str(stringWithNulls, 4); + EXPECT_EQ(4, str.GetLength()); + stream << str; + EXPECT_EQ(4u, stream.tellp()); + str = ""; + } + + // << operators can be chained. + { + std::ostringstream stream; + CFX_ByteStringC str1("abc"); + CFX_ByteStringC str2("def"); + stream << str1 << str2; + EXPECT_EQ("abcdef", stream.str()); + } +} |