diff options
author | Roman Gershman <romange@gmail.com> | 2019-05-23T03·03+0300 |
---|---|---|
committer | Derek Mauro <761129+derekmauro@users.noreply.github.com> | 2019-05-23T03·03-0400 |
commit | 27c30ec671cb7b5ba84c4e79feff7fd0b0ac6338 (patch) | |
tree | 2a66b5c72434251348d3cac81314e638848043c1 /absl/strings/str_cat_test.cc | |
parent | ce65f5ac3cbf897bb5e3de1a51d80fd00866abaa (diff) |
Avoid undefined behavior when nullptr is passed to memcpy with size 0
Diffstat (limited to 'absl/strings/str_cat_test.cc')
-rw-r--r-- | absl/strings/str_cat_test.cc | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/absl/strings/str_cat_test.cc b/absl/strings/str_cat_test.cc index 1f1051d41f1e..29db9c023781 100644 --- a/absl/strings/str_cat_test.cc +++ b/absl/strings/str_cat_test.cc @@ -408,6 +408,20 @@ TEST(StrCat, VectorBoolReferenceTypes) { EXPECT_EQ(result, "1010"); } +// Passing nullptr to memcpy is undefined behavior and this test +// provides coverage of codepaths that handle empty strings with nullptrs. +TEST(StrCat, AvoidsMemcpyWithNullptr) { + EXPECT_EQ(absl::StrCat(42, absl::string_view{}), "42"); + + // Cover CatPieces code. + EXPECT_EQ(absl::StrCat(1, 2, 3, 4, 5, absl::string_view{}), "12345"); + + // Cover AppendPieces. + std::string result; + absl::StrAppend(&result, 1, 2, 3, 4, 5, absl::string_view{}); + EXPECT_EQ(result, "12345"); +} + #ifdef GTEST_HAS_DEATH_TEST TEST(StrAppend, Death) { std::string s = "self"; |