Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(997)

Side by Side Diff: fpdfsdk/fpdf_structtree_embeddertest.cpp

Issue 2519343002: Add APIs for limited use of document tagged code. (Closed)
Patch Set: Add test Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698