blob: 76a6bc958de46b252950aa412766232dc810e340 [file] [log] [blame]
// Copyright 2017 The PDFium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "fxbarcode/oned/BC_OnedEAN8Writer.h"
#include "core/fxcrt/data_vector.h"
#include "core/fxcrt/span.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace {
TEST(OnedEAN8WriterTest, Encode) {
CBC_OnedEAN8Writer writer;
writer.InitEANWriter();
// EAN-8 barcodes encode 8-digit numbers into 67 modules in a unidimensional
// disposition.
EXPECT_TRUE(writer.Encode("").empty());
EXPECT_TRUE(writer.Encode("123").empty());
EXPECT_TRUE(writer.Encode("1234567").empty());
EXPECT_TRUE(writer.Encode("123456789").empty());
static constexpr auto kExpected1 = pdfium::span_from_cstring(
"# #" // Start
" ## #" // 1 L
" # ##" // 2 L
" #### #" // 3 L
" # ##" // 4 L
" # # " // Middle
"# ### " // 5 R
"# # " // 6 R
"# # " // 7 R
"### # " // 0 R
"# #"); // End
DataVector<uint8_t> encoded = writer.Encode("12345670");
ASSERT_EQ(kExpected1.size(), encoded.size());
for (size_t i = 0; i < kExpected1.size(); i++) {
EXPECT_EQ(kExpected1[i] != ' ', !!encoded[i]) << i;
}
static constexpr auto kExpected2 = pdfium::span_from_cstring(
"# #" // Start
" # ##" // 9 L
" # ##" // 9 L
" # ##" // 4 L
" # ##" // 4 L
" # # " // Middle
"## ## " // 1 R
"## ## " // 1 R
"### # " // 0 R
"# ### " // 4 R
"# #"); // End
encoded = writer.Encode("99441104");
ASSERT_EQ(kExpected2.size(), encoded.size());
for (size_t i = 0; i < kExpected2.size(); i++) {
EXPECT_EQ(kExpected2[i] != ' ', !!encoded[i]) << i;
}
}
TEST(OnedEAN8WriterTest, Checksum) {
CBC_OnedEAN8Writer writer;
writer.InitEANWriter();
EXPECT_EQ(0, writer.CalcChecksum(""));
EXPECT_EQ(6, writer.CalcChecksum("123"));
EXPECT_EQ(0, writer.CalcChecksum("1234567"));
EXPECT_EQ(4, writer.CalcChecksum("9944110"));
}
} // namespace