generated from coulomb/repo-seed
Record deferred reconciliation requests
This commit is contained in:
@@ -536,10 +536,19 @@ class TestReconciliationEndpoints:
|
||||
assert body["file_backed"] is False
|
||||
assert body["reconciliation_class"] == "deferred"
|
||||
assert body["write_through_result"] == "not_applicable"
|
||||
assert body["reconciliation_record_id"]
|
||||
|
||||
r = await client.get(f"/workstreams/{ws['id']}")
|
||||
assert r.json()["status"] == "active"
|
||||
|
||||
r = await client.get("/messages/?to_agent=state-hub&unread_only=true")
|
||||
assert r.status_code == 200
|
||||
messages = r.json()
|
||||
assert len(messages) == 1
|
||||
assert messages[0]["id"] == body["reconciliation_record_id"]
|
||||
assert "Reconcile workstream state change" in messages[0]["subject"]
|
||||
assert ws["id"] in messages[0]["body"]
|
||||
|
||||
async def test_apply_task_write_through_patches_task_block_then_db(self, client, tmp_path):
|
||||
await _create_domain(client)
|
||||
repo_root = tmp_path / "repo"
|
||||
@@ -587,3 +596,54 @@ class TestReconciliationEndpoints:
|
||||
|
||||
r = await client.get(f"/tasks/{task['id']}")
|
||||
assert r.json()["status"] == "in_progress"
|
||||
|
||||
async def test_apply_task_confirmation_case_creates_reconciliation_message(self, client, tmp_path):
|
||||
await _create_domain(client)
|
||||
repo_root = tmp_path / "repo"
|
||||
workplans = repo_root / "workplans"
|
||||
workplans.mkdir(parents=True)
|
||||
repo = await _create_repo(client, local_path=repo_root)
|
||||
topic = await _create_topic(client)
|
||||
ws = await _create_workstream(client, topic["id"], repo_id=repo["id"])
|
||||
task = await _create_task(client, ws["id"])
|
||||
wp = workplans / "STATE-WP-9999-demo.md"
|
||||
wp.write_text(
|
||||
"---\n"
|
||||
"id: STATE-WP-9999\n"
|
||||
"type: workplan\n"
|
||||
"title: Demo\n"
|
||||
"domain: custodian\n"
|
||||
"repo: state-hub\n"
|
||||
"status: active\n"
|
||||
f"state_hub_workstream_id: \"{ws['id']}\"\n"
|
||||
"---\n\n"
|
||||
"## Demo Task\n\n"
|
||||
"```task\n"
|
||||
"id: STATE-WP-9999-T01\n"
|
||||
"status: todo\n"
|
||||
"priority: high\n"
|
||||
f"state_hub_task_id: \"{task['id']}\"\n"
|
||||
"```\n",
|
||||
encoding="utf-8",
|
||||
)
|
||||
|
||||
r = await client.post("/reconciliation/state-change", json={
|
||||
"target_type": "task",
|
||||
"target_id": task["id"],
|
||||
"target_status": "blocked",
|
||||
"apply": True,
|
||||
})
|
||||
|
||||
assert r.status_code == 200, r.text
|
||||
body = r.json()
|
||||
assert body["reconciliation_class"] == "human_confirmation"
|
||||
assert body["write_through_result"] == "not_applicable"
|
||||
assert body["reconciliation_record_id"]
|
||||
|
||||
r = await client.get(f"/tasks/{task['id']}")
|
||||
assert r.json()["status"] == "todo"
|
||||
|
||||
r = await client.get("/messages/?to_agent=state-hub&unread_only=true")
|
||||
messages = r.json()
|
||||
assert len(messages) == 1
|
||||
assert "blocking reason" in messages[0]["body"]
|
||||
|
||||
Reference in New Issue
Block a user