ODCode128ReaderTest.cpp 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /*
  2. * Copyright 2021 gitlost
  3. */
  4. // SPDX-License-Identifier: Apache-2.0
  5. #include "oned/ODCode128Reader.h"
  6. #include "ReaderOptions.h"
  7. #include "Barcode.h"
  8. #include "gtest/gtest.h"
  9. using namespace ZXing;
  10. using namespace ZXing::OneD;
  11. // Helper to call decodePattern()
  12. static Barcode parse(const int startPattern, PatternRow row)
  13. {
  14. if (startPattern == 'A') {
  15. row.insert(row.begin(), { 0, 2, 1, 1, 4, 1, 2 });
  16. } else if (startPattern == 'B') {
  17. row.insert(row.begin(), { 0, 2, 1, 1, 2, 1, 4 });
  18. } else if (startPattern == 'C') {
  19. row.insert(row.begin(), { 0, 2, 1, 1, 2, 3, 2 });
  20. }
  21. row.insert(row.end(), { 2, 3, 3, 1, 1, 1, 2, 0 }); // Stop pattern
  22. std::unique_ptr<Code128Reader::DecodingState> state;
  23. ReaderOptions opts;
  24. Code128Reader reader(opts);
  25. PatternView next(row);
  26. return reader.decodePattern(0, next, state);
  27. }
  28. TEST(ODCode128ReaderTest, SymbologyIdentifier)
  29. {
  30. {
  31. // Plain "2001"
  32. PatternRow row({ 2, 2, 1, 2, 3, 1, 2, 2, 2, 1, 2, 2, 3, 1, 1, 2, 2, 2 });
  33. auto result = parse('C', row);
  34. EXPECT_EQ(result.symbologyIdentifier(), "]C0");
  35. EXPECT_EQ(result.text(), "2001");
  36. }
  37. {
  38. // GS1 "(20)01"
  39. PatternRow row({ 4, 1, 1, 1, 3, 1, 2, 2, 1, 2, 3, 1, 2, 2, 2, 1, 2, 2, 1, 3, 2, 1, 3, 1 });
  40. auto result = parse('C', row);
  41. EXPECT_EQ(result.symbologyIdentifier(), "]C1");
  42. EXPECT_EQ(result.text(TextMode::HRI), "(20)01");
  43. }
  44. {
  45. // AIM "A FNC1 B"
  46. PatternRow row({ 1, 1, 1, 3, 2, 3, 4, 1, 1, 1, 3, 1, 1, 3, 1, 1, 2, 3, 2, 1, 2, 3, 2, 1 });
  47. auto result = parse('B', row);
  48. EXPECT_EQ(result.symbologyIdentifier(), "]C2");
  49. EXPECT_EQ(result.text(), "AB");
  50. }
  51. {
  52. // AIM "z FNC1 B"
  53. PatternRow row({ 2, 1, 4, 1, 2, 1, 4, 1, 1, 1, 3, 1, 1, 3, 1, 1, 2, 3, 4, 2, 1, 2, 1, 1 });
  54. auto result = parse('B', row);
  55. EXPECT_EQ(result.symbologyIdentifier(), "]C2");
  56. EXPECT_EQ(result.text(), "zB");
  57. }
  58. {
  59. // AIM "99 FNC1 A"
  60. PatternRow row({ 1, 1, 3, 1, 4, 1, 4, 1, 1, 1, 3, 1, 1, 1, 4, 1, 3, 1, 1, 1, 1, 3, 2, 3, 1, 2, 3, 1, 2, 2 });
  61. auto result = parse('C', row);
  62. EXPECT_EQ(result.symbologyIdentifier(), "]C2");
  63. EXPECT_EQ(result.text(), "99A");
  64. }
  65. {
  66. // Bad AIM Application Indicator "? FNC1 B"
  67. PatternRow row({ 2, 1, 2, 3, 2, 1, 4, 1, 1, 1, 3, 1, 1, 3, 1, 1, 2, 3, 3, 2, 2, 2, 1, 1 });
  68. auto result = parse('B', row);
  69. EXPECT_EQ(result.symbologyIdentifier(), "]C0"); // Just ignoring, not giving FormatError
  70. EXPECT_EQ(result.text(), "?<GS>B");
  71. }
  72. }
  73. TEST(ODCode128ReaderTest, ReaderInit)
  74. {
  75. {
  76. // Null
  77. PatternRow row({ 1, 1, 1, 1, 4, 3, 1, 3, 1, 1, 4, 1 });
  78. auto result = parse('C', row);
  79. EXPECT_FALSE(result.readerInit());
  80. EXPECT_EQ(result.text(), "92");
  81. }
  82. {
  83. // Set (FNC3 first)
  84. PatternRow row({ 1, 1, 4, 3, 1, 1, 1, 1, 3, 1, 4, 1, 1, 1, 1, 1, 4, 3, 3, 3, 1, 1, 2, 1 });
  85. auto result = parse('B', row);
  86. EXPECT_TRUE(result.readerInit());
  87. EXPECT_EQ(result.text(), "92");
  88. }
  89. {
  90. // Set (FNC3 between "9" and "2" )
  91. PatternRow row({ 3, 2, 1, 1, 2, 2, 1, 1, 4, 3, 1, 1, 2, 2, 3, 2, 1, 1, 1, 2, 1, 4, 2, 1 });
  92. auto result = parse('B', row);
  93. EXPECT_TRUE(result.readerInit());
  94. EXPECT_EQ(result.text(), "92");
  95. }
  96. }