blob: 17490fc822231bf328d45fb56dbc15b344f0b3eb [file] [log] [blame] [edit]
// Copyright 2015 The PDFium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "core/fpdfapi/page/cpdf_streamparser.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
using testing::ElementsAre;
using testing::IsEmpty;
TEST(CPDFStreamParserTest, ReadHexString) {
{
// Position out of bounds.
uint8_t data[] = "12ab>";
CPDF_StreamParser parser(data);
parser.SetPos(6);
EXPECT_THAT(parser.ReadHexString(), IsEmpty());
}
{
// Regular conversion.
uint8_t data[] = "1A2b>abcd";
CPDF_StreamParser parser(data);
EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x1a, 0x2b));
EXPECT_EQ(5u, parser.GetPos());
}
{
// Missing ending >
uint8_t data[] = "1A2b";
CPDF_StreamParser parser(data);
EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x1a, 0x2b));
EXPECT_EQ(5u, parser.GetPos());
}
{
// Uneven number of bytes.
uint8_t data[] = "1A2>asdf";
CPDF_StreamParser parser(data);
EXPECT_THAT(parser.ReadHexString(), ElementsAre(0x1a, 0x20));
EXPECT_EQ(4u, parser.GetPos());
}
{
uint8_t data[] = ">";
CPDF_StreamParser parser(data);
EXPECT_THAT(parser.ReadHexString(), IsEmpty());
EXPECT_EQ(1u, parser.GetPos());
}
}