1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
/*
* Copyright 2017 Huy Cuong Nguyen
* Copyright 2008 ZXing authors
*/
// SPDX-License-Identifier: Apache-2.0
#include "BitMatrix.h"
#include "BitMatrixIO.h"
#include "ByteArray.h"
#include "qrcode/QRBitMatrixParser.h"
#include "qrcode/QRFormatInformation.h"
#include "qrcode/QRVersion.h"
#include "gtest/gtest.h"
using namespace ZXing;
using namespace ZXing::QRCode;
TEST(QRBitMatrixParserTest, MQRCodeM3L)
{
const auto bitMatrix = ParseBitMatrix("XXXXXXX X X X X\n"
"X X X X \n"
"X XXX X XXXXXXX\n"
"X XXX X X X XX\n"
"X XXX X X XX\n"
"X X X X X X\n"
"XXXXXXX X XX \n"
" X X X\n"
"XXXXXX X X X\n"
" X XX XXX\n"
"XXX XX XXXX XXX\n"
" X X XXX X \n"
"X XXXXX XXX X X\n"
" X X X XXX \n"
"XXX XX X X XXXX\n",
88, false);
const auto format = ReadFormatInformation(bitMatrix);
const auto version = ReadVersion(bitMatrix, format.type());
EXPECT_EQ(3, version->versionNumber());
const auto codewords = ReadCodewords(bitMatrix, *version, format);
EXPECT_EQ(17, codewords.size());
EXPECT_EQ(0x0, codewords[10]);
EXPECT_EQ(0xd1, codewords[11]);
}
TEST(QRBitMatrixParserTest, MQRCodeM3M)
{
const auto bitMatrix = ParseBitMatrix("XXXXXXX X X X X\n"
"X X XX\n"
"X XXX X X XX XX\n"
"X XXX X X X \n"
"X XXX X XX XXXX\n"
"X X XX \n"
"XXXXXXX X XXXX\n"
" X XXX \n"
"X XX XX X X\n"
" X X XX \n"
"XX XX XXXXXXX\n"
" X X X\n"
"XX X X X \n"
" X X X \n"
"X X XXXX XXX\n",
88, false);
const auto format = ReadFormatInformation(bitMatrix);
const auto version = ReadVersion(bitMatrix, format.type());
EXPECT_EQ(3, version->versionNumber());
const auto codewords = ReadCodewords(bitMatrix, *version, format);
EXPECT_EQ(17, codewords.size());
EXPECT_EQ(0x0, codewords[8]);
EXPECT_EQ(0x89, codewords[9]);
}
|