Chromium Code Reviews| Index: core/fpdfapi/parser/cpdf_document_unittest.cpp | 
| diff --git a/core/fpdfapi/parser/cpdf_document_unittest.cpp b/core/fpdfapi/parser/cpdf_document_unittest.cpp | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..3be4f588cb32dded26ec83d2a8fcfd7d36b1e440 | 
| --- /dev/null | 
| +++ b/core/fpdfapi/parser/cpdf_document_unittest.cpp | 
| @@ -0,0 +1,100 @@ | 
| +// 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/fpdfapi/parser/cpdf_document.h" | 
| + | 
| +#include <memory> | 
| + | 
| +#include "core/fpdfapi/cpdf_modulemgr.h" | 
| +#include "core/fpdfapi/parser/cpdf_array.h" | 
| +#include "core/fpdfapi/parser/cpdf_dictionary.h" | 
| +#include "core/fpdfapi/parser/cpdf_parser.h" | 
| +#include "testing/gtest/include/gtest/gtest.h" | 
| + | 
| +namespace { | 
| + | 
| +CPDF_Dictionary* CreatePageTreeNode(CPDF_Array* kids, | 
| + CPDF_Document* pDoc, | 
| + int count) { | 
| + CPDF_Dictionary* pageNode = new CPDF_Dictionary(); | 
| + pageNode->SetStringFor("Type", "Pages"); | 
| + pageNode->SetReferenceFor("Kids", pDoc, pDoc->AddIndirectObject(kids)); | 
| + pageNode->SetIntegerFor("Count", count); | 
| + uint32_t pageNodeRef = pDoc->AddIndirectObject(pageNode); | 
| + for (size_t i = 0; i < kids->GetCount(); i++) | 
| + kids->GetDictAt(i)->SetReferenceFor("Parent", pDoc, pageNodeRef); | 
| + return pageNode; | 
| +} | 
| + | 
| +CPDF_Dictionary* CreateNumberedPage(size_t number) { | 
| + CPDF_Dictionary* page = new CPDF_Dictionary(); | 
| + page->SetStringFor("Type", "Page"); | 
| + page->SetIntegerFor("PageNumbering", number); | 
| + return page; | 
| +} | 
| + | 
| +} // namespace | 
| + | 
| +class CPDF_TestDocumentForPages : public CPDF_Document { | 
| + public: | 
| + CPDF_TestDocumentForPages() : CPDF_Document(nullptr) { | 
| + CPDF_ModuleMgr* module_mgr = CPDF_ModuleMgr::Get(); | 
| + module_mgr->InitPageModule(); | 
| + // Set up test | 
| + CPDF_Array* zeroToTwo = new CPDF_Array(); | 
| + zeroToTwo->AddReference(this, AddIndirectObject(CreateNumberedPage(0))); | 
| + zeroToTwo->AddReference(this, AddIndirectObject(CreateNumberedPage(1))); | 
| + zeroToTwo->AddReference(this, AddIndirectObject(CreateNumberedPage(2))); | 
| + CPDF_Dictionary* branch1 = CreatePageTreeNode(zeroToTwo, this, 3); | 
| + | 
| + CPDF_Array* zeroToThree = new CPDF_Array(); | 
| + zeroToThree->AddReference(this, branch1->GetObjNum()); | 
| + zeroToThree->AddReference(this, AddIndirectObject(CreateNumberedPage(3))); | 
| + CPDF_Dictionary* branch2 = CreatePageTreeNode(zeroToThree, this, 4); | 
| + | 
| + CPDF_Array* fourFive = new CPDF_Array(); | 
| + fourFive->AddReference(this, AddIndirectObject(CreateNumberedPage(4))); | 
| + fourFive->AddReference(this, AddIndirectObject(CreateNumberedPage(5))); | 
| + CPDF_Dictionary* branch3 = CreatePageTreeNode(fourFive, this, 2); | 
| + | 
| + CPDF_Array* justSix = new CPDF_Array(); | 
| + justSix->AddReference(this, AddIndirectObject(CreateNumberedPage(6))); | 
| + CPDF_Dictionary* branch4 = CreatePageTreeNode(justSix, this, 1); | 
| + | 
| + CPDF_Array* allPages = new CPDF_Array(); | 
| + allPages->AddReference(this, branch2->GetObjNum()); | 
| + allPages->AddReference(this, branch3->GetObjNum()); | 
| + allPages->AddReference(this, branch4->GetObjNum()); | 
| + CPDF_Dictionary* pagesDict = CreatePageTreeNode(allPages, this, 7); | 
| + | 
| + CPDF_Dictionary* root = new CPDF_Dictionary(); | 
| + root->SetReferenceFor("Pages", this, AddIndirectObject(pagesDict)); | 
| + m_pRootDict = root; | 
| + m_PageList.SetSize(7); | 
| + } | 
| +}; | 
| + | 
| +TEST(cpdf_document, GetPages) { | 
| + CPDF_TestDocumentForPages* document = new CPDF_TestDocumentForPages(); | 
| 
 
Tom Sepez
2016/10/21 22:25:33
Why a pointer?  wouldn't this leak?
 
npm
2016/10/21 22:39:25
Using unique_ptr instead of pointer
 
 | 
| + for (int i = 0; i < 7; i++) { | 
| + CPDF_Dictionary* page = document->GetPage(i); | 
| + ASSERT_TRUE(page); | 
| + ASSERT_TRUE(page->GetObjectFor("PageNumbering")); | 
| + EXPECT_EQ(i, page->GetIntegerFor("PageNumbering")); | 
| + } | 
| + CPDF_Dictionary* page = document->GetPage(7); | 
| + EXPECT_FALSE(page); | 
| +} | 
| + | 
| +TEST(cpdf_document, GetPagesReverseOrder) { | 
| + CPDF_TestDocumentForPages* document = new CPDF_TestDocumentForPages(); | 
| + for (int i = 6; i >= 0; i--) { | 
| + CPDF_Dictionary* page = document->GetPage(i); | 
| + ASSERT_TRUE(page); | 
| + ASSERT_TRUE(page->GetObjectFor("PageNumbering")); | 
| + EXPECT_EQ(i, page->GetIntegerFor("PageNumbering")); | 
| + } | 
| + CPDF_Dictionary* page = document->GetPage(7); | 
| + EXPECT_FALSE(page); | 
| +} |