如何对用OpenCV开发的API进行测试 (Google Test 版本)

如何对用OpenCV开发的API进行测试 (Google Test 版本)

如何对用OpenCV开发的API进行测试

假设你想测试一个使用OpenCV开发的图像处理API,例如一个图像滤波函数。以下是一种测试方法的示例:

  1. 准备测试环境:首先,需要安装OpenCV库,并设置好C++开发环境。

  2. 编写测试代码:创建一个新的C++文件,引入必要的OpenCV头文件和测试框架头文件(如Google Test)。

    cpp 复制代码
    #include <opencv2/opencv.hpp>
    #include <gtest/gtest.h>
    
    // 测试函数原型声明
    cv::Mat customImageFilter(const cv::Mat &inputImage);
    
    TEST(ImageFilterTest, BasicFiltering) {
        // 准备测试数据
        cv::Mat inputImage = cv::Mat::ones(100, 100, CV_8UC1) * 255; // 创建一个100x100的全白图像
        cv::Mat expectedResult = ...; // 根据你的滤波逻辑定义预期结果
    
        // 调用待测试的图像处理API
        cv::Mat result = customImageFilter(inputImage);
    
        // 验证结果
        EXPECT_EQ(expectedResult.size(), result.size());
        for (int i = 0; i < result.rows; ++i) {
            for (int j = 0; j < result.cols; ++j) {
                EXPECT_EQ(expectedResult.at<uchar>(i, j), result.at<uchar>(i, j));
            }
        }
    }
    
    int main(int argc, char **argv) {
        ::testing::InitGoogleTest(&argc, argv);
        return RUN_ALL_TESTS();
    }
  3. 编译和运行测试:使用合适的编译器编译测试代码,并运行测试。测试框架会自动执行所有测试用例,并报告测试结果。

断言介绍

断言

gtest 使用一系列断言的宏来检查值是否符合预期,主要分为两类:ASSERT 和 EXPECT。区别在于 ASSERT 不通过的时候会认为是一个 fatal 的错误,退出当前函数(只是函数)。而 EXPECT 失败的话会继续运行当前函数,所以对于函数内几个失败可以同时报告出来。通常我们用 EXPECT 级别的断言就好,除非你认为当前检查点失败后函数的后续检查没有意义。

基础的断言

Fatal assertion Nonfatal assertion Verifies
ASSERT_TRUE(condition ); EXPECT_TRUE(condition ); condition is true
ASSERT_FALSE(condition ); EXPECT_FALSE(condition ); condition is false

数值比较

Fatal assertion Nonfatal assertion Verifies
ASSERT_EQ(val1 , val2 ); EXPECT_EQ(val1 , val2 ); val1 == val2
ASSERT_NE(val1 , val2 ); EXPECT_NE(val1 , val2 ); val1 != val2
ASSERT_LT(val1 , val2 ); EXPECT_LT(val1 , val2 ); val1 < val2
ASSERT_LE(val1 , val2 ); EXPECT_LE(val1 , val2 ); val1 <= val2
ASSERT_GT(val1 , val2 ); EXPECT_GT(val1 , val2 ); val1 > val2
ASSERT_GE(val1 , val2 ); EXPECT_GE(val1 , val2 ); val1 >= val2

字符串比较

Fatal assertion Nonfatal assertion Verifies
ASSERT_STREQ(str1 , str2 ); EXPECT_STREQ(str1 , _str_2); the two C strings have the same content
ASSERT_STRNE(str1 , str2 ); EXPECT_STRNE(str1 , str2 ); the two C strings have different content
ASSERT_STRCASEEQ(str1 , str2 ); EXPECT_STRCASEEQ(str1 , str2 ); the two C strings have the same content, ignoring case
ASSERT_STRCASENE(str1 , str2 ); EXPECT_STRCASENE(str1 , str2 ); the two C strings have different content, ignoring case
相关推荐
武子康3 小时前
调查研究-186 LangChain 和 LangGraph 的区别:从快速构建 Agent 到生产级工作流编排
人工智能·langchain·llm
武子康3 小时前
调查研究-185 CodeGraph 调研:给 AI 编程 Agent 一张代码库地图,少一点反复 grep(2026)
人工智能·openai·claude
aqi004 小时前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
混沌福王5 小时前
Electron三端统一架构:运行时Adapter、IPC能力边界与分层设计
人工智能·agent·ai编程
说了很好5 小时前
马尔可夫扩散链+损失函数推导,手把手实现原生Diffusion
人工智能
聂二AI落地内参5 小时前
合同抽取别停在 JSON:标准规则和交易日历才是硬仗
人工智能
冬哥聊AI5 小时前
滴滴Agent岗二面:RAG 系统的 LLM 幻觉怎么治?从两类根源讲到四道防线
人工智能
lyshlc6 小时前
# AI Agent的推迟判定协议:不确定性下的最优策略
人工智能
用户329901675056 小时前
用zod在运行时兜住AI返回的JSON
人工智能