Fix CI regressions and stabilize tests
This commit is contained in:
@@ -19,26 +19,26 @@ var expectedSchema = map[string][]string{
|
||||
"created_at", "updated_at", "closed_at", "content_hash", "external_ref",
|
||||
"compaction_level", "compacted_at", "compacted_at_commit", "original_size",
|
||||
},
|
||||
"dependencies": {"issue_id", "depends_on_id", "type", "created_at", "created_by"},
|
||||
"labels": {"issue_id", "label"},
|
||||
"comments": {"id", "issue_id", "author", "text", "created_at"},
|
||||
"events": {"id", "issue_id", "event_type", "actor", "old_value", "new_value", "comment", "created_at"},
|
||||
"config": {"key", "value"},
|
||||
"metadata": {"key", "value"},
|
||||
"dirty_issues": {"issue_id", "marked_at"},
|
||||
"export_hashes": {"issue_id", "content_hash", "exported_at"},
|
||||
"child_counters": {"parent_id", "last_child"},
|
||||
"issue_snapshots": {"id", "issue_id", "snapshot_time", "compaction_level", "original_size", "compressed_size", "original_content", "archived_events"},
|
||||
"dependencies": {"issue_id", "depends_on_id", "type", "created_at", "created_by"},
|
||||
"labels": {"issue_id", "label"},
|
||||
"comments": {"id", "issue_id", "author", "text", "created_at"},
|
||||
"events": {"id", "issue_id", "event_type", "actor", "old_value", "new_value", "comment", "created_at"},
|
||||
"config": {"key", "value"},
|
||||
"metadata": {"key", "value"},
|
||||
"dirty_issues": {"issue_id", "marked_at"},
|
||||
"export_hashes": {"issue_id", "content_hash", "exported_at"},
|
||||
"child_counters": {"parent_id", "last_child"},
|
||||
"issue_snapshots": {"id", "issue_id", "snapshot_time", "compaction_level", "original_size", "compressed_size", "original_content", "archived_events"},
|
||||
"compaction_snapshots": {"id", "issue_id", "compaction_level", "snapshot_json", "created_at"},
|
||||
"repo_mtimes": {"repo_path", "jsonl_path", "mtime_ns", "last_checked"},
|
||||
"repo_mtimes": {"repo_path", "jsonl_path", "mtime_ns", "last_checked"},
|
||||
}
|
||||
|
||||
// SchemaProbeResult contains the results of a schema compatibility check
|
||||
type SchemaProbeResult struct {
|
||||
Compatible bool
|
||||
MissingTables []string
|
||||
MissingColumns map[string][]string // table -> missing columns
|
||||
ErrorMessage string
|
||||
Compatible bool
|
||||
MissingTables []string
|
||||
MissingColumns map[string][]string // table -> missing columns
|
||||
ErrorMessage string
|
||||
}
|
||||
|
||||
// probeSchema verifies all expected tables and columns exist
|
||||
@@ -52,19 +52,19 @@ func probeSchema(db *sql.DB) SchemaProbeResult {
|
||||
|
||||
for table, expectedCols := range expectedSchema {
|
||||
// Try to query the table with all expected columns
|
||||
query := fmt.Sprintf("SELECT %s FROM %s LIMIT 0", strings.Join(expectedCols, ", "), table)
|
||||
query := fmt.Sprintf("SELECT %s FROM %s LIMIT 0", strings.Join(expectedCols, ", "), table) // #nosec G201 -- table/column names sourced from hardcoded schema
|
||||
_, err := db.Exec(query)
|
||||
|
||||
|
||||
if err != nil {
|
||||
errMsg := err.Error()
|
||||
|
||||
|
||||
// Check if table doesn't exist
|
||||
if strings.Contains(errMsg, "no such table") {
|
||||
result.Compatible = false
|
||||
result.MissingTables = append(result.MissingTables, table)
|
||||
continue
|
||||
}
|
||||
|
||||
|
||||
// Check if column doesn't exist
|
||||
if strings.Contains(errMsg, "no such column") {
|
||||
result.Compatible = false
|
||||
@@ -97,25 +97,25 @@ func probeSchema(db *sql.DB) SchemaProbeResult {
|
||||
// findMissingColumns determines which columns are missing from a table
|
||||
func findMissingColumns(db *sql.DB, table string, expectedCols []string) []string {
|
||||
missing := []string{}
|
||||
|
||||
|
||||
for _, col := range expectedCols {
|
||||
query := fmt.Sprintf("SELECT %s FROM %s LIMIT 0", col, table)
|
||||
query := fmt.Sprintf("SELECT %s FROM %s LIMIT 0", col, table) // #nosec G201 -- table/column names sourced from hardcoded schema
|
||||
_, err := db.Exec(query)
|
||||
if err != nil && strings.Contains(err.Error(), "no such column") {
|
||||
missing = append(missing, col)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return missing
|
||||
}
|
||||
|
||||
// verifySchemaCompatibility runs schema probe and returns detailed error on failure
|
||||
func verifySchemaCompatibility(db *sql.DB) error {
|
||||
result := probeSchema(db)
|
||||
|
||||
|
||||
if !result.Compatible {
|
||||
return fmt.Errorf("%w: %s", ErrSchemaIncompatible, result.ErrorMessage)
|
||||
}
|
||||
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user