diff options
author | tsepez <tsepez@chromium.org> | 2016-11-18 14:48:21 -0800 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2016-11-18 14:48:21 -0800 |
commit | 430ab8363e77c48b2c2435af4d289f85e2be1b96 (patch) | |
tree | c0a9bff16a5b56d607d75c9f415dfc2cce7eb3fd /xfa/fxfa/app | |
parent | 9053f19d78b6215570029d896c1d62bbb0ce5f7d (diff) | |
download | pdfium-430ab8363e77c48b2c2435af4d289f85e2be1b96.tar.xz |
Add unit test for CXFA_FileRead.
The FileRead's return convention is being modified at
https://codereview.chromium.org/2430743003/, so first provide
a test of the old behaviour.
Fix some issues with null dictionaries as provided by the
CPDF_Stream default ctor along the way.
Review-Url: https://codereview.chromium.org/2517513003
Diffstat (limited to 'xfa/fxfa/app')
-rw-r--r-- | xfa/fxfa/app/xfa_ffapp_unittest.cpp | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/xfa/fxfa/app/xfa_ffapp_unittest.cpp b/xfa/fxfa/app/xfa_ffapp_unittest.cpp new file mode 100644 index 0000000000..7e1b9d7237 --- /dev/null +++ b/xfa/fxfa/app/xfa_ffapp_unittest.cpp @@ -0,0 +1,86 @@ +// Copyright 2016 PDFium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "xfa/fxfa/xfa_ffapp.h" + +#include <memory> + +#include "core/fpdfapi/parser/cpdf_dictionary.h" +#include "core/fpdfapi/parser/cpdf_stream.h" +#include "core/fxcrt/fx_memory.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "third_party/base/ptr_util.h" + +using UniqueFileRead = + std::unique_ptr<CXFA_FileRead, ReleaseDeleter<CXFA_FileRead>>; + +TEST(CXFAFileRead, NoStreams) { + std::vector<CPDF_Stream*> streams; + UniqueFileRead fileread(new CXFA_FileRead(streams)); + + uint8_t output_buffer[16]; + memset(output_buffer, 0xbd, sizeof(output_buffer)); + EXPECT_FALSE(fileread->ReadBlock(output_buffer, 0, 0)); + EXPECT_EQ(0xbd, output_buffer[0]); +} + +TEST(CXFAFileRead, EmptyStreams) { + std::vector<CPDF_Stream*> streams; + std::unique_ptr<CPDF_Stream> stream1 = pdfium::MakeUnique<CPDF_Stream>(); + streams.push_back(stream1.get()); + UniqueFileRead fileread(new CXFA_FileRead(streams)); + + uint8_t output_buffer[16]; + memset(output_buffer, 0xbd, sizeof(output_buffer)); + EXPECT_FALSE(fileread->ReadBlock(output_buffer, 0, 0)); + EXPECT_EQ(0xbd, output_buffer[0]); +} + +TEST(CXFAFileRead, NormalStreams) { + std::vector<CPDF_Stream*> streams; + std::unique_ptr<CPDF_Stream> stream1 = pdfium::MakeUnique<CPDF_Stream>(); + std::unique_ptr<CPDF_Stream> stream2 = pdfium::MakeUnique<CPDF_Stream>(); + std::unique_ptr<CPDF_Stream> stream3 = pdfium::MakeUnique<CPDF_Stream>(); + + // 16 chars total. + stream1->InitStream(reinterpret_cast<const uint8_t*>("one t"), 5, + new CPDF_Dictionary()); + stream2->InitStream(reinterpret_cast<const uint8_t*>("wo "), 3, + new CPDF_Dictionary()); + stream3->InitStream(reinterpret_cast<const uint8_t*>("three!!!"), 8, + new CPDF_Dictionary()); + + streams.push_back(stream1.get()); + streams.push_back(stream2.get()); + streams.push_back(stream3.get()); + UniqueFileRead fileread(new CXFA_FileRead(streams)); + + uint8_t output_buffer[16]; + memset(output_buffer, 0xbd, sizeof(output_buffer)); + EXPECT_TRUE(fileread->ReadBlock(output_buffer, 0, 0)); + EXPECT_EQ(0xbd, output_buffer[0]); + + memset(output_buffer, 0xbd, sizeof(output_buffer)); + EXPECT_TRUE(fileread->ReadBlock(output_buffer, 1, 0)); + EXPECT_EQ(0xbd, output_buffer[0]); + + memset(output_buffer, 0xbd, sizeof(output_buffer)); + EXPECT_TRUE(fileread->ReadBlock(output_buffer, 0, 1)); + EXPECT_EQ(0, memcmp(output_buffer, "o", 1)); + EXPECT_EQ(0xbd, output_buffer[1]); + + memset(output_buffer, 0xbd, sizeof(output_buffer)); + EXPECT_TRUE(fileread->ReadBlock(output_buffer, 0, sizeof(output_buffer))); + EXPECT_EQ(0, memcmp(output_buffer, "one two three!!!", 16)); + + memset(output_buffer, 0xbd, sizeof(output_buffer)); + EXPECT_TRUE(fileread->ReadBlock(output_buffer, 2, 10)); + EXPECT_EQ(0, memcmp(output_buffer, "e two thre", 10)); + EXPECT_EQ(0xbd, output_buffer[11]); + + memset(output_buffer, 0xbd, sizeof(output_buffer)); + EXPECT_FALSE(fileread->ReadBlock(output_buffer, 1, sizeof(output_buffer))); + EXPECT_EQ(0, memcmp(output_buffer, "ne two three!!!", 15)); + EXPECT_EQ(0xbd, output_buffer[15]); +} |