summaryrefslogtreecommitdiff
path: root/core/fpdfapi/parser/cpdf_object_unittest.cpp
diff options
context:
space:
mode:
authortsepez <tsepez@chromium.org>2016-10-10 14:06:44 -0700
committerCommit bot <commit-bot@chromium.org>2016-10-10 14:06:44 -0700
commit381fc833ac9e6ea58762b7e7ac8b7f2129e8477f (patch)
tree3ea0596bee1c45fe49bbbad0559d6e505ccf0fee /core/fpdfapi/parser/cpdf_object_unittest.cpp
parent5609f39c9d4534733f04a2be631da56948c2e96f (diff)
downloadpdfium-381fc833ac9e6ea58762b7e7ac8b7f2129e8477f.tar.xz
Add method to convert to an indirect object in a dictionary.
Avoid an assert which previously could only be overcome by removing/re-inserting. Back-fill a unit test for the equivalent Array method. BUG=654387 Review-Url: https://codereview.chromium.org/2403143002
Diffstat (limited to 'core/fpdfapi/parser/cpdf_object_unittest.cpp')
-rw-r--r--core/fpdfapi/parser/cpdf_object_unittest.cpp30
1 files changed, 30 insertions, 0 deletions
diff --git a/core/fpdfapi/parser/cpdf_object_unittest.cpp b/core/fpdfapi/parser/cpdf_object_unittest.cpp
index b2177afd8a..502d2a06d2 100644
--- a/core/fpdfapi/parser/cpdf_object_unittest.cpp
+++ b/core/fpdfapi/parser/cpdf_object_unittest.cpp
@@ -766,6 +766,21 @@ TEST(PDFArrayTest, CloneDirectObject) {
EXPECT_FALSE(cloned_obj);
}
+TEST(PDFArrayTest, ConvertIndirect) {
+ CPDF_IndirectObjectHolder objects_holder;
+ ScopedArray array(new CPDF_Array);
+ CPDF_Object* pObj = new CPDF_Number(42);
+ array->Add(pObj);
+ array->ConvertToIndirectObjectAt(0, &objects_holder);
+ CPDF_Object* pRef = array->GetObjectAt(0);
+ CPDF_Object* pNum = array->GetDirectObjectAt(0);
+ EXPECT_TRUE(pRef->IsReference());
+ EXPECT_TRUE(pNum->IsNumber());
+ EXPECT_NE(pObj, pRef);
+ EXPECT_EQ(pObj, pNum);
+ EXPECT_EQ(42, array->GetIntegerAt(0));
+}
+
TEST(PDFDictionaryTest, CloneDirectObject) {
CPDF_IndirectObjectHolder objects_holder;
ScopedDict dict(new CPDF_Dictionary());
@@ -833,3 +848,18 @@ TEST(PDFObjectTest, CloneCheckLoop) {
EXPECT_EQ(nullptr, cloned_arr->AsArray()->GetObjectAt(0));
}
}
+
+TEST(PDFDictionaryTest, ConvertIndirect) {
+ CPDF_IndirectObjectHolder objects_holder;
+ ScopedDict dict(new CPDF_Dictionary);
+ CPDF_Object* pObj = new CPDF_Number(42);
+ dict->SetFor("clams", pObj);
+ dict->ConvertToIndirectObjectFor("clams", &objects_holder);
+ CPDF_Object* pRef = dict->GetObjectFor("clams");
+ CPDF_Object* pNum = dict->GetDirectObjectFor("clams");
+ EXPECT_TRUE(pRef->IsReference());
+ EXPECT_TRUE(pNum->IsNumber());
+ EXPECT_NE(pObj, pRef);
+ EXPECT_EQ(pObj, pNum);
+ EXPECT_EQ(42, dict->GetIntegerFor("clams"));
+}