Chromium Code Reviews| Index: core/fxcrt/cfx_string_pool_template_unittest.cpp |
| diff --git a/core/fxcrt/cfx_string_pool_template_unittest.cpp b/core/fxcrt/cfx_string_pool_template_unittest.cpp |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..95a9007b92c982b78b3b82891056b4646a42fdd7 |
| --- /dev/null |
| +++ b/core/fxcrt/cfx_string_pool_template_unittest.cpp |
| @@ -0,0 +1,94 @@ |
| +// Copyright 2016 PDFium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "core/fxcrt/include/cfx_string_pool_template.h" |
| +#include "core/fxcrt/include/fx_string.h" |
| +#include "testing/fx_string_testhelpers.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +TEST(fxcrt, ByteStringPool) { |
| + CFX_ByteStringPool pool; |
| + |
| + CFX_ByteString null1; |
| + CFX_ByteString null2; |
| + CFX_ByteString goats1("goats"); |
| + CFX_ByteString goats2("goats"); |
| + |
| + // Underlying storage, if non-null, is not shared. |
|
dsinclair
2016/09/15 20:23:26
Doesn't this check that the underlying storage is
Tom Sepez
2016/09/15 20:51:24
Yes, I think that's inline with the comment, for a
|
| + EXPECT_EQ(nullptr, null1.m_pData.Get()); |
| + EXPECT_EQ(nullptr, null2.m_pData.Get()); |
| + EXPECT_NE(goats1.m_pData, goats2.m_pData); |
|
Tom Sepez
2016/09/15 20:52:37
Note that we don't get here because operator== on
|
| + |
| + CFX_ByteString interned_null1 = pool.Intern(null1); |
| + CFX_ByteString interned_null2 = pool.Intern(null2); |
| + CFX_ByteString interned_goats1 = pool.Intern(goats1); |
| + CFX_ByteString interned_goats2 = pool.Intern(goats2); |
| + |
| + // Strings are logically equal after being interned. |
| + EXPECT_EQ(null1, interned_null1); |
| + EXPECT_EQ(null2, interned_null2); |
| + EXPECT_EQ(goats1, interned_goats1); |
| + EXPECT_EQ(goats2, interned_goats2); |
| + |
|
dsinclair
2016/09/15 20:23:26
Should EXPECT_EQ(interned_goats1, interned_goats2)
Tom Sepez
2016/09/15 20:51:24
Yes, but that should be covered by the basic strin
|
| + // Interned underlying storage, if non-null, belongs to first seen. |
| + EXPECT_EQ(nullptr, interned_null1.m_pData.Get()); |
| + EXPECT_EQ(nullptr, interned_null2.m_pData.Get()); |
| + EXPECT_EQ(goats1.m_pData, interned_goats1.m_pData); |
| + EXPECT_EQ(goats1.m_pData, interned_goats2.m_pData); |
| + |
| + pool.Clear(); |
| + CFX_ByteString reinterned_null2 = pool.Intern(null2); |
| + CFX_ByteString reinterned_null1 = pool.Intern(null2); |
|
dsinclair
2016/09/15 20:23:26
Is it intentional that the null1 and goats1 are po
Tom Sepez
2016/09/15 20:51:24
Yes, otherwise they're not equal.
|
| + CFX_ByteString reinterned_goats2 = pool.Intern(goats2); |
| + CFX_ByteString reinterned_goats1 = pool.Intern(goats2); |
| + |
| + // After clearing pool, storage was re-interned using second strings. |
| + EXPECT_EQ(nullptr, interned_null1.m_pData.Get()); |
| + EXPECT_EQ(nullptr, interned_null2.m_pData.Get()); |
| + EXPECT_EQ(goats2.m_pData, reinterned_goats1.m_pData); |
| + EXPECT_EQ(goats2.m_pData, reinterned_goats2.m_pData); |
| +} |
| + |
| +TEST(fxcrt, WideStringPool) { |
| + CFX_WideStringPool pool; |
| + |
| + CFX_WideString null1; |
| + CFX_WideString null2; |
| + CFX_WideString goats1(L"goats"); |
| + CFX_WideString goats2(L"goats"); |
| + |
| + // Underlying storage, if non-null, is not shared. |
| + EXPECT_EQ(nullptr, null1.m_pData.Get()); |
| + EXPECT_EQ(nullptr, null2.m_pData.Get()); |
| + EXPECT_NE(goats1.m_pData, goats2.m_pData); |
| + |
| + CFX_WideString interned_null1 = pool.Intern(null1); |
| + CFX_WideString interned_null2 = pool.Intern(null2); |
| + CFX_WideString interned_goats1 = pool.Intern(goats1); |
| + CFX_WideString interned_goats2 = pool.Intern(goats2); |
| + |
| + // Strings are logically equal after being interned. |
| + EXPECT_EQ(null1, interned_null1); |
| + EXPECT_EQ(null2, interned_null2); |
| + EXPECT_EQ(goats1, interned_goats1); |
| + EXPECT_EQ(goats2, interned_goats2); |
| + |
| + // Interned underlying storage, if non-null, belongs to first seen. |
| + EXPECT_EQ(nullptr, interned_null1.m_pData.Get()); |
| + EXPECT_EQ(nullptr, interned_null2.m_pData.Get()); |
| + EXPECT_EQ(goats1.m_pData, interned_goats1.m_pData); |
| + EXPECT_EQ(goats1.m_pData, interned_goats2.m_pData); |
| + |
| + pool.Clear(); |
| + CFX_WideString reinterned_null2 = pool.Intern(null2); |
| + CFX_WideString reinterned_null1 = pool.Intern(null2); |
| + CFX_WideString reinterned_goats2 = pool.Intern(goats2); |
| + CFX_WideString reinterned_goats1 = pool.Intern(goats2); |
| + |
| + // After clearing pool, storage was re-interned using second strings. |
| + EXPECT_EQ(nullptr, interned_null1.m_pData.Get()); |
| + EXPECT_EQ(nullptr, interned_null2.m_pData.Get()); |
| + EXPECT_EQ(goats2.m_pData, reinterned_goats1.m_pData); |
| + EXPECT_EQ(goats2.m_pData, reinterned_goats2.m_pData); |
| +} |