OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2016 PDFium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "public/fpdf_structtree.h" | |
6 #include "testing/embedder_test.h" | |
7 #include "testing/test_support.h" | |
8 | |
9 class FPDFStructTreeEmbeddertest : public EmbedderTest, public TestSaver {}; | |
10 | |
11 TEST_F(FPDFStructTreeEmbeddertest, GetAltText) { | |
12 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
| |
13 FPDF_PAGE page = LoadPage(0); | |
14 ASSERT_TRUE(page); | |
15 | |
16 FPDF_STRUCTTREE struct_tree = FPDF_StructTree_GetForPage(page); | |
17 ASSERT_TRUE(struct_tree); | |
18 ASSERT_EQ(1, FPDF_StructTree_CountChildren(struct_tree)); | |
19 | |
20 FPDF_STRUCTELEMENT element = FPDF_StructTree_GetChildAtIndex(struct_tree, -1); | |
21 EXPECT_EQ(nullptr, element); | |
22 element = FPDF_StructTree_GetChildAtIndex(struct_tree, 1); | |
23 EXPECT_EQ(nullptr, element); | |
24 element = FPDF_StructTree_GetChildAtIndex(struct_tree, 0); | |
25 ASSERT_NE(nullptr, element); | |
26 EXPECT_EQ(0U, FPDF_StructElement_GetAltText(element, nullptr, 0)); | |
27 | |
28 ASSERT_EQ(1, FPDF_StructElement_CountChildren(element)); | |
29 FPDF_STRUCTELEMENT child_element = | |
30 FPDF_StructElement_GetChildAtIndex(element, -1); | |
31 EXPECT_EQ(nullptr, child_element); | |
32 child_element = FPDF_StructElement_GetChildAtIndex(element, 1); | |
33 EXPECT_EQ(nullptr, child_element); | |
34 child_element = FPDF_StructElement_GetChildAtIndex(element, 0); | |
35 ASSERT_NE(nullptr, child_element); | |
36 EXPECT_EQ(0U, FPDF_StructElement_GetAltText(child_element, nullptr, 0)); | |
37 | |
38 ASSERT_EQ(1, FPDF_StructElement_CountChildren(child_element)); | |
39 FPDF_STRUCTELEMENT gchild_element = | |
40 FPDF_StructElement_GetChildAtIndex(child_element, -1); | |
41 EXPECT_EQ(nullptr, gchild_element); | |
42 gchild_element = FPDF_StructElement_GetChildAtIndex(child_element, 1); | |
43 EXPECT_EQ(nullptr, gchild_element); | |
44 gchild_element = FPDF_StructElement_GetChildAtIndex(child_element, 0); | |
45 ASSERT_NE(nullptr, gchild_element); | |
46 ASSERT_EQ(25U, FPDF_StructElement_GetAltText(gchild_element, nullptr, 0)); | |
47 | |
48 char buffer[25]; | |
49 ASSERT_EQ(25U, FPDF_StructElement_GetAltText(gchild_element, buffer, | |
50 sizeof(buffer))); | |
51 const char kBlackImageText[25] = | |
52 "\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
| |
53 EXPECT_EQ(0, memcmp(kBlackImageText, buffer, sizeof(buffer))); | |
54 | |
55 FPDF_StructTree_Close(struct_tree); | |
56 FPDF_ClosePage(page); | |
57 } | |
OLD | NEW |