12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- // This file is part of OpenCV project.
- // It is subject to the license terms in the LICENSE file found in the top-level directory
- // of this distribution and at http://opencv.org/license.html.
- #include "test_precomp.hpp"
- namespace opencv_test{namespace{
- //init validation map
- datasetType initValidation(std::string path)
- {
- const std::string valid_path = findDataFile(path);
- return buildDataSet(valid_path);
- }
- TEST(Barcode_BarcodeDetector_single, regression)
- {
- const std::string root = "barcode/single/";
- datasetType validation = initValidation(root + "result.csv");
- auto bardet = barcode::BarcodeDetector();
- datasetType::iterator iterator = validation.begin();
- while (iterator != validation.end())
- {
- std::string img_name = iterator->first;
- std::string result = iterator->second;
- std::string image_path = findDataFile(root + img_name);
- Mat img = imread(image_path);
- EXPECT_FALSE(img.empty()) << "Can't read image: " << image_path;
- std::vector<cv::Point2f> points;
- std::vector<std::string> infos;
- std::vector<cv::barcode::BarcodeType> formats;
- bardet.detectAndDecode(img, infos, formats, points);
- EXPECT_FALSE(points.empty()) << "Nothing detected: " << image_path;
- bool is_correct = false;
- for (const auto &ans : infos)
- {
- if (ans == result)
- {
- is_correct = true;
- break;
- }
- }
- EXPECT_TRUE(is_correct) << "No results for " << img_name;
- iterator++;
- }
- }
- TEST(Barcode_BarcodeDetector_detect_multi, detect_regression)
- {
- const std::string root = "barcode/multiple/";
- datasetType validation = initValidation(root + "result.csv");
- auto bardet = barcode::BarcodeDetector();
- datasetType::iterator iterator = validation.begin();
- while (iterator != validation.end())
- {
- std::string img = iterator->first;
- size_t expect_corners_size = std::stoi(iterator->second);
- std::string image_path = findDataFile(root + img);
- Mat src = imread(image_path);
- EXPECT_FALSE(src.empty()) << "Can't read image: " << image_path;
- std::vector<Point> corners;
- bardet.detect(src, corners);
- EXPECT_EQ(corners.size(), expect_corners_size) << "Can't detect all barcodes: " << img;
- iterator++;
- }
- }
- TEST(Barcode_BarcodeDetector_basic, not_found_barcode)
- {
- auto bardet = barcode::BarcodeDetector();
- std::vector<Point> corners;
- vector<cv::String> decoded_info;
- vector<barcode::BarcodeType> decoded_type;
- Mat zero_image = Mat::zeros(256, 256, CV_8UC1);
- EXPECT_FALSE(bardet.detect(zero_image, corners));
- corners = std::vector<Point>(4);
- EXPECT_ANY_THROW(bardet.decode(zero_image, corners, decoded_info, decoded_type));
- }
- }} // namespace
|