mirror of
https://github.com/coder/coder.git
synced 2025-07-15 22:20:27 +00:00
fix(coderd): mark sub agent deletion via boolean instead of delete (#18411)
Deletion of data is uncommon in our database, so the introduction of sub agents and the deletion of them introduced issues with foreign key assumptions, as can be seen in coder/internal#685. We could have only addressed the specific case by allowing cascade deletion of stats as well as handling in the stats collector, but it's unclear how many more such edge-cases we could run into. In this change, we mark the rows as deleted via boolean instead, and filter them out in all relevant queries. Fixes coder/internal#685
This commit is contained in:
committed by
GitHub
parent
68f21fa523
commit
511fd09582
@ -4,6 +4,7 @@ import (
|
||||
"context"
|
||||
"database/sql"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
@ -243,6 +244,25 @@ func (b WorkspaceBuildBuilder) Do() WorkspaceResponse {
|
||||
require.NoError(b.t, err)
|
||||
}
|
||||
|
||||
agents, err := b.db.GetWorkspaceAgentsByWorkspaceAndBuildNumber(ownerCtx, database.GetWorkspaceAgentsByWorkspaceAndBuildNumberParams{
|
||||
WorkspaceID: resp.Workspace.ID,
|
||||
BuildNumber: resp.Build.BuildNumber,
|
||||
})
|
||||
if !errors.Is(err, sql.ErrNoRows) {
|
||||
require.NoError(b.t, err, "get workspace agents")
|
||||
// Insert deleted subagent test antagonists for the workspace build.
|
||||
// See also `dbgen.WorkspaceAgent()`.
|
||||
for _, agent := range agents {
|
||||
subAgent := dbgen.WorkspaceSubAgent(b.t, b.db, agent, database.WorkspaceAgent{
|
||||
TroubleshootingURL: "I AM A TEST ANTAGONIST AND I AM HERE TO MESS UP YOUR TESTS. IF YOU SEE ME, SOMETHING IS WRONG AND SUB AGENT DELETION MAY NOT BE HANDLED CORRECTLY IN A QUERY.",
|
||||
})
|
||||
err = b.db.DeleteWorkspaceSubAgentByID(ownerCtx, subAgent.ID)
|
||||
require.NoError(b.t, err, "delete workspace agent subagent antagonist")
|
||||
|
||||
b.t.Logf("inserted deleted subagent antagonist %s (%v) for workspace agent %s (%v)", subAgent.Name, subAgent.ID, agent.Name, agent.ID)
|
||||
}
|
||||
}
|
||||
|
||||
return resp
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user