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

Side by Side Diff: fpdfsdk/fpdf_structtree_embeddertest.cpp

Issue 2519343002: Add APIs for limited use of document tagged code. (Closed)
Patch Set: Fix alt text encoding 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 "core/fxcrt/fx_string.h"
6 #include "public/fpdf_structtree.h"
7 #include "testing/embedder_test.h"
8 #include "testing/test_support.h"
9
10 class FPDFStructTreeEmbeddertest : public EmbedderTest, public TestSaver {};
11
12 TEST_F(FPDFStructTreeEmbeddertest, GetAltText) {
13 ASSERT_TRUE(OpenDocument("tagged_alt_text.pdf"));
14 FPDF_PAGE page = LoadPage(0);
15 ASSERT_TRUE(page);
16
17 FPDF_STRUCTTREE struct_tree = FPDF_StructTree_GetForPage(page);
18 ASSERT_TRUE(struct_tree);
19 ASSERT_EQ(1, FPDF_StructTree_CountChildren(struct_tree));
20
21 FPDF_STRUCTELEMENT element = FPDF_StructTree_GetChildAtIndex(struct_tree, -1);
22 EXPECT_EQ(nullptr, element);
23 element = FPDF_StructTree_GetChildAtIndex(struct_tree, 1);
24 EXPECT_EQ(nullptr, element);
25 element = FPDF_StructTree_GetChildAtIndex(struct_tree, 0);
26 ASSERT_NE(nullptr, element);
27 EXPECT_EQ(0U, FPDF_StructElement_GetAltText(element, nullptr, 0));
28
29 ASSERT_EQ(1, FPDF_StructElement_CountChildren(element));
30 FPDF_STRUCTELEMENT child_element =
31 FPDF_StructElement_GetChildAtIndex(element, -1);
32 EXPECT_EQ(nullptr, child_element);
33 child_element = FPDF_StructElement_GetChildAtIndex(element, 1);
34 EXPECT_EQ(nullptr, child_element);
35 child_element = FPDF_StructElement_GetChildAtIndex(element, 0);
36 ASSERT_NE(nullptr, child_element);
37 EXPECT_EQ(0U, FPDF_StructElement_GetAltText(child_element, nullptr, 0));
38
39 ASSERT_EQ(1, FPDF_StructElement_CountChildren(child_element));
40 FPDF_STRUCTELEMENT gchild_element =
41 FPDF_StructElement_GetChildAtIndex(child_element, -1);
42 EXPECT_EQ(nullptr, gchild_element);
43 gchild_element = FPDF_StructElement_GetChildAtIndex(child_element, 1);
44 EXPECT_EQ(nullptr, gchild_element);
45 gchild_element = FPDF_StructElement_GetChildAtIndex(child_element, 0);
46 ASSERT_NE(nullptr, gchild_element);
47 ASSERT_EQ(24U, FPDF_StructElement_GetAltText(gchild_element, nullptr, 0));
48
49 unsigned short buffer[12];
50 ASSERT_EQ(24U, FPDF_StructElement_GetAltText(gchild_element, buffer,
51 sizeof(buffer)));
52 const FX_WCHAR kExpected[] = L"Black Image";
53 EXPECT_EQ(CFX_WideString(kExpected),
54 CFX_WideString::FromUTF16LE(buffer, FXSYS_len(kExpected)));
dsinclair 2016/11/23 14:04:19 Add a test where buffer is provided by buflen is l
Lei Zhang 2016/11/23 19:49:55 Sure.
55
56 FPDF_StructTree_Close(struct_tree);
npm 2016/11/23 16:23:01 Test that struct_tree is null now?
Lei Zhang 2016/11/23 19:49:55 Calling "delete ptr" doesn't set |ptr| to nullptr.
57 FPDF_ClosePage(page);
58 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698