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

Side by Side Diff: fpdfsdk/fsdk_baseform_embeddertest.cpp

Issue 2260683003: Fix an embedder test with leaked page object (Closed) Base URL: https://pdfium.googlesource.com/pdfium.git@fix
Patch Set: Created 4 years, 4 months 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
1 // Copyright 2016 PDFium Authors. All rights reserved. 1 // Copyright 2016 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "fpdfsdk/include/cba_annotiterator.h" 5 #include "fpdfsdk/include/cba_annotiterator.h"
6 #include "fpdfsdk/include/fsdk_define.h" 6 #include "fpdfsdk/include/fsdk_define.h"
7 #include "fpdfsdk/include/fsdk_mgr.h" 7 #include "fpdfsdk/include/fsdk_mgr.h"
8 #include "testing/embedder_test.h" 8 #include "testing/embedder_test.h"
9 #include "testing/embedder_test_mock_delegate.h" 9 #include "testing/embedder_test_mock_delegate.h"
10 #include "testing/embedder_test_timer_handling_delegate.h" 10 #include "testing/embedder_test_timer_handling_delegate.h"
11 #include "testing/gmock/include/gmock/gmock.h" 11 #include "testing/gmock/include/gmock/gmock.h"
12 #include "testing/gtest/include/gtest/gtest.h" 12 #include "testing/gtest/include/gtest/gtest.h"
13 13
14 namespace { 14 namespace {
15 15
16 void CheckRect(const CFX_FloatRect& actual, const CFX_FloatRect& expected) { 16 void CheckRect(const CFX_FloatRect& actual, const CFX_FloatRect& expected) {
17 EXPECT_EQ(expected.left, actual.left); 17 EXPECT_EQ(expected.left, actual.left);
18 EXPECT_EQ(expected.bottom, actual.bottom); 18 EXPECT_EQ(expected.bottom, actual.bottom);
19 EXPECT_EQ(expected.right, actual.right); 19 EXPECT_EQ(expected.right, actual.right);
20 EXPECT_EQ(expected.top, actual.top); 20 EXPECT_EQ(expected.top, actual.top);
21 } 21 }
22 22
23 } // namespace 23 } // namespace
24 24
25 class FSDKBaseFormEmbeddertest : public EmbedderTest {}; 25 class FSDKBaseFormEmbeddertest : public EmbedderTest {};
26 26
27 TEST_F(FSDKBaseFormEmbeddertest, CBA_AnnotIterator) { 27 TEST_F(FSDKBaseFormEmbeddertest, CBA_AnnotIterator) {
28 EXPECT_TRUE(OpenDocument("annotiter.pdf")); 28 EXPECT_TRUE(OpenDocument("annotiter.pdf"));
29 EXPECT_TRUE(LoadPage(0)); 29 FPDF_PAGE page0 = LoadPage(0);
30 EXPECT_TRUE(LoadPage(1)); 30 FPDF_PAGE page1 = LoadPage(1);
31 EXPECT_TRUE(LoadPage(2)); 31 FPDF_PAGE page2 = LoadPage(2);
32 EXPECT_TRUE(page0);
33 EXPECT_TRUE(page1);
34 EXPECT_TRUE(page2);
32 35
33 CFX_FloatRect LeftBottom(200, 200, 220, 220); 36 CFX_FloatRect LeftBottom(200, 200, 220, 220);
34 CFX_FloatRect RightBottom(400, 201, 420, 221); 37 CFX_FloatRect RightBottom(400, 201, 420, 221);
35 CFX_FloatRect LeftTop(201, 400, 221, 420); 38 CFX_FloatRect LeftTop(201, 400, 221, 420);
36 CFX_FloatRect RightTop(401, 401, 421, 421); 39 CFX_FloatRect RightTop(401, 401, 421, 421);
37 40
38 CPDFSDK_Document* pSDKDoc = 41 CPDFSDK_Document* pSDKDoc =
39 CPDFSDK_Document::FromFPDFFormHandle(form_handle()); 42 CPDFSDK_Document::FromFPDFFormHandle(form_handle());
40 { 43 {
41 // Page 0 specifies "row order". 44 // Page 0 specifies "row order".
42 CBA_AnnotIterator iter(pSDKDoc->GetPageView(0), "Widget", ""); 45 CBA_AnnotIterator iter(
Tom Sepez 2016/08/19 20:41:18 I don't understand why these should change. Under
Tom Sepez 2016/08/19 21:02:16 Is this where the comment about ref-counts kicks i
46 pSDKDoc->GetPageView(UnderlyingFromFPDFPage(page0), true), "Widget",
47 "");
43 CPDFSDK_Annot* pAnnot = iter.GetFirstAnnot(); 48 CPDFSDK_Annot* pAnnot = iter.GetFirstAnnot();
44 CheckRect(pAnnot->GetRect(), RightTop); 49 CheckRect(pAnnot->GetRect(), RightTop);
45 pAnnot = iter.GetNextAnnot(pAnnot); 50 pAnnot = iter.GetNextAnnot(pAnnot);
46 CheckRect(pAnnot->GetRect(), LeftTop); 51 CheckRect(pAnnot->GetRect(), LeftTop);
47 pAnnot = iter.GetNextAnnot(pAnnot); 52 pAnnot = iter.GetNextAnnot(pAnnot);
48 CheckRect(pAnnot->GetRect(), RightBottom); 53 CheckRect(pAnnot->GetRect(), RightBottom);
49 pAnnot = iter.GetNextAnnot(pAnnot); 54 pAnnot = iter.GetNextAnnot(pAnnot);
50 CheckRect(pAnnot->GetRect(), LeftBottom); 55 CheckRect(pAnnot->GetRect(), LeftBottom);
51 pAnnot = iter.GetNextAnnot(pAnnot); 56 pAnnot = iter.GetNextAnnot(pAnnot);
52 EXPECT_EQ(iter.GetFirstAnnot(), pAnnot); 57 EXPECT_EQ(iter.GetFirstAnnot(), pAnnot);
53 58
54 pAnnot = iter.GetLastAnnot(); 59 pAnnot = iter.GetLastAnnot();
55 CheckRect(pAnnot->GetRect(), LeftBottom); 60 CheckRect(pAnnot->GetRect(), LeftBottom);
56 pAnnot = iter.GetPrevAnnot(pAnnot); 61 pAnnot = iter.GetPrevAnnot(pAnnot);
57 CheckRect(pAnnot->GetRect(), RightBottom); 62 CheckRect(pAnnot->GetRect(), RightBottom);
58 pAnnot = iter.GetPrevAnnot(pAnnot); 63 pAnnot = iter.GetPrevAnnot(pAnnot);
59 CheckRect(pAnnot->GetRect(), LeftTop); 64 CheckRect(pAnnot->GetRect(), LeftTop);
60 pAnnot = iter.GetPrevAnnot(pAnnot); 65 pAnnot = iter.GetPrevAnnot(pAnnot);
61 CheckRect(pAnnot->GetRect(), RightTop); 66 CheckRect(pAnnot->GetRect(), RightTop);
62 pAnnot = iter.GetPrevAnnot(pAnnot); 67 pAnnot = iter.GetPrevAnnot(pAnnot);
63 EXPECT_EQ(iter.GetLastAnnot(), pAnnot); 68 EXPECT_EQ(iter.GetLastAnnot(), pAnnot);
64 } 69 }
65 { 70 {
66 // Page 1 specifies "column order" 71 // Page 1 specifies "column order"
67 CBA_AnnotIterator iter(pSDKDoc->GetPageView(1), "Widget", ""); 72 CBA_AnnotIterator iter(
73 pSDKDoc->GetPageView(UnderlyingFromFPDFPage(page1), true), "Widget",
74 "");
68 CPDFSDK_Annot* pAnnot = iter.GetFirstAnnot(); 75 CPDFSDK_Annot* pAnnot = iter.GetFirstAnnot();
69 CheckRect(pAnnot->GetRect(), RightTop); 76 CheckRect(pAnnot->GetRect(), RightTop);
70 pAnnot = iter.GetNextAnnot(pAnnot); 77 pAnnot = iter.GetNextAnnot(pAnnot);
71 CheckRect(pAnnot->GetRect(), RightBottom); 78 CheckRect(pAnnot->GetRect(), RightBottom);
72 pAnnot = iter.GetNextAnnot(pAnnot); 79 pAnnot = iter.GetNextAnnot(pAnnot);
73 CheckRect(pAnnot->GetRect(), LeftTop); 80 CheckRect(pAnnot->GetRect(), LeftTop);
74 pAnnot = iter.GetNextAnnot(pAnnot); 81 pAnnot = iter.GetNextAnnot(pAnnot);
75 CheckRect(pAnnot->GetRect(), LeftBottom); 82 CheckRect(pAnnot->GetRect(), LeftBottom);
76 pAnnot = iter.GetNextAnnot(pAnnot); 83 pAnnot = iter.GetNextAnnot(pAnnot);
77 EXPECT_EQ(iter.GetFirstAnnot(), pAnnot); 84 EXPECT_EQ(iter.GetFirstAnnot(), pAnnot);
78 85
79 pAnnot = iter.GetLastAnnot(); 86 pAnnot = iter.GetLastAnnot();
80 CheckRect(pAnnot->GetRect(), LeftBottom); 87 CheckRect(pAnnot->GetRect(), LeftBottom);
81 pAnnot = iter.GetPrevAnnot(pAnnot); 88 pAnnot = iter.GetPrevAnnot(pAnnot);
82 CheckRect(pAnnot->GetRect(), LeftTop); 89 CheckRect(pAnnot->GetRect(), LeftTop);
83 pAnnot = iter.GetPrevAnnot(pAnnot); 90 pAnnot = iter.GetPrevAnnot(pAnnot);
84 CheckRect(pAnnot->GetRect(), RightBottom); 91 CheckRect(pAnnot->GetRect(), RightBottom);
85 pAnnot = iter.GetPrevAnnot(pAnnot); 92 pAnnot = iter.GetPrevAnnot(pAnnot);
86 CheckRect(pAnnot->GetRect(), RightTop); 93 CheckRect(pAnnot->GetRect(), RightTop);
87 pAnnot = iter.GetPrevAnnot(pAnnot); 94 pAnnot = iter.GetPrevAnnot(pAnnot);
88 EXPECT_EQ(iter.GetLastAnnot(), pAnnot); 95 EXPECT_EQ(iter.GetLastAnnot(), pAnnot);
89 } 96 }
90 { 97 {
91 // Page 2 specifies "struct order" 98 // Page 2 specifies "struct order"
92 CBA_AnnotIterator iter(pSDKDoc->GetPageView(2), "Widget", ""); 99 CBA_AnnotIterator iter(
100 pSDKDoc->GetPageView(UnderlyingFromFPDFPage(page2), true), "Widget",
101 "");
93 CPDFSDK_Annot* pAnnot = iter.GetFirstAnnot(); 102 CPDFSDK_Annot* pAnnot = iter.GetFirstAnnot();
94 CheckRect(pAnnot->GetRect(), LeftBottom); 103 CheckRect(pAnnot->GetRect(), LeftBottom);
95 pAnnot = iter.GetNextAnnot(pAnnot); 104 pAnnot = iter.GetNextAnnot(pAnnot);
96 CheckRect(pAnnot->GetRect(), RightTop); 105 CheckRect(pAnnot->GetRect(), RightTop);
97 pAnnot = iter.GetNextAnnot(pAnnot); 106 pAnnot = iter.GetNextAnnot(pAnnot);
98 CheckRect(pAnnot->GetRect(), LeftTop); 107 CheckRect(pAnnot->GetRect(), LeftTop);
99 pAnnot = iter.GetNextAnnot(pAnnot); 108 pAnnot = iter.GetNextAnnot(pAnnot);
100 CheckRect(pAnnot->GetRect(), RightBottom); 109 CheckRect(pAnnot->GetRect(), RightBottom);
101 pAnnot = iter.GetNextAnnot(pAnnot); 110 pAnnot = iter.GetNextAnnot(pAnnot);
102 EXPECT_EQ(iter.GetFirstAnnot(), pAnnot); 111 EXPECT_EQ(iter.GetFirstAnnot(), pAnnot);
103 112
104 pAnnot = iter.GetLastAnnot(); 113 pAnnot = iter.GetLastAnnot();
105 CheckRect(pAnnot->GetRect(), RightBottom); 114 CheckRect(pAnnot->GetRect(), RightBottom);
106 pAnnot = iter.GetPrevAnnot(pAnnot); 115 pAnnot = iter.GetPrevAnnot(pAnnot);
107 CheckRect(pAnnot->GetRect(), LeftTop); 116 CheckRect(pAnnot->GetRect(), LeftTop);
108 pAnnot = iter.GetPrevAnnot(pAnnot); 117 pAnnot = iter.GetPrevAnnot(pAnnot);
109 CheckRect(pAnnot->GetRect(), RightTop); 118 CheckRect(pAnnot->GetRect(), RightTop);
110 pAnnot = iter.GetPrevAnnot(pAnnot); 119 pAnnot = iter.GetPrevAnnot(pAnnot);
111 CheckRect(pAnnot->GetRect(), LeftBottom); 120 CheckRect(pAnnot->GetRect(), LeftBottom);
112 pAnnot = iter.GetPrevAnnot(pAnnot); 121 pAnnot = iter.GetPrevAnnot(pAnnot);
113 EXPECT_EQ(iter.GetLastAnnot(), pAnnot); 122 EXPECT_EQ(iter.GetLastAnnot(), pAnnot);
114 } 123 }
124
125 UnloadPage(page2);
126 UnloadPage(page1);
127 UnloadPage(page0);
115 } 128 }
OLDNEW
« fpdfsdk/fpdfedit_embeddertest.cpp ('K') | « fpdfsdk/fpdfedit_embeddertest.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698