// 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 #include "core/fxcrt/data_vector.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 const char kExpected1[] = "# #" // Start " ## #" // 1 L " # ##" // 2 L " #### #" // 3 L " # ##" // 4 L " # # " // Middle "# ### " // 5 R "# # " // 6 R "# # " // 7 R "### # " // 0 R "# #"; // End DataVector encoded = writer.Encode("12345670"); ASSERT_EQ(strlen(kExpected1), encoded.size()); for (size_t i = 0; i < strlen(kExpected1); i++) EXPECT_EQ(kExpected1[i] != ' ', !!encoded[i]) << i; static const char kExpected2[] = "# #" // 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(strlen(kExpected2), encoded.size()); for (size_t i = 0; i < strlen(kExpected2); 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