背景:我正在处理的代码库非常大,并且大量使用了断言。测试中发现的大量问题最终与单个断言(文件和行号)相关联。但是,如果有人修改了源代码,则与断言关联的行号可能会发生变化,并且在再次发生时将变得难以跟踪。
示例:在测试期间,假设测试人员在 main.cpp:1808 遇到了几个断言。针对此断言,我们的缺陷跟踪系统中记录了一个错误。第二天有人修改了 main.cpp。当测试人员重新执行他们的测试时,相同的断言仍然发生,但现在报告发生在 main.cpp:1790。因此,如果不查看源代码,很难确定这是一个新的断言还是先前看到的断言的再次出现。
问题: 是否可以将每个单独的 assert() 与一个唯一的 ID 相关联,这将在代码更改中持续存在,而不是依赖于行号?我自己想不出解决办法。我希望比我聪明的人会有一些想法。以下是我认为解决方案的行为方式:
#include <iostream>
#include <string>
#include <assert.h>
using namespace std;
//Can ASSERT to redefined to generate a UID?
#define ASSERT assert
void main(void)
{
std::string name;
int age;
std::cin >> name;
ASSERT(name.length() < 10); //Generate a UID if assert fails(ie 0001)
std::cin >> age;
ASSERT(age < 100); //Generate a UID if assert fails(ie 0002)
}
一些代码更改后
#include <iostream>
#include <string>
#include <assert.h>
using namespace std;
#define ASSERT assert
void main(void)
{
std::string name;
int age;
int height;
std::cin >> height;
ASSERT(height < 10); //Generate a UID if assert fails(ie 0003)
std::cin >> name;
ASSERT(name.length() < 10); //Generate a UID if assert fails(ie 0001)
std::cin >> age;
ASSERT(age < 100); //Generate a UID if assert fails(ie 0002)
}