From 077f6439954cdbb5061a78b59be95ebf2277ac26 Mon Sep 17 00:00:00 2001 From: Henrique Nakashima Date: Mon, 16 Oct 2017 13:32:01 -0400 Subject: Add FPDFCatalog_IsTagged to public API. The new fpdf_catalog.h will contains functions to access entries in the catalog (root) dict in a PDF. Bug: chromium:768986 Change-Id: I6e1d4a479d6f8742981e89f07bab98ee96dc3763 Reviewed-on: https://pdfium-review.googlesource.com/15970 Reviewed-by: dsinclair Commit-Queue: Henrique Nakashima --- fpdfsdk/fpdfcatalog_unittest.cpp | 95 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 95 insertions(+) create mode 100644 fpdfsdk/fpdfcatalog_unittest.cpp (limited to 'fpdfsdk/fpdfcatalog_unittest.cpp') diff --git a/fpdfsdk/fpdfcatalog_unittest.cpp b/fpdfsdk/fpdfcatalog_unittest.cpp new file mode 100644 index 0000000000..13c063453b --- /dev/null +++ b/fpdfsdk/fpdfcatalog_unittest.cpp @@ -0,0 +1,95 @@ +// Copyright 2017 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 "public/fpdf_catalog.h" + +#include "core/fpdfapi/cpdf_modulemgr.h" +#include "core/fpdfapi/parser/cpdf_document.h" +#include "core/fpdfapi/parser/cpdf_number.h" +#include "core/fpdfapi/parser/cpdf_parser.h" +#include "core/fpdfapi/parser/cpdf_string.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "testing/test_support.h" + +#ifdef PDF_ENABLE_XFA +#include "fpdfsdk/fpdfxfa/cpdfxfa_context.h" +#endif // PDF_ENABLE_XFA + +class CPDF_TestDocument : public CPDF_Document { + public: + CPDF_TestDocument() : CPDF_Document(nullptr) {} + + void SetRoot(CPDF_Dictionary* root) { + m_pRootDict = root; + GetRoot(); + } +}; + +#ifdef PDF_ENABLE_XFA +class CPDF_TestXFAContext : public CPDFXFA_Context { + public: + CPDF_TestXFAContext() + : CPDFXFA_Context(pdfium::MakeUnique()) {} + + void SetRoot(CPDF_Dictionary* root) { + reinterpret_cast(GetPDFDoc())->SetRoot(root); + } + + CPDF_IndirectObjectHolder* GetHolder() { return GetPDFDoc(); } +}; +using CPDF_TestPdfDocument = CPDF_TestXFAContext; +#else // PDF_ENABLE_XFA +using CPDF_TestPdfDocument = CPDF_TestDocument; +#endif // PDF_ENABLE_XFA + +class PDFCatalogTest : public testing::Test { + public: + void SetUp() override { + CPDF_ModuleMgr::Get()->Init(); + + m_pDoc = pdfium::MakeUnique(); + + // Setup the root directory. + m_pRootObj = pdfium::MakeUnique(); + } + + void TearDown() override { + m_pDoc.reset(); + CPDF_ModuleMgr::Destroy(); + } + + protected: + std::unique_ptr m_pDoc; + std::unique_ptr m_pRootObj; +}; + +TEST_F(PDFCatalogTest, IsTagged) { + // Null doc + EXPECT_FALSE(FPDFCatalog_IsTagged(nullptr)); + + // No root + m_pDoc->SetRoot(nullptr); + EXPECT_FALSE(FPDFCatalog_IsTagged(m_pDoc.get())); + + // Empty root + m_pDoc->SetRoot(m_pRootObj.get()); + EXPECT_FALSE(FPDFCatalog_IsTagged(m_pDoc.get())); + + // Root with other key + m_pRootObj->SetNewFor("OTHER_KEY", "other value", false); + EXPECT_FALSE(FPDFCatalog_IsTagged(m_pDoc.get())); + + // Root with empty MarkInfo + CPDF_Dictionary* markInfoDict = + m_pRootObj->SetNewFor("MarkInfo"); + EXPECT_FALSE(FPDFCatalog_IsTagged(m_pDoc.get())); + + // MarkInfo present but Marked is 0 + markInfoDict->SetNewFor("Marked", 0); + EXPECT_FALSE(FPDFCatalog_IsTagged(m_pDoc.get())); + + // MarkInfo present and Marked is 1, PDF is considered tagged. + markInfoDict->SetNewFor("Marked", 1); + EXPECT_TRUE(FPDFCatalog_IsTagged(m_pDoc.get())); +} -- cgit v1.2.3