Chromium Code Reviews| Index: fpdfsdk/src/fpdfview_embeddertest.cpp |
| diff --git a/fpdfsdk/src/fpdfview_embeddertest.cpp b/fpdfsdk/src/fpdfview_embeddertest.cpp |
| index 94a51094a87f35a4f86e49647a6882beb787ca55..ebd64cff00c15b90d6480e486976737537ce2ccb 100644 |
| --- a/fpdfsdk/src/fpdfview_embeddertest.cpp |
| +++ b/fpdfsdk/src/fpdfview_embeddertest.cpp |
| @@ -2,7 +2,11 @@ |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| +#include <limits> |
| +#include <string> |
| + |
| #include "../../testing/embedder_test.h" |
| +#include "../../fpdfsdk/include/fpdfview.h" |
| #include "testing/gtest/include/gtest/gtest.h" |
| class FPDFViewEmbeddertest : public EmbedderTest { |
| @@ -40,3 +44,99 @@ TEST_F(FPDFViewEmbeddertest, ViewerRef) { |
| EXPECT_EQ(DuplexUndefined, FPDF_VIEWERREF_GetDuplex(document())); |
| } |
| +TEST_F(FPDFViewEmbeddertest, NamedDests) { |
| + EXPECT_TRUE(OpenDocument("testing/resources/named_dests.pdf")); |
| + long buffer_size; |
| + char fixed_buffer[512]; |
| + FPDF_DEST dest; |
| + |
| + // Query the size of the first item. |
| + buffer_size = 2000000; // Absurdly large, check not used for this case. |
| + dest = FPDF_GetNamedDest(document(), 0, nullptr, buffer_size); |
| + EXPECT_NE(nullptr, dest); |
| + EXPECT_EQ(12u, buffer_size); |
| + |
| + // Try to retrieve the first item with too small a buffer. |
| + buffer_size = 10; |
| + dest = FPDF_GetNamedDest(document(), 0, fixed_buffer, buffer_size); |
| + EXPECT_NE(nullptr, dest); |
| + EXPECT_EQ(-1, buffer_size); |
| + |
| + // Try to retrieve the first item with correctly sized buffer. Item is |
| + // taken from Dests NameTree in named_dests.pdf. |
| + buffer_size = 12; |
| + dest = FPDF_GetNamedDest(document(), 0, fixed_buffer, buffer_size); |
| + EXPECT_NE(nullptr, dest); |
| + EXPECT_EQ(12u, buffer_size); |
| + EXPECT_EQ(std::string("F\0i\0r\0s\0t\0\0\0", 12), |
| + std::string(fixed_buffer, buffer_size)); |
| + |
| + // Try to retrieve the second item with ample buffer. Iitem is taken |
| + // from Dests NameTree but has a sub-dictionary in named_dests.pdf. |
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), 1, fixed_buffer, buffer_size); |
| + EXPECT_NE(nullptr, dest); |
| + EXPECT_EQ(10u, buffer_size); |
| + EXPECT_EQ(std::string("N\0e\0x\0t\0\0\0", 10), |
| + std::string(fixed_buffer, buffer_size)); |
| + |
| + // Try to retrieve third item with ample buffer. Item is taken |
| + // from Dests NameTree but has a bad sub-dictionary in named_dests.pdf. |
| + // in named_dests.pdf). |
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), 2, fixed_buffer, buffer_size); |
| + EXPECT_EQ(nullptr, dest); |
| + EXPECT_EQ(sizeof(fixed_buffer), buffer_size); // unmodified. |
| + |
| + // Try to retrieve the forth item with ample buffer. Item is taken |
| + // from Dests NameTree but has a vale of the wrong type in named_dests.pdf. |
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), 3, fixed_buffer, buffer_size); |
| + EXPECT_EQ(nullptr, dest); |
| + EXPECT_EQ(sizeof(fixed_buffer), buffer_size); // unmodified. |
| + |
| + // Try to retrieve fifth item with ample buffer. Iitem taken from the |
| + // old-style Dests dictionary object in named_dests.pdf. |
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), 4, fixed_buffer, buffer_size); |
| + EXPECT_NE(nullptr, dest); |
| + EXPECT_EQ(30u, buffer_size); |
| + EXPECT_EQ( |
| + std::string("F\0i\0r\0s\0t\0A\0l\0t\0e\0r\0n\0a\0t\0e\0\0\0", 30), |
| + std::string(fixed_buffer, buffer_size)); |
| + |
| + // Try to retrieve sixth item with ample buffer. Iitem istaken from the |
| + // old-style Dests dictionary object but has a sub-dictionary in |
| + // named_dests.pdf. |
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), 5, fixed_buffer, buffer_size); |
| + EXPECT_NE(nullptr, dest); |
| + EXPECT_EQ(28u, buffer_size); |
| + EXPECT_EQ( |
| + std::string("L\0a\0s\0t\0A\0l\0t\0e\0r\0n\0a\0t\0e\0\0\0", 28), |
| + std::string(fixed_buffer, buffer_size)); |
| + |
| + // Try to retrieve non-existent item with ample buffer. |
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), 6, fixed_buffer, buffer_size); |
| + EXPECT_EQ(nullptr, dest); |
| + EXPECT_EQ(sizeof(fixed_buffer), buffer_size); // unmodified. |
| + |
| + // Try to underflow/overflow the integer index. |
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), std::numeric_limits<int>::max(), |
| + fixed_buffer, buffer_size); |
| + EXPECT_EQ(nullptr, dest); |
| + EXPECT_EQ(sizeof(fixed_buffer), buffer_size); // unmodified. |
| + |
|
Bo Xu
2015/01/21 22:29:42
Same test case here?
Tom Sepez
2015/01/21 22:36:49
nice catch. should be min()
|
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), std::numeric_limits<int>::max(), |
| + fixed_buffer, buffer_size); |
| + EXPECT_EQ(nullptr, dest); |
| + EXPECT_EQ(sizeof(fixed_buffer), buffer_size); // unmodified. |
| + |
| + buffer_size = sizeof(fixed_buffer); |
| + dest = FPDF_GetNamedDest(document(), -1, fixed_buffer, buffer_size); |
| + EXPECT_EQ(nullptr, dest); |
| + EXPECT_EQ(sizeof(fixed_buffer), buffer_size); // unmodified. |
| +} |