// Copyright 2017 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 <cstring> #include "fxbarcode/oned/BC_OnedCode39Writer.h" #include "testing/gtest/include/gtest/gtest.h" namespace { // 3 wide and 6 narrow modules per char. 1 space between chars. const int MODULES_PER_CHAR = 3 * 3 + 6 * 1 + 1; // '*' is added as the first and last char. const int DELIMITER_CHARS = 2; // Last char may serve as checksum. const int CHECKSUM_CHARS = 1; TEST(OnedCode39WriterTest, SetWideNarrowRatio) { // Code 39 barcodes encode strings of any size into modules in a // unidimensional disposition. // Each module is either: a narrow bar, a narrow space, a wide // bar, or a wide space. Accepted wide-to-narrow ratios are between 2 and 3. // This writer in particular only takes integer ratios, so it's either 2 or 3. CBC_OnedCode39Writer writer; EXPECT_FALSE(writer.SetWideNarrowRatio(0)); EXPECT_FALSE(writer.SetWideNarrowRatio(1)); EXPECT_TRUE(writer.SetWideNarrowRatio(2)); EXPECT_TRUE(writer.SetWideNarrowRatio(3)); EXPECT_FALSE(writer.SetWideNarrowRatio(4)); EXPECT_FALSE(writer.SetWideNarrowRatio(100)); writer.SetWideNarrowRatio(3); int32_t width; int32_t height; uint8_t* encoded; const char* expected; encoded = writer.Encode("PDFIUM", BCFORMAT_CODE_39, width, height); expected = "# # ### ### # " // * Start "# ### ### # # " // P "# # ### # ### " // D "# ### ### # # " // F "# ### # ### # " // I "### # # # ### " // U "### ### # # # " // M "# # ### ### #"; // * End FX_Free(encoded); writer.SetWideNarrowRatio(2); encoded = writer.Encode("PDFIUM", BCFORMAT_CODE_39, width, height); expected = "# # ## ## # " // * Start "# ## ## # # " // P "# # ## # ## " // D "# ## ## # # " // F "# ## # ## # " // I "## # # # ## " // U "## ## # # # " // M "# # ## ## #"; // * End FX_Free(encoded); } TEST(OnedCode39WriterTest, Encode) { CBC_OnedCode39Writer writer; int32_t width; int32_t height; uint8_t* encoded; const char* expected; encoded = writer.Encode("", BCFORMAT_CODE_39, width, height); EXPECT_EQ(1, height); EXPECT_EQ((0 + DELIMITER_CHARS) * MODULES_PER_CHAR - 1, width); expected = "# # ### ### # " // * Start "# # ### ### #"; // * End for (size_t i = 0; i < strlen(expected); i++) { EXPECT_EQ(expected[i] != ' ', !!encoded[i]) << i; } FX_Free(encoded); encoded = writer.Encode("123", BCFORMAT_CODE_39, width, height); EXPECT_EQ(1, height); EXPECT_EQ((3 + DELIMITER_CHARS) * MODULES_PER_CHAR - 1, width); expected = "# # ### ### # " // * Start "### # # # ### " // 1 "# ### # # ### " // 2 "### ### # # # " // 3 "# # ### ### #"; // * End for (size_t i = 0; i < strlen(expected); i++) { EXPECT_EQ(expected[i] != ' ', !!encoded[i]) << i; } FX_Free(encoded); encoded = writer.Encode("PDFIUM", BCFORMAT_CODE_39, width, height); EXPECT_EQ(1, height); EXPECT_EQ((6 + DELIMITER_CHARS) * MODULES_PER_CHAR - 1, width); expected = "# # ### ### # " // * Start "# ### ### # # " // P "# # ### # ### " // D "# ### ### # # " // F "# ### # ### # " // I "### # # # ### " // U "### ### # # # " // M "# # ### ### #"; // * End for (size_t i = 0; i < strlen(expected); i++) { EXPECT_EQ(expected[i] != ' ', !!encoded[i]) << i; } FX_Free(encoded); encoded = writer.Encode("A -$%./+Z", BCFORMAT_CODE_39, width, height); EXPECT_EQ(1, height); EXPECT_EQ((9 + DELIMITER_CHARS) * MODULES_PER_CHAR - 1, width); expected = "# # ### ### # " // * Start "### # # # ### " // A "# ### # ### # " // Space "# # # ### ### " // - "# # # # # " // $ "# # # # # " // % "### # # ### # " // . "# # # # # " // / "# # # # # " // + "# ### ### # # " // Z "# # ### ### #"; // * End for (size_t i = 0; i < strlen(expected); i++) { EXPECT_EQ(expected[i] != ' ', !!encoded[i]) << i; } FX_Free(encoded); } TEST(OnedCode39WriterTest, Checksum) { CBC_OnedCode39Writer writer; int32_t width; int32_t height; uint8_t* encoded; const char* expected; writer.SetCalcChecksum(true); encoded = writer.Encode("123", BCFORMAT_CODE_39, width, height); EXPECT_EQ(1, height); EXPECT_EQ((3 + CHECKSUM_CHARS + DELIMITER_CHARS) * MODULES_PER_CHAR - 1, width); expected = "# # ### ### # " // * Start "### # # # ### " // 1 (1) "# ### # # ### " // 2 (2) "### ### # # # " // 3 (3) "# ### ### # # " // 6 (6 = (1 + 2 + 3) % 43) "# # ### ### #"; // * End for (size_t i = 0; i < strlen(expected); i++) { EXPECT_EQ(expected[i] != ' ', !!encoded[i]) << i; } FX_Free(encoded); encoded = writer.Encode("PDFIUM", BCFORMAT_CODE_39, width, height); EXPECT_EQ(1, height); EXPECT_EQ((6 + CHECKSUM_CHARS + DELIMITER_CHARS) * MODULES_PER_CHAR - 1, width); expected = "# # ### ### # " // * Start "# ### ### # # " // P (25) "# # ### # ### " // D (13) "# ### ### # # " // F (15) "# ### # ### # " // I (18) "### # # # ### " // U (30) "### ### # # # " // M (22) "### # # ### # " // . (37 = (25 + 13 + 15 + 18 + 30 + 22) % 43) "# # ### ### #"; // * End for (size_t i = 0; i < strlen(expected); i++) { EXPECT_EQ(expected[i] != ' ', !!encoded[i]) << i; } FX_Free(encoded); } } // namespace