Index: fpdfsdk/fpdf_structtree_embeddertest.cpp |
diff --git a/fpdfsdk/fpdf_structtree_embeddertest.cpp b/fpdfsdk/fpdf_structtree_embeddertest.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ad6ee28c6703584f35abcd1c793d9b12a1f62808 |
--- /dev/null |
+++ b/fpdfsdk/fpdf_structtree_embeddertest.cpp |
@@ -0,0 +1,57 @@ |
+// 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 "public/fpdf_structtree.h" |
+#include "testing/embedder_test.h" |
+#include "testing/test_support.h" |
+ |
+class FPDFStructTreeEmbeddertest : public EmbedderTest, public TestSaver {}; |
+ |
+TEST_F(FPDFStructTreeEmbeddertest, GetAltText) { |
+ ASSERT_TRUE(OpenDocument("tagged_alt_text.pdf")); |
Lei Zhang
2016/11/22 23:30:42
Made tagged_alt_text.pdf in OpenOffice. I set the
Tom Sepez
2016/11/22 23:45:36
That should be fine. I pulled the patch and it lo
|
+ FPDF_PAGE page = LoadPage(0); |
+ ASSERT_TRUE(page); |
+ |
+ FPDF_STRUCTTREE struct_tree = FPDF_StructTree_GetForPage(page); |
+ ASSERT_TRUE(struct_tree); |
+ ASSERT_EQ(1, FPDF_StructTree_CountChildren(struct_tree)); |
+ |
+ FPDF_STRUCTELEMENT element = FPDF_StructTree_GetChildAtIndex(struct_tree, -1); |
+ EXPECT_EQ(nullptr, element); |
+ element = FPDF_StructTree_GetChildAtIndex(struct_tree, 1); |
+ EXPECT_EQ(nullptr, element); |
+ element = FPDF_StructTree_GetChildAtIndex(struct_tree, 0); |
+ ASSERT_NE(nullptr, element); |
+ EXPECT_EQ(0U, FPDF_StructElement_GetAltText(element, nullptr, 0)); |
+ |
+ ASSERT_EQ(1, FPDF_StructElement_CountChildren(element)); |
+ FPDF_STRUCTELEMENT child_element = |
+ FPDF_StructElement_GetChildAtIndex(element, -1); |
+ EXPECT_EQ(nullptr, child_element); |
+ child_element = FPDF_StructElement_GetChildAtIndex(element, 1); |
+ EXPECT_EQ(nullptr, child_element); |
+ child_element = FPDF_StructElement_GetChildAtIndex(element, 0); |
+ ASSERT_NE(nullptr, child_element); |
+ EXPECT_EQ(0U, FPDF_StructElement_GetAltText(child_element, nullptr, 0)); |
+ |
+ ASSERT_EQ(1, FPDF_StructElement_CountChildren(child_element)); |
+ FPDF_STRUCTELEMENT gchild_element = |
+ FPDF_StructElement_GetChildAtIndex(child_element, -1); |
+ EXPECT_EQ(nullptr, gchild_element); |
+ gchild_element = FPDF_StructElement_GetChildAtIndex(child_element, 1); |
+ EXPECT_EQ(nullptr, gchild_element); |
+ gchild_element = FPDF_StructElement_GetChildAtIndex(child_element, 0); |
+ ASSERT_NE(nullptr, gchild_element); |
+ ASSERT_EQ(25U, FPDF_StructElement_GetAltText(gchild_element, nullptr, 0)); |
+ |
+ char buffer[25]; |
+ ASSERT_EQ(25U, FPDF_StructElement_GetAltText(gchild_element, buffer, |
+ sizeof(buffer))); |
+ const char kBlackImageText[25] = |
+ "\xFE\xFF\00B\00l\00a\00c\00k\00 \00I\00m\00a\00g\00e"; |
Lei Zhang
2016/11/22 23:30:42
Is there a better way to do this?
Tom Sepez
2016/11/22 23:45:36
const uint8_t kBlackImageText[25] = {
0xfe, 0xff
|
+ EXPECT_EQ(0, memcmp(kBlackImageText, buffer, sizeof(buffer))); |
+ |
+ FPDF_StructTree_Close(struct_tree); |
+ FPDF_ClosePage(page); |
+} |