添加测试用例

This commit is contained in:
2026-01-16 15:51:23 +08:00
parent 704058485c
commit 90acfb340c
10 changed files with 753 additions and 125 deletions

64
bash/unit_test.sh Normal file
View File

@@ -0,0 +1,64 @@
#!/bin/bash
# Termux专属 测试用例启动脚本
# 功能:编译代码 + 运行ConsoleCmdAutoTest测试类 + 输出测试日志 + 终端环境重置
cd "$(dirname "${BASH_SOURCE[0]}")" || { echo "❌ 目录切换失败"; exit 1; }
BASE_DIR=$(cd .. && pwd)
# ========== 配置项 ==========
# 测试类全限定名
TEST_MAIN_CLASS="cc.winboll.test.ConsoleCmdAutoTest"
# 日志输出路径(与测试类中配置的日志目录一致)
TEST_LOG_DIR="$BASE_DIR/logs"
TEST_LOG_FILE="$TEST_LOG_DIR/test_run.log"
# JVM 内存配置适配Termux低内存环境
JAVA_OPTS="-Xmx128m -Xms64m"
# 编译脚本路径
BUILD_SH="$BASE_DIR/bash/build_class.sh"
# ========== 前置检查 ==========
# 创建日志目录
if [ ! -d "$TEST_LOG_DIR" ]; then
mkdir -p "$TEST_LOG_DIR" || { echo "❌ 日志目录创建失败: $TEST_LOG_DIR"; exit 1; }
fi
# ========== 编译代码 ==========
echo "📦 开始编译项目代码..."
bash "$BUILD_SH" || { echo "❌ 项目编译失败,退出测试"; exit 1; }
echo "✅ 项目编译成功"
# ========== 配置类路径 ==========
CLASSPATH="$BASE_DIR/runtime"
if [ -d "$BASE_DIR/libs" ]; then
CLASSPATH="$CLASSPATH:$BASE_DIR/libs/*"
fi
# ========== 信号捕获(异常终止处理) ==========
STOP_SIGNAL=0
on_exit() {
STOP_SIGNAL=1
echo -e "\n⚠ 测试进程异常终止!查看日志: $TEST_LOG_FILE"
stty sane
exit 1
}
trap 'on_exit' SIGABRT SIGSEGV SIGILL SIGTERM
# ========== 启动测试用例 ==========
echo -e "\n🚀 启动测试用例: $TEST_MAIN_CLASS"
echo -e "📜 测试日志将输出到: $TEST_LOG_FILE"
echo -e "=====================================\n"
# 屏蔽^C视觉印记 + 执行测试类 + 日志重定向
stty -echoctl
java $JAVA_OPTS -cp "$CLASSPATH" "$TEST_MAIN_CLASS" -v -log:ALL &> "$TEST_LOG_FILE"
# ========== 测试结束处理 ==========
if [ $STOP_SIGNAL -eq 0 ]; then
echo -e "\n====================================="
echo "✅ 测试用例执行完成!"
echo "📊 测试报告路径: $BASE_DIR/test-report.txt"
echo "📜 详细日志路径: $TEST_LOG_FILE"
fi
# 重置终端属性,避免残留问题
stty sane
exit $?