Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
cpdf_syntax_parser_unittest.cpp
Go to the documentation of this file.
1// Copyright 2016 The PDFium Authors
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 <limits>
6
7#include "core/fpdfapi/parser/cpdf_object.h"
8#include "core/fpdfapi/parser/cpdf_parser.h"
9#include "core/fpdfapi/parser/cpdf_syntax_parser.h"
10#include "core/fxcrt/cfx_read_only_span_stream.h"
11#include "core/fxcrt/fx_extension.h"
12#include "testing/gmock/include/gmock/gmock.h"
13#include "testing/gtest/include/gtest/gtest.h"
14#include "testing/utils/path_service.h"
15
16using testing::ElementsAre;
17using testing::IsEmpty;
18
20 {
21 // Empty string.
22 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
23 pdfium::span<const uint8_t>()));
24 EXPECT_THAT(parser.ReadHexString(), IsEmpty());
25 EXPECT_EQ(0, parser.GetPos());
26 }
27 {
28 // Blank string.
29 static const char data[] = " ";
30 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
31 ByteStringView(data).unsigned_span()));
32 EXPECT_THAT(parser.ReadHexString(), IsEmpty());
33 EXPECT_EQ(2, parser.GetPos());
34 }
35 {
36 // Skips unknown characters.
37 static const char data[] = "z12b";
38 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
39 ByteStringView(data).unsigned_span()));
40 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x12, 0xb0));
41 EXPECT_EQ(4, parser.GetPos());
42 }
43 {
44 // Skips unknown characters.
45 static const char data[] = "*<&*#$^&@1";
46 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
47 ByteStringView(data).unsigned_span()));
48 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x10));
49 EXPECT_EQ(10, parser.GetPos());
50 }
51 {
52 // Skips unknown characters.
53 static const char data[] = "\x80zab";
54 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
55 ByteStringView(data).unsigned_span()));
56 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0xab));
57 EXPECT_EQ(4, parser.GetPos());
58 }
59 {
60 // Skips unknown characters.
61 static const char data[] = "\xffzab";
62 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
63 ByteStringView(data).unsigned_span()));
64 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0xab));
65 EXPECT_EQ(4, parser.GetPos());
66 }
67 {
68 // Regular conversion.
69 static const char data[] = "1A2b>abcd";
70 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
71 ByteStringView(data).unsigned_span()));
72 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x1a, 0x2b));
73 EXPECT_EQ(5, parser.GetPos());
74 }
75 {
76 // Position out of bounds.
77 static const char data[] = "12ab>";
78 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
79 ByteStringView(data).unsigned_span()));
80 parser.SetPos(5);
81 EXPECT_THAT(parser.ReadHexString(), IsEmpty());
82
83 parser.SetPos(6);
84 EXPECT_THAT(parser.ReadHexString(), IsEmpty());
85
86 parser.SetPos(std::numeric_limits<FX_FILESIZE>::max());
87 EXPECT_THAT(parser.ReadHexString(), IsEmpty());
88
89 // Check string still parses when set to 0.
90 parser.SetPos(0);
91 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x12, 0xab));
92 }
93 {
94 // Missing ending >.
95 static const char data[] = "1A2b";
96 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
97 ByteStringView(data).unsigned_span()));
98 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x1a, 0x2b));
99 EXPECT_EQ(4, parser.GetPos());
100 }
101 {
102 // Missing ending >.
103 static const char data[] = "12abz";
104 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
105 ByteStringView(data).unsigned_span()));
106 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x12, 0xab));
107 EXPECT_EQ(5, parser.GetPos());
108 }
109 {
110 // Uneven number of bytes.
111 static const char data[] = "1A2>asdf";
112 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
113 ByteStringView(data).unsigned_span()));
114 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x1a, 0x20));
115 EXPECT_EQ(4, parser.GetPos());
116 }
117 {
118 // Uneven number of bytes.
119 static const char data[] = "1A2zasdf";
120 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
121 ByteStringView(data).unsigned_span()));
122 EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x1a, 0x2a, 0xdf));
123 EXPECT_EQ(8, parser.GetPos());
124 }
125 {
126 // Just ending character.
127 const char gt = '>';
128 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
129 pdfium::byte_span_from_ref(gt)));
130 EXPECT_THAT(parser.ReadHexString(), IsEmpty());
131 EXPECT_EQ(1, parser.GetPos());
132 }
133}
134
136 // Data with a reference with number CPDF_Object::kInvalidObjNum
137 static const char data[] = "4294967295 0 R";
138 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(
139 ByteStringView(data).unsigned_span()));
140 RetainPtr<CPDF_Object> ref = parser.GetObjectBody(nullptr);
141 EXPECT_FALSE(ref);
142}
143
145 static const uint8_t data[] = " WORD ";
146 CPDF_SyntaxParser parser(pdfium::MakeRetain<CFX_ReadOnlySpanStream>(data));
147 EXPECT_EQ("WORD", parser.PeekNextWord());
148 EXPECT_EQ("WORD", parser.GetNextWord().word);
149}
FX_FILESIZE GetPos() const
void SetPos(FX_FILESIZE pos)
TEST(FXCRYPT, MD5GenerateEmtpyData)
#define FX_FILESIZE
Definition fx_types.h:19