feat: 添加 Operation 查询功能及完整测试
主要功能: - 新增 OperationQueryRequest/OperationQueryResult 结构体 - 实现 Repository.Query() - 支持多条件筛选、分页、排序 - 实现 Repository.Count() - 统计记录数 - 新增 PersistenceClient.QueryOperations/CountOperations/GetOperationByID 查询功能: - 支持按 OpID、OpSource、OpType、Doid 等字段筛选 - 支持模糊查询(Doid、DoPrefix) - 支持时间范围查询(TimeFrom/TimeTo) - 支持 IP 地址筛选(ClientIP、ServerIP) - 支持按 TrustlogStatus 筛选 - 支持组合查询 - 支持分页(PageSize、PageNumber) - 支持排序(OrderBy、OrderDesc) 测试覆盖: - ✅ query_test.go - 查询功能单元测试 - ✅ pg_query_integration_test.go - PostgreSQL 集成测试(16个测试用例) * Query all records * Filter by OpSource/OpType/Status/Actor/Producer/IP * DOID 模糊查询 * 时间范围查询 * 分页测试 * 排序测试(升序/降序) * 组合查询 * Count 统计 * PersistenceClient 接口测试 修复: - 修复 TestClusterSafety_MultipleCursorWorkers - 添加缺失字段 - 修复 TestCursorInitialization - 确保 schema 最新 - 添加自动 schema 更新(ALTER TABLE IF NOT EXISTS) 测试结果: - ✅ 所有单元测试通过(100%) - ✅ 所有集成测试通过(PostgreSQL、Pulsar、E2E) - ✅ Query 功能测试通过(16个测试用例)
This commit is contained in:
@@ -56,6 +56,12 @@ func TestClusterSafety_MultipleCursorWorkers(t *testing.T) {
|
||||
|
||||
t.Log("✅ PostgreSQL connected")
|
||||
|
||||
// 确保schema是最新的(添加可能缺失的列)
|
||||
_, _ = db.Exec("ALTER TABLE operation ADD COLUMN IF NOT EXISTS op_hash VARCHAR(128)")
|
||||
_, _ = db.Exec("ALTER TABLE operation ADD COLUMN IF NOT EXISTS sign VARCHAR(512)")
|
||||
_, _ = db.Exec("ALTER TABLE operation ADD COLUMN IF NOT EXISTS timestamp TIMESTAMP")
|
||||
_, _ = db.Exec("ALTER TABLE operation ADD COLUMN IF NOT EXISTS updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP")
|
||||
|
||||
// 创建测试数据:50 条未存证记录
|
||||
operationCount := 50
|
||||
timestamp := time.Now().Unix()
|
||||
@@ -63,12 +69,14 @@ func TestClusterSafety_MultipleCursorWorkers(t *testing.T) {
|
||||
opID := fmt.Sprintf("cluster-test-%d-%d", timestamp, i)
|
||||
_, err := db.Exec(`
|
||||
INSERT INTO operation (
|
||||
op_id, op_actor, doid, producer_id,
|
||||
op_id, op_actor, doid, producer_id,
|
||||
request_body_hash, response_body_hash, op_hash, sign,
|
||||
op_source, op_type, do_prefix, do_repository,
|
||||
trustlog_status, created_at
|
||||
) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, NOW())
|
||||
trustlog_status, timestamp, created_at
|
||||
) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14, NOW())
|
||||
`, opID, "cluster-tester", fmt.Sprintf("cluster/test/%d", i), "cluster-producer",
|
||||
"DOIP", "CREATE", "cluster-test", "cluster-repo", "NOT_TRUSTLOGGED")
|
||||
"req-hash", "resp-hash", "op-hash", "signature",
|
||||
"DOIP", "CREATE", "cluster-test", "cluster-repo", "NOT_TRUSTLOGGED", time.Now())
|
||||
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to create test data: %v", err)
|
||||
|
||||
Reference in New Issue
Block a user