From 511c6c2808eda10453d35ab1c8df4f3dfce29d87 Mon Sep 17 00:00:00 2001 From: lids <1713278948@qq.com> Date: Wed, 15 Apr 2026 17:55:34 +0800 Subject: [PATCH] =?UTF-8?q?AI=20=E8=87=AA=E5=8A=A8=E7=94=9F=E6=88=90?= =?UTF-8?q?=E6=B5=8B=E8=AF=95=E7=94=A8=E4=BE=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- tests/test_errors.cpp | 110 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 110 insertions(+) create mode 100644 tests/test_errors.cpp diff --git a/tests/test_errors.cpp b/tests/test_errors.cpp new file mode 100644 index 0000000..0adbdec --- /dev/null +++ b/tests/test_errors.cpp @@ -0,0 +1,110 @@ +#include "gtest/gtest.h" +#include "src/errors.cpp" +#include +#include +#include + +// 用于捕获信号的跳转点 +static jmp_buf env; + +// 信号处理函数 +void signal_handler(int sig) { + longjmp(env, 1); +} + +// 测试空指针解引用 +TEST(ErrorsTest, TestNullPointer) { + // 设置信号处理程序以捕获段错误 + struct sigaction sa; + struct sigaction old_sa; + + sa.sa_handler = signal_handler; + sigemptyset(&sa.sa_mask); + sa.sa_flags = 0; + + // 保存旧的信号处理程序 + sigaction(SIGSEGV, &sa, &old_sa); + + // 设置跳转点 + if (setjmp(env) == 0) { + // 尝试调用会触发段错误的函数 + test_null_pointer(); + // 如果执行到这里,说明没有触发段错误,测试失败 + FAIL() << "Expected segmentation fault from null pointer dereference"; + } else { + // 成功捕获到段错误,测试通过 + SUCCEED(); + } + + // 恢复旧的信号处理程序 + sigaction(SIGSEGV, &old_sa, nullptr); +} + +// 测试数组越界访问 +TEST(ErrorsTest, TestArrayOutOfBounds) { + // 设置信号处理程序以捕获段错误 + struct sigaction sa; + struct sigaction old_sa; + + sa.sa_handler = signal_handler; + sigemptyset(&sa.sa_mask); + sa.sa_flags = 0; + + // 保存旧的信号处理程序 + sigaction(SIGSEGV, &sa, &old_sa); + + // 设置跳转点 + if (setjmp(env) == 0) { + // 尝试调用会触发段错误的函数 + test_array_out_of_bounds(); + // 如果执行到这里,说明没有触发段错误,测试失败 + FAIL() << "Expected segmentation fault from array out of bounds access"; + } else { + // 成功捕获到段错误,测试通过 + SUCCEED(); + } + + // 恢复旧的信号处理程序 + sigaction(SIGSEGV, &old_sa, nullptr); +} + +// 测试未初始化变量使用 +TEST(ErrorsTest, TestUninitializedVar) { + // 未初始化变量的行为是未定义的,可能不会立即崩溃 + // 我们只能验证函数可以执行而不崩溃(尽管行为未定义) + // 注意:这是一个有问题的测试,因为行为未定义 + // 但在某些情况下,我们可能只想验证函数不会崩溃 + + // 设置信号处理程序以防万一 + struct sigaction sa; + struct sigaction old_sa; + + sa.sa_handler = signal_handler; + sigemptyset(&sa.sa_mask); + sa.sa_flags = 0; + + // 保存旧的信号处理程序 + sigaction(SIGSEGV, &sa, &old_sa); + + // 设置跳转点 + if (setjmp(env) == 0) { + // 尝试调用函数 + test_uninitialized_var(); + // 如果执行到这里,说明没有触发段错误 + // 对于未初始化变量,行为未定义,可能不会崩溃 + SUCCEED(); + } else { + // 如果意外捕获到段错误,也记录为通过 + // 因为未初始化变量的行为是未定义的 + SUCCEED(); + } + + // 恢复旧的信号处理程序 + sigaction(SIGSEGV, &old_sa, nullptr); +} + +// 主函数 +int main(int argc, char **argv) { + ::testing::InitGoogleTest(&argc, argv); + return RUN_ALL_TESTS(); +}