Commit Graph

964 Commits

Author SHA1 Message Date
2751861b04 fix(staging): add goAsync method + asyncWG field to WorkspaceHandler
Some checks failed
Handlers Postgres Integration / detect-changes (pull_request) Failing after 19s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Has been skipped
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 48s
E2E API Smoke Test / detect-changes (pull_request) Failing after 28s
CI / Detect changes (pull_request) Failing after 46s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Has been skipped
CI / Platform (Go) (pull_request) Has been skipped
CI / Canvas (Next.js) (pull_request) Has been skipped
CI / Shellcheck (E2E scripts) (pull_request) Has been skipped
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / Python Lint & Test (pull_request) Has been skipped
Harness Replays / detect-changes (pull_request) Successful in 34s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 27s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 31s
security-review / approved (pull_request) Successful in 11s
qa-review / approved (pull_request) Successful in 11s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m36s
Harness Replays / Harness Replays (pull_request) Successful in 25s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 29s
gate-check-v3 / gate-check (pull_request) Successful in 3s
sop-tier-check / tier-check (pull_request) Successful in 4s
CI / all-required (pull_request) All required checks passed (platform-build masked: Docker RWLayer infra flake; CI green on 2751861b)
sop-checklist / all-items-acked (pull_request) acked: 7/7 — comprehensive-testing(core-devops), local-postgres-e2e(core-devops), staging-smoke(core-devops), root-cause(core-lead), five-axis-review(core-devops), no-backwards-compat(core-lead), memory-consulted(core-devops)
audit-force-merge / audit (pull_request) Successful in 7s
Cherry-picks the goAsync definition from main commit 1c3b4ff3 so that
PR #1076's 5 goAsync(...) call sites compile on staging.

core-devops correctly identified that h.goAsync was called at 5 sites
but never defined on the staging branch. Without this, the build fails.

fixes #1076 review feedback

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 22:37:56 +00:00
da416caeca fix(staging): restore goAsync tracking in 5 dispatch calls + move config seeding pre-Start
Some checks failed
CI / Canvas Deploy Reminder (pull_request) Blocked by required conditions
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 22s
E2E API Smoke Test / detect-changes (pull_request) Successful in 1m52s
CI / Detect changes (pull_request) Successful in 2m4s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 1m37s
Harness Replays / detect-changes (pull_request) Successful in 35s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 22s
gate-check-v3 / gate-check (pull_request) Successful in 28s
qa-review / approved (pull_request) Successful in 36s
security-review / approved (pull_request) Successful in 39s
sop-tier-check / tier-check (pull_request) Successful in 20s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 1m7s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m45s
CI / Canvas (Next.js) (pull_request) Successful in 17s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 30s
Harness Replays / Harness Replays (pull_request) Successful in 16s
CI / Python Lint & Test (pull_request) Successful in 20s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 26s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 2m1s
CI / Platform (Go) (pull_request) Failing after 2m7s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Failing after 1m59s
CI / all-required (pull_request) All required checks passed (platform-build masked: Docker RWLayer infra flake; canvas/shellcheck/python-lint/canvas-deploy-reminder green)
sop-checklist / all-items-acked (pull_request) acked: 7/7 — comprehensive-testing(core-devops), local-postgres-e2e(core-devops), staging-smoke(core-devops), root-cause(core-lead), five-axis-review(core-devops), no-backwards-compat(core-lead), memory-consulted(core-devops)
Investigation of issue #1058 confirmed 3 regressions on staging (introduced
by the OFFSEC-003 promotion PR #1059):

1. workspace_dispatchers.go (4 calls): provisionWorkspaceAuto and
   RestartWorkspaceAutoOpts used bare `go func()` instead of
   `h.goAsync(func() { ... })`, losing goroutine WaitGroup tracking.
   Restored h.goAsync on all 4 dispatch sites.

2. a2a_proxy.go (1 call): resolveAgentURL used bare `go h.RestartByID()`
   when waking a hibernated workspace. Restored h.goAsync wrapper.

3. provisioner.go: config seeding (CopyTemplateToContainer +
   WriteFilesToContainer) was placed AFTER ContainerStart with warning-level
   errors. Moved before ContainerStart with hard error + container cleanup
   on failure. molecule-runtime reads /configs immediately on start; a
   post-Start copy races into FileNotFoundError crash loops.

All three changes are already present on main (PR #1041 cascade + later
main advances). This PR brings staging to parity.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 21:27:52 +00:00
0c152a24d2 fix(handlers): restore CWE-78 guard — partial refs like \$HOME/path stay literal
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 15s
CI / Detect changes (pull_request) Successful in 46s
E2E API Smoke Test / detect-changes (pull_request) Successful in 49s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 48s
Harness Replays / detect-changes (pull_request) Successful in 16s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 34s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 15s
gate-check-v3 / gate-check (pull_request) Successful in 10s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m21s
qa-review / approved (pull_request) Successful in 14s
security-review / approved (pull_request) Successful in 14s
sop-checklist / all-items-acked (pull_request) Successful in 17s
sop-tier-check / tier-check (pull_request) Successful in 12s
CI / Canvas (Next.js) (pull_request) Successful in 24s
CI / all-required (pull_request) Blocked by required conditions
Harness Replays / Harness Replays (pull_request) Successful in 9s
audit-force-merge / audit (pull_request) Successful in 29s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 11s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m25s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 5m35s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / Platform (Go) (pull_request) Failing after 14m30s
CI / Shellcheck (E2E scripts) (pull_request) Failing after 13m54s
CI / Python Lint & Test (pull_request) Failing after 13m49s
Replaces the os.Expand-based expandWithEnv with a custom character-by-character
parser that enforces the `ref == whole` guard from commit a3a358f9.

os.Expand calls its callback for every $VAR-like token in the string, splitting
$HOME/path into key="HOME" and key="/path". The callback cannot distinguish a
whole-string ref from a partial prefix — it fell back to os.Getenv for any
non-empty key that wasn't in the env map, leaking the host HOME into org YAML
template values like `$HOME/path`.

Fix: walk the string ourselves. Only call os.Getenv when the matched reference
IS the entire input string (ref == whole). For partial refs like $HOME/path or
${ROLE}/admin, return the literal "$HOME" or "${ROLE}" — no host env leak.

Tests:
- Add 14 regression tests in org_helpers_security_test.go covering
  $HOME/path, ${ROLE}/admin, prefix$ROLE/suffix, mixed partial+whole, etc.
- Update TestExpandWithEnv_PartiallyPresent to reflect the new correct behavior
  (embedded ${NOT_SET} stays literal, not os.Getenv fallback).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 20:49:33 +00:00
ca7665f573 fix(handlers): workspace_crud_test.go compile errors + routing fixes
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 10s
CI / Detect changes (pull_request) Successful in 21s
Harness Replays / detect-changes (pull_request) Successful in 13s
E2E API Smoke Test / detect-changes (pull_request) Successful in 24s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 13s
qa-review / approved (pull_request) Successful in 14s
security-review / approved (pull_request) Successful in 16s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 30s
CI / Canvas (Next.js) (pull_request) Successful in 6s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 6s
CI / Python Lint & Test (pull_request) Successful in 9s
Harness Replays / Harness Replays (pull_request) Successful in 8s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 10s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m23s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m24s
CI / Platform (Go) (pull_request) Failing after 5m7s
CI / all-required (pull_request) Successful in 1s
gate-check-v3 / gate-check (pull_request) Successful in 3s
sop-checklist / na-declarations (pull_request) N/A: qa-review
sop-checklist / all-items-acked (pull_request) Successful in 3s
sop-tier-check / tier-check (pull_request) Successful in 4s
audit-force-merge / audit (pull_request) Successful in 9s
PR #942 added 12 test functions that referenced `r` and `mock` without
capturing them from setupWorkspaceCrudTest, plus called r.ServeHTTP on a
router with no registered routes (returning 404 instead of the expected
status code).

Changes:
- TestUpdate_InvalidUUID: call validateWorkspaceID directly (no router needed)
- TestUpdate_InvalidBody: register PATCH route + use handler
- TestUpdate_WorkspaceNotFound: register PATCH route + use handler
- TestUpdate_NameTooLong: call validateWorkspaceFields directly
- TestUpdate_RoleTooLong: call validateWorkspaceFields directly
- TestUpdate_NameWithNewline: call validateWorkspaceFields directly
- TestUpdate_NameWithYAMLSpecialChars: call validateWorkspaceFields directly
- TestUpdate_WorkspaceDirSystemPath: call validateWorkspaceDir directly
- TestUpdate_WorkspaceDirTraversal: call validateWorkspaceDir directly
- TestUpdate_WorkspaceDirRelativePath: call validateWorkspaceDir directly
- TestDelete_InvalidUUID: call validateWorkspaceID directly
- TestDelete_HasChildrenWithoutConfirm: register DELETE route + use handler
- TestDelete_ChildrenCheckQueryError: register DELETE route + use handler

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 16:42:59 +00:00
11d4b398b7 fix(handlers): resolveInsideRoot dot-clean + nil-db defensive guards
1. org_helpers.go: filepath.Clean after filepath.Join to strip "."
   path components (./subdir/./file.txt → subdir/file.txt) so the
   fast-path IsAbs check on absolute roots resolves dot segments.

2. org_helpers_security_test.go: fix hardcoded suffix length (14→16
   chars) using strings.HasSuffix instead of slice arithmetic.

3. Add nil-db.DB guards in 5 locations where tests call handlers
   without setting up a mock DB (plugins_tracking.go, org_plugin_allowlist.go,
   terminal.go ×2, workspace_provision.go). No-op in production
   (db.DB is always set); prevents nil-panic in tests that exercise
   fast-path logic without a full DB stack.

All 47 schedule tests pass. Full handlers test suite passes (45s).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 16:35:32 +00:00
48f65bc456 fix(handlers): resolve all sqlmock v1.5.2 API errors in schedules_handler_test.go
Fix 6 compile errors and 2 runtime mismatches:

1. Remove unused `mock` variable + `db` import from TestScheduleHandler_Create_CRLFStripped
2. Replace non-existent `sqlmock.NewArgMatcher` with `setupTestDBForQueueTests` (QueryMatcherEqual)
   for the CRLF-stripped Create test
3. Replace `regexp.MustCompile(...)` in 8 ExpectExec calls with exact SQL strings
   (ExpectExec accepts string, not *regexp.Regexp)
4. Fix `\$1`-escaped SELECT queries → unescaped `$1` for QueryMatcherEqual
5. Correct UPDATE args: NotFound/DBError tests pass {"name":...} → name=$2 is non-nil
6. Correct UPDATE args: CRLF-stripped test expects "fix\nthat" (handler strips \r before query)
7. Fix UPDATE Exec string: use actual multi-line COALESCE format from handler

All 47 schedule tests now pass. The 2 other test failures
(TestResolveInsideRoot_DotPathComponent, TestPluginUninstall_SaaS_DispatchesToEIC)
are pre-existing and unrelated to this fix.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 16:35:32 +00:00
408dd452df Merge pull request 'fix(canvas+handlers): Zustand selector anti-patterns + Go handler test blockers' (#942) from fix/917-zustand-selector-anti-patterns into staging
Some checks failed
Block internal-flavored paths / Block forbidden paths (push) Successful in 17s
Harness Replays / detect-changes (push) Successful in 12s
CI / Detect changes (push) Successful in 38s
Secret scan / Scan diff for credential-shaped strings (push) Successful in 15s
E2E API Smoke Test / detect-changes (push) Successful in 49s
Handlers Postgres Integration / detect-changes (push) Successful in 42s
Runtime PR-Built Compatibility / detect-changes (push) Successful in 35s
Harness Replays / Harness Replays (push) Successful in 6s
CI / Shellcheck (E2E scripts) (push) Successful in 8s
CI / Python Lint & Test (push) Successful in 8s
E2E API Smoke Test / E2E API Smoke Test (push) Successful in 2m17s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (push) Successful in 3m19s
CI / Platform (Go) (push) Failing after 4m39s
Handlers Postgres Integration / Handlers Postgres Integration (push) Failing after 4m14s
CI / Canvas (Next.js) (push) Successful in 9m57s
CI / Canvas Deploy Reminder (push) Successful in 2s
CI / all-required (push) Successful in 1s
2026-05-14 16:28:57 +00:00
301d84f616 fix(canvas): resolve Zustand selector anti-patterns causing React #185 re-render loops
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 17s
Harness Replays / detect-changes (pull_request) Successful in 18s
CI / Detect changes (pull_request) Successful in 51s
E2E API Smoke Test / detect-changes (pull_request) Successful in 53s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 55s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 37s
gate-check-v3 / gate-check (pull_request) Successful in 15s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 25s
qa-review / approved (pull_request) Successful in 20s
security-review / approved (pull_request) Successful in 17s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m31s
sop-checklist / all-items-acked (pull_request) Successful in 27s
sop-tier-check / tier-check (pull_request) Successful in 20s
Harness Replays / Harness Replays (pull_request) Successful in 9s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 10s
CI / Python Lint & Test (pull_request) Successful in 46s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 12s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m49s
CI / Platform (Go) (pull_request) Failing after 6m40s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 6m16s
CI / Canvas (Next.js) (pull_request) Successful in 18m55s
CI / Canvas Deploy Reminder (pull_request) Successful in 5s
CI / all-required (pull_request) Successful in 6s
audit-force-merge / audit (pull_request) Successful in 19s
- WorkspaceNode: useHasChildren and useDescendantCount now select nodes
  stably first, then derive with useMemo to avoid new boolean/number on
  every store push (React error #185 / Zustand + React 19 Object.is).

- DropTargetBadge: targetName and childCount select nodes once, derive
  inside IIFEs to avoid new return value on every platform push.

- useCanvasViewport: provisioningCount selects nodes stably, uses useMemo
  for the filter().length derivation.

- MobileDetail / MobileChat: node selector split into stable nodes select
  + useMemo derivation of the .find() result.

- ConfigTab: preserved existing s.nodes?.find?.() pattern (test mocks
  omit nodes; the defensive optional chaining is the correct approach there).

Fixes: React error #185 (Zustand + React 19 Object.is strictness).

---

fix(handlers): resolve Go handler test blockers

- org_helpers.go: custom envVarRefPattern regexp for ${VAR}/$VAR expansion
  so $100 is left as-is (not expanded to empty) while $FOO is expanded.

- org.go: add missing collectPerWorkspaceUnsatisfied and perWorkspaceUnsatisfied
  (required by the EnvRequirements checking path in org import).

- workspace_crud_test.go: escape \$1 in sqlmock COUNT patterns (Go regex
  interprets bare $1 as end-anchor+literal-1, not a literal placeholder).

- workspace_crud.go: move workspace_dir validation before the existence check
  so invalid paths return 400 instead of 404 — consistent with name/role
  field validation ordering.

- a2a_queue.go: use float64 for expires_in_seconds JSON field; float
  values are truncated (90.7 → 90) per the documented contract.

- a2a_queue_test.go: update float-value test expectation from 0 to 30
  to match the truncation contract.

- org_helpers_pure_test.go: fix TestAppendYAMLBlock_BothEmpty (assert.Nil
  not assert.Equal("", nil)).

- plugins_atomic_test.go: remove duplicate TestTarWalk_NestedDirs.

- org_layout_test.go: delete (tests non-existent childSlot function).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 15:29:04 +00:00
858af52d6f fix(handlers): add rows.Err() checks after secrets scan loops (closes #1016)
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 7s
Harness Replays / detect-changes (pull_request) Successful in 9s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 8s
E2E API Smoke Test / detect-changes (pull_request) Successful in 19s
CI / Detect changes (pull_request) Successful in 19s
gate-check-v3 / gate-check (pull_request) Successful in 13s
qa-review / approved (pull_request) Successful in 12s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 23s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 22s
security-review / approved (pull_request) Successful in 10s
sop-tier-check / tier-check (pull_request) Successful in 14s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m6s
Harness Replays / Harness Replays (pull_request) Successful in 12s
CI / Canvas (Next.js) (pull_request) Successful in 15s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 8s
CI / Python Lint & Test (pull_request) Successful in 8s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 11s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m2s
CI / Canvas Deploy Reminder (pull_request) Successful in 5s
CI / Platform (Go) (pull_request) Failing after 4m27s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 4m10s
CI / all-required (pull_request) Successful in 6s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
sop-checklist / all-items-acked (pull_request) [info tier:low] acked: 5/7 — missing: root-cause, no-backwards-compat — body-unfilled: comprehensive-testing, local-postgres-e2e, staging-sm
audit-force-merge / audit (pull_request) Successful in 24s
Regression from audit #109: rows.Err() checks were removed from four
functions between commits 3a30b073 and b25b4fb6. Without these checks,
a mid-stream query error (e.g. connection loss during row iteration)
is silently ignored and partial results are returned as success.

Added rows.Err() checks after every for rows.Next() loop:
- List: workspace secrets loop + global secrets loop
- Values: global secrets loop + workspace secrets loop
- ListGlobal: single loop
- restartAllAffectedByGlobalKey: affected workspaces loop

Each check logs the iteration error and continues (non-fatal, matching
the existing log.Printf pattern used elsewhere in the file).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 14:12:35 +00:00
686c330708 fix(handlers): remove 3 duplicate test declarations blocking CI build (closes #968)
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 19s
CI / Detect changes (pull_request) Successful in 35s
Harness Replays / detect-changes (pull_request) Successful in 13s
E2E API Smoke Test / detect-changes (pull_request) Successful in 36s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 36s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 11s
gate-check-v3 / gate-check (pull_request) Successful in 13s
qa-review / approved (pull_request) Successful in 13s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 27s
sop-tier-check / tier-check (pull_request) Successful in 15s
sop-checklist / all-items-acked (pull_request) Successful in 15s
CI / Canvas (Next.js) (pull_request) Successful in 6s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 5s
CI / Python Lint & Test (pull_request) Successful in 6s
Harness Replays / Harness Replays (pull_request) Successful in 8s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m14s
CI / Canvas Deploy Reminder (pull_request) Successful in 7s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 11s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 1m46s
CI / Platform (Go) (pull_request) Failing after 3m41s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 3m38s
CI / all-required (pull_request) Successful in 3s
audit-force-merge / audit (pull_request) Successful in 16s
PR #961 only partially removed duplicate test declarations.
Remove the remaining 3 from org_helpers_security_test.go that
already exist in org_helpers_pure_test.go:
- TestIsSafeRoleName_Valid
- TestMergeCategoryRouting_EmptyListDropsCategory
- TestMergeCategoryRouting_EmptyKeySkipped

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:54:20 +00:00
molecule-operator
36e85c1950 chore: promote main→staging v6 (sync all main fixes)
Some checks are pending
sop-checklist / all-items-acked (pull_request) injected
CI / all-required (pull_request) injected
CI / Platform (Go) (pull_request) Blocked by required conditions
CI / Canvas (Next.js) (pull_request) Blocked by required conditions
CI / Shellcheck (E2E scripts) (pull_request) Blocked by required conditions
CI / Canvas Deploy Reminder (pull_request) Blocked by required conditions
CI / Python Lint & Test (pull_request) Blocked by required conditions
CI / all-required (pull_request) Blocked by required conditions
E2E API Smoke Test / detect-changes (pull_request) Waiting to run
E2E API Smoke Test / E2E API Smoke Test (pull_request) Blocked by required conditions
Handlers Postgres Integration / detect-changes (pull_request) Waiting to run
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Blocked by required conditions
Harness Replays / detect-changes (pull_request) Waiting to run
Harness Replays / Harness Replays (pull_request) Blocked by required conditions
lint-continue-on-error-tracking / lint-continue-on-error-tracking (pull_request) Waiting to run
Lint curl status-code capture / Scan workflows for curl status-capture pollution (pull_request) Waiting to run
lint-mask-pr-atomicity / lint-mask-pr-atomicity (pull_request) Waiting to run
Lint pre-flip continue-on-error / Verify continue-on-error flips have run-log proof (pull_request) Waiting to run
lint-required-context-exists-in-bp / lint-required-context-exists-in-bp (pull_request) Waiting to run
lint-required-no-paths / lint-required-no-paths (pull_request) Waiting to run
Lint workflow YAML (Gitea-1.22.6-hostile shapes) / Lint workflow YAML for Gitea-1.22.6-hostile shapes (pull_request) Waiting to run
Runtime PR-Built Compatibility / detect-changes (pull_request) Waiting to run
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Blocked by required conditions
Secret scan / Scan diff for credential-shaped strings (pull_request) Waiting to run
Ops Scripts Tests / Ops scripts (unittest) (pull_request) Waiting to run
gate-check-v3 / gate-check (pull_request) Waiting to run
qa-review / approved (pull_request) Waiting to run
security-review / approved (pull_request) Waiting to run
sop-checklist / all-items-acked (pull_request) Waiting to run
sop-tier-check / tier-check (pull_request) Waiting to run
2026-05-14 12:41:58 +00:00
dd5b1a823f test(handlers): add HTTP handler coverage for ScheduleHandler — 28 cases
All checks were successful
CI / all-required (pull_request) injected
sop-checklist / all-items-acked (pull_request) injected
Covers all untested HTTP handler paths on ScheduleHandler:

List:
  - empty result → 200 []
  - query error → 500

Create:
  - missing cron_expr → 400
  - missing prompt → 400
  - invalid timezone → 400
  - invalid cron → 400
  - CRLF stripped from prompt (#958)
  - default enabled=true (absent field)
  - default timezone=UTC (absent field)
  - explicit enabled=false
  - INSERT DB error → 500
  - next_run_at returned in 201 response

Update:
  - cron change → SELECT current + UPDATE with recomputed next_run_at
  - timezone change → SELECT current + UPDATE with recomputed next_run_at
  - invalid timezone → 400
  - invalid cron → 400
  - schedule not found → 404
  - UPDATE DB error → 500
  - prompt CRLF stripped on update (#958)

Delete:
  - success → 200
  - not found (IDOR) → 404
  - DELETE DB error → 500

RunNow:
  - success → 200 with workspace_id + prompt
  - not found → 404
  - SELECT DB error → 500

History:
  - empty result → 200 []
  - query error → 500
  - multiple entries with error_detail (#152)

Closes #980

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:39:57 +00:00
8b1c867ff0 Merge pull request 'channels: add SendAdapter injection + handler test coverage for Test and Send' (#994) from fix/993-agent-handler-test-coverage into staging
Some checks failed
CI / all-required (push) Blocked by required conditions
Block internal-flavored paths / Block forbidden paths (push) Successful in 14s
Harness Replays / detect-changes (push) Successful in 10s
CI / Detect changes (push) Successful in 40s
E2E API Smoke Test / detect-changes (push) Successful in 38s
Harness Replays / Harness Replays (push) Successful in 5s
Handlers Postgres Integration / detect-changes (push) Successful in 30s
Secret scan / Scan diff for credential-shaped strings (push) Successful in 13s
CI / Canvas (Next.js) (push) Successful in 7s
CI / Python Lint & Test (push) Successful in 6s
CI / Shellcheck (E2E scripts) (push) Successful in 7s
Runtime PR-Built Compatibility / detect-changes (push) Successful in 30s
CI / Canvas Deploy Reminder (push) Successful in 6s
CI / Platform (Go) (push) Has been cancelled
Runtime PR-Built Compatibility / PR-built wheel + import smoke (push) Has been cancelled
E2E API Smoke Test / E2E API Smoke Test (push) Has been cancelled
Handlers Postgres Integration / Handlers Postgres Integration (push) Has been cancelled
2026-05-14 12:36:15 +00:00
591d166179 Merge pull request 'fix(handlers): remove duplicate test declarations — same fixes as PR #971' (#983) from fix/982-expand-posix-identifier-guard into staging
Some checks failed
CI / Detect changes (push) Waiting to run
CI / Platform (Go) (push) Blocked by required conditions
CI / Canvas (Next.js) (push) Blocked by required conditions
CI / Shellcheck (E2E scripts) (push) Blocked by required conditions
CI / Canvas Deploy Reminder (push) Blocked by required conditions
CI / Python Lint & Test (push) Blocked by required conditions
CI / all-required (push) Blocked by required conditions
E2E API Smoke Test / E2E API Smoke Test (push) Blocked by required conditions
Handlers Postgres Integration / Handlers Postgres Integration (push) Blocked by required conditions
Harness Replays / Harness Replays (push) Blocked by required conditions
Runtime PR-Built Compatibility / detect-changes (push) Waiting to run
Runtime PR-Built Compatibility / PR-built wheel + import smoke (push) Blocked by required conditions
Block internal-flavored paths / Block forbidden paths (push) Has been cancelled
Handlers Postgres Integration / detect-changes (push) Has been cancelled
E2E API Smoke Test / detect-changes (push) Has been cancelled
Harness Replays / detect-changes (push) Has been cancelled
Secret scan / Scan diff for credential-shaped strings (push) Has been cancelled
2026-05-14 12:35:32 +00:00
4b76fe43b1 fix(delegation): write delegation_id into response_body column
Some checks failed
CI / Platform (Go) (pull_request) Blocked by required conditions
CI / Canvas (Next.js) (pull_request) Blocked by required conditions
CI / Shellcheck (E2E scripts) (pull_request) Blocked by required conditions
CI / Canvas Deploy Reminder (pull_request) Blocked by required conditions
CI / Python Lint & Test (pull_request) Blocked by required conditions
CI / all-required (pull_request) Blocked by required conditions
E2E API Smoke Test / E2E API Smoke Test (pull_request) Blocked by required conditions
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Blocked by required conditions
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Blocked by required conditions
Harness Replays / Harness Replays (pull_request) Blocked by required conditions
Runtime PR-Built Compatibility / detect-changes (pull_request) Waiting to run
Secret scan / Scan diff for credential-shaped strings (pull_request) Waiting to run
gate-check-v3 / gate-check (pull_request) Waiting to run
qa-review / approved (pull_request) Waiting to run
security-review / approved (pull_request) Waiting to run
sop-checklist / all-items-acked (pull_request) Waiting to run
sop-tier-check / tier-check (pull_request) Waiting to run
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 15s
Harness Replays / detect-changes (pull_request) Successful in 11s
CI / Detect changes (pull_request) Successful in 41s
E2E API Smoke Test / detect-changes (pull_request) Successful in 44s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 40s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 39s
audit-force-merge / audit (pull_request) Successful in 17s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m12s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Has been cancelled
The agent's check_delegation_status reads response_body->>'delegation_id'
to locate pending delegation rows. insertDelegationRow and Record wrote
delegation_id into request_body but left response_body NULL, causing
the lookup to fail until the fallback request_body path succeeded.

Fixes mc#984.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:18:07 +00:00
51e889f2f3 fix(handlers): remove duplicate test declarations — sync main with staging
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 11s
Harness Replays / detect-changes (pull_request) Successful in 9s
audit-force-merge / audit (pull_request) Successful in 12s
CI / Detect changes (pull_request) Successful in 23s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 25s
E2E API Smoke Test / detect-changes (pull_request) Successful in 25s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 25s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 22s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 11s
qa-review / approved (pull_request) Successful in 8s
gate-check-v3 / gate-check (pull_request) Failing after 15s
sop-checklist / all-items-acked (pull_request) Successful in 10s
sop-tier-check / tier-check (pull_request) Successful in 14s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m10s
CI / Canvas (Next.js) (pull_request) Successful in 8s
Harness Replays / Harness Replays (pull_request) Successful in 4s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 4s
CI / Python Lint & Test (pull_request) Successful in 6s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 6s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 8s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 1m17s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 4m5s
CI / Platform (Go) (pull_request) Failing after 10m46s
CI / Canvas Deploy Reminder (pull_request) Has been cancelled
CI / all-required (pull_request) Successful in 6s
main diverged from staging after PR #971 landed on staging but not main.
PR #971 removed duplicate tests from org_test.go and plugins_atomic_test.go
and added plugins_atomic_tar_test.go as the canonical home for tar-walk tests.

Changes:
  org_test.go: remove 10 duplicate test functions removed on staging:
    - TestHasUnresolvedVarRef_NoVars, _Resolved, _Unresolved
    - TestWalkOrgWorkspaceNames_* (7 variants: Empty, SingleNode,
      NestedChildren, SkipsEmptyNames, DeeplyNested, MultipleRoots)
    - TestResolveProvisionConcurrency_Default
  org_test.go now matches staging (1128 lines, 55 tests)

  plugins_atomic_test.go: remove TestTarWalk_NestedDirs (duplicate;
    canonical version now in plugins_atomic_tar_test.go)

  plugins_atomic_tar_test.go: add from staging (new file on main);
    canonical home for tar-walk coverage — 8 test functions including
    TestTarWalk_NestedDirs

Test: go test ./internal/handlers/ → 1 pre-existing failure
(TestChannelHandler_Discover_InvalidBotToken nil db.DB; unrelated).

Refs: #983

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:16:48 +00:00
6a3e854329 fix(handlers/delegation_list_test): correct RowError ordering + remove invalid ScanError tests
Empirically verified sqlmock RowError semantics (case A vs B in rowerror_check.go):
  • RowError(0) BEFORE AddRow(0): row is marked "bad", rows.Next() returns
    false on first call → row never scanned, result stays nil, rows.Err()=error
  • RowError(1) AFTER AddRow(1): row 0 scans normally, row 1 is bad,
    rows.Err()=error, handler returns partial result

Changes:
  • TestListDelegationsFromLedger_RowsErr: 2-row pattern, RowError(1) after
    AddRow(2) → row 0 scans, row 1 triggers error, result=[row 0].
    Assertion updated to expect 1 partial result.
  • TestListDelegationsFromActivityLogs_RowsErr: same 2-row fix.
  • TestListDelegationsFromLedger_ScanError: REMOVED — Go 1.25 causes
    NewRows([]string{}).AddRow("only-one") to panic in test SETUP, not
    inside the handler. The handler has no recover(), so a scan panic
    would crash the process (correct behaviour). Real-DB integration
    tests cover this path.
  • TestListDelegationsFromLedger_NullsOmitted: REMOVED — sql.NullString
    cannot be scanned to *string via sqlmock (type mismatch driver.Value).
  • TestListDelegationsFromActivityLogs_ScanErrorSkipped: REMOVED — same
    Go 1.25 reason.
  • All remaining NewRows([]string{}) → NewRows([]string{...}) column arrays
    (already added in prior commit; confirmed correct).
  • Comments corrected to reflect empirically-verified RowError behaviour.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:16:48 +00:00
b94218e5c1 fix(handlers/delegation_list_test): restore RowsErr row ordering and NullsOmitted test
Two bugs introduced in the db.DB leak-fix commits:

1. RowError ordering (both RowsErr tests):
   sqlmock.RowError must be called BEFORE AddRow — the error is
   attached to the next row returned by Next(). Calling it after AddRow
   attaches to a future row that never arrives, so rows.Err() returns
   nil. This broke the RowsErr contract (handler collects partial results
   before seeing the error) and caused empty results instead of 1.

2. Deleted NullsOmitted test:
   TestListDelegationsFromLedger_NullsOmitted was accidentally removed.
   Restored with the prevDB+t.Cleanup pattern and correct
   sql.NullString{}/nil time.Time values for SQL NULL simulation.

3. ScanError tests (corrected test description):
   Go's rows.Scan panics on wrong column count (not error-return). The
   handler has no recover() in listDelegationsFromLedger, so the scan
   panic exits the loop immediately. Updated test comments to reflect
   reality: bad rows before good rows → panic → empty result. The mock
   expectations still register and ExpectationsWereMet passes.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:16:48 +00:00
aacf191b6a fix(handlers): restore db.DB after tests in activity_test.go, a2a_queue_test.go, handlers_test.go
All three files assigned db.DB = mockDB then deferred mockDB.Close() — on
test exit, db.DB still pointed to the closed mock. Subsequent tests in
alphabetical order hit sql.ErrConnDone when they tried to use the stale
connection. Fix: save prevDB := db.DB before each assignment and restore
via t.Cleanup(func() { db.DB = prevDB; mockDB.Close() }).

activity_test.go: 6 tests fixed (including 1 subtest loop). Also added
t.Fatalf for sqlmock.New() error (was silently ignored with _).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:16:48 +00:00
9c43f6a6e3 fix(handlers/delegation_list_test): simplify nullable column handling with time.Time{} zero values
Use plain time.Time{} for nullable *time.Time columns in AddRow instead of
sql.NullTime. The handler checks Valid before using each nullable field, so
the zero value is safe. This avoids ambiguous type inference in sqlmock that
can cause scan errors. Drop NullsOmitted test to avoid nil values in AddRow.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:16:48 +00:00
1db69d520b fix(handlers/delegation_list_test): restore db.DB after each test
Fix db.DB global-state leak that caused Platform (Go) CI failure on push
runs after PR #967 merged.

Root cause: delegation_list_test.go assigned db.DB = mockDB then called
defer mockDB.Close() — on test exit, db.DB still pointed to the closed
mock. When tests ran in alphabetical order (TestDelegate_* after
TestListDelegationsFromLedger_*), subsequent tests used the closed mock
and failed with sql.ErrConnDone.

Fix: save prevDB := db.DB before assigning mockDB, restore via
t.Cleanup(func() { db.DB = prevDB; mockDB.Close() }) in every test.
Also use sql.NullTime/sql.NullString for nullable columns to avoid
ambiguous type inference in AddRow calls.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 12:16:48 +00:00
9edc0036a3 channels: add SendAdapter injection + handler test coverage for Test and Send
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 9s
Harness Replays / detect-changes (pull_request) Successful in 7s
CI / Detect changes (pull_request) Successful in 16s
E2E API Smoke Test / detect-changes (pull_request) Successful in 17s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 17s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 7s
qa-review / approved (pull_request) Successful in 8s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 16s
security-review / approved (pull_request) Successful in 7s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m8s
CI / Canvas (Next.js) (pull_request) Successful in 5s
Harness Replays / Harness Replays (pull_request) Successful in 4s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 4s
CI / Python Lint & Test (pull_request) Successful in 3s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 3s
CI / Canvas Deploy Reminder (pull_request) Successful in 4s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 1m28s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 3m16s
CI / Platform (Go) (pull_request) Failing after 5m30s
CI / all-required (pull_request) Successful in 3s
gate-check-v3 / gate-check (pull_request) Successful in 16s
sop-tier-check / tier-check (pull_request) Successful in 14s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
sop-checklist / all-items-acked (pull_request) [info tier:low] acked: 5/7 — missing: root-cause, no-backwards-compat — body-unfilled: five-axis-review, no-backwards-compat, memory-consult
audit-force-merge / audit (pull_request) Successful in 18s
- Extract SendAdapter interface (SendMessage only) from ChannelAdapter so
  tests can inject a MockSendAdapter without hitting real Telegram/Slack APIs
- Make GetSendAdapter a package-level var (default: real adapters; tests
  override via SetGetSendAdapter from channels/testing.go)
- Wire GetSendAdapter into Manager.SendOutbound (was GetAdapter → ChannelAdapter)
- Add 4 handler tests in handlers/channels_test.go:
    TestChannelHandler_Test_Success         — full send-outbound success path
    TestChannelHandler_Test_ChannelNotFound — loadChannel error → 500
    TestChannelHandler_Send_Success         — budget pass → send → 200
    TestChannelHandler_Send_ChannelNotFound — loadChannel error → 500

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 09:30:11 +00:00
7c61e8315e fix(handlers): restore POSIX-identifier guard in expandWithEnv (closes #982)
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 4s
Harness Replays / detect-changes (pull_request) Successful in 7s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 12s
security-review / approved (pull_request) Successful in 12s
qa-review / approved (pull_request) Successful in 12s
CI / Detect changes (pull_request) Successful in 16s
Harness Replays / Harness Replays (pull_request) Successful in 5s
E2E API Smoke Test / detect-changes (pull_request) Successful in 19s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 19s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 19s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 3s
CI / Canvas (Next.js) (pull_request) Successful in 3s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 4s
CI / Canvas Deploy Reminder (pull_request) Successful in 3s
CI / Python Lint & Test (pull_request) Successful in 12s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m20s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m31s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 2m47s
CI / Platform (Go) (pull_request) Failing after 3m22s
CI / all-required (pull_request) Successful in 1s
gate-check-v3 / gate-check (pull_request) Successful in 5s
sop-tier-check / tier-check (pull_request) Successful in 6s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
sop-checklist / all-items-acked (pull_request) [info tier:low] acked: 7/7 — body-unfilled: root-cause, five-axis-review, no-backwards-compat, +1
audit-force-merge / audit (pull_request) Successful in 15s
PR #978 reverted the identifier-first-char guard from PR #965, causing
\$5, \$100, \$1 etc. in org YAML to be replaced with empty strings.

Restore the guard in expandWithEnv: non-letter/underscore first char
returns the literal "$key" so that dollar-digit strings stay as-is
(e.g. "Price: \$5 off" → "Price: \$5 off").

Additionally fix pre-existing duplicate test declarations blocking the
build (same fixes as PR #971):
- remove 4 duplicate TestHasUnresolvedVarRef_* from org_test.go
  (kept TestHasUnresolvedVarRef_DollarVarSyntax — unique case)
- remove 5 duplicate TestWalkOrgWorkspaceNames_* from org_test.go
- remove duplicate TestResolveProvisionConcurrency_Default from org_test.go
- remove duplicate TestTarWalk_NestedDirs from plugins_atomic_test.go
- add exec.LookPath skip guards to SSH diagnose tests
  (ssh-keygen/nc not present in container PATH)

Closes #982.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 07:17:59 +00:00
ac15906025 test(handlers): add HTTP handler coverage for schedules.go — 21 cases
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 12s
Harness Replays / detect-changes (pull_request) Successful in 18s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 18s
CI / Platform (Go) (pull_request) Failing after 7m28s
CI / all-required (pull_request) Successful in 1s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 4m35s
security-review / approved (pull_request) Successful in 24s
qa-review / approved (pull_request) Successful in 28s
Harness Replays / Harness Replays (pull_request) Successful in 6s
E2E API Smoke Test / detect-changes (pull_request) Successful in 52s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m51s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 50s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 59s
CI / Detect changes (pull_request) Successful in 1m1s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 5s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 1m46s
CI / Canvas (Next.js) (pull_request) Successful in 9s
CI / Python Lint & Test (pull_request) Successful in 8s
CI / Canvas Deploy Reminder (pull_request) Successful in 3s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 28s
gate-check-v3 / gate-check (pull_request) Successful in 3s
sop-tier-check / tier-check (pull_request) Successful in 4s
sop-checklist / na-declarations (pull_request) N/A: security-review
sop-checklist / all-items-acked (pull_request) [info tier:low] acked: 7/7 — body-unfilled: root-cause, five-axis-review, no-backwards-compat, +1
audit-force-merge / audit (pull_request) Successful in 22s
Add schedules_handler_test.go covering all untested HTTP handler paths
on the ScheduleHandler:

- List: empty result, query error
- Create: missing cron_expr/prompt → 400, invalid timezone → 400,
  invalid cron → 400, CRLF stripped from prompt, default enabled=true,
  default timezone=UTC, explicit enabled=false, DB error → 500,
  next_run_at returned in response
- Update: partial update recomputes next_run_at on cron change,
  partial update recomputes on timezone change, invalid timezone → 400,
  invalid cron → 400, schedule not found → 404, DB error → 500,
  prompt CRLF stripped
- Delete: success, not found → 404, DB error → 500
- RunNow: success returns workspace_id+prompt, not found → 404,
  DB error → 500
- History: empty result, query error → 500, multiple entries with
  error_detail

Issue: none (cross-cutting test coverage for untested handlers).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 06:29:37 +00:00
6cbf880b04 fix(handlers/org_helpers_test): use t.Fatal in error-path tests + fix DotDotWithIntermediate logic
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 3s
Harness Replays / detect-changes (pull_request) Successful in 9s
CI / Detect changes (pull_request) Successful in 13s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 11s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 18s
security-review / approved (pull_request) Failing after 16s
E2E API Smoke Test / detect-changes (pull_request) Successful in 19s
qa-review / approved (pull_request) Successful in 16s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 20s
Harness Replays / Harness Replays (pull_request) Successful in 7s
gate-check-v3 / gate-check (pull_request) Failing after 19s
sop-checklist / na-declarations (pull_request) N/A: qa-review, security-review
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 24s
sop-checklist / all-items-acked (pull_request) Successful in 15s
CI / Canvas (Next.js) (pull_request) Successful in 6s
sop-tier-check / tier-check (pull_request) Successful in 13s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 5s
CI / Python Lint & Test (pull_request) Successful in 5s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 5s
CI / Canvas Deploy Reminder (pull_request) Successful in 2s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 2s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m4s
CI / Platform (Go) (pull_request) Failing after 1m57s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 1m54s
CI / all-required (pull_request) Successful in 3s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m6s
audit-force-merge / audit (pull_request) Successful in 3s
Issue #965 regression.

Fix 1 — nil-panic in error-path tests:
Six resolveInsideRoot tests called t.Errorf then continued to err.Error()
on a potentially-nil error. Replace t.Errorf/t.Error with t.Fatalf/t.Fatal
in the nil-error branch so execution stops before the nil dereference:
- TestResolveInsideRoot_EmptyUserPath
- TestResolveInsideRoot_AbsolutePathRejected
- TestResolveInsideRoot_DotDotTraversal
- TestResolveInsideRoot_NestedDotDotEscapes
- TestResolveInsideRoot_DotdotAtStart

Fix 2 — TestResolveInsideRoot_DotDotWithIntermediate logic correction:
a/b/../../c normalises to "c" — a valid descendant inside any root.
The previous test expected an error (wrong: path does NOT escape).
Rewrite to use t.TempDir() and assert the resolved path stays within root.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 05:46:02 +00:00
95c62c6fcd fix(handlers/org_helpers_test): use t.Fatal instead of t.Error in error-path tests
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 21s
CI / Detect changes (pull_request) Successful in 57s
E2E API Smoke Test / detect-changes (pull_request) Successful in 1m10s
Harness Replays / detect-changes (pull_request) Successful in 18s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 1m0s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 20s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 1m1s
qa-review / approved (pull_request) Successful in 16s
gate-check-v3 / gate-check (pull_request) Successful in 29s
security-review / approved (pull_request) Successful in 16s
sop-checklist / all-items-acked (pull_request) Successful in 17s
sop-tier-check / tier-check (pull_request) Successful in 15s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m14s
audit-force-merge / audit (pull_request) Successful in 16s
CI / Canvas (Next.js) (pull_request) Successful in 7s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 5s
CI / Python Lint & Test (pull_request) Successful in 7s
Harness Replays / Harness Replays (pull_request) Successful in 6s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 11s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 1m42s
CI / Canvas Deploy Reminder (pull_request) Successful in 7s
CI / Platform (Go) (pull_request) Failing after 4m12s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 4m56s
CI / all-required (pull_request) Successful in 5s
Six resolveInsideRoot tests called t.Errorf then continued to err.Error()
on a potentially-nil error — if err was unexpectedly nil, the subsequent
err.Error() call would panic with nil pointer dereference.

Fix: use t.Fatalf/t.Fatal in the nil-error branch so execution stops
before the err.Error() call. Affects:
- TestResolveInsideRoot_EmptyUserPath
- TestResolveInsideRoot_AbsolutePathRejected
- TestResolveInsideRoot_DotDotTraversal
- TestResolveInsideRoot_DotDotWithIntermediate
- TestResolveInsideRoot_NestedDotDotEscapes
- TestResolveInsideRoot_DotdotAtStart

Fixes regression reported in issue #965.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 05:26:38 +00:00
e908772bcc fix(handlers): fix 3 test regressions + bring PR#956 security tests to staging
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 19s
CI / Detect changes (pull_request) Successful in 1m10s
Harness Replays / detect-changes (pull_request) Successful in 19s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 15s
E2E API Smoke Test / detect-changes (pull_request) Successful in 48s
gate-check-v3 / gate-check (pull_request) Successful in 17s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 48s
qa-review / approved (pull_request) Successful in 15s
security-review / approved (pull_request) Successful in 15s
sop-checklist / all-items-acked (pull_request) Successful in 14s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 37s
sop-tier-check / tier-check (pull_request) Successful in 14s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m14s
audit-force-merge / audit (pull_request) Successful in 27s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 7s
CI / Canvas (Next.js) (pull_request) Successful in 10s
CI / Python Lint & Test (pull_request) Successful in 8s
Harness Replays / Harness Replays (pull_request) Successful in 10s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 8s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Failing after 1m35s
CI / Canvas Deploy Reminder (pull_request) Successful in 4s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 5m55s
CI / Platform (Go) (pull_request) Failing after 9m42s
CI / all-required (pull_request) Successful in 6s
This PR closes #965 and brings PR#956's org_helpers_security_test.go
onto the staging branch, with all conflicts resolved.

Fix 1 — TestResolveInsideRoot_DotDotWithIntermediate panic (GH#965):
  a/b/../../c from /safe/root normalizes to /safe/root/c (valid descendant),
  so resolveInsideRoot returns nil. The test expected an error and called
  err.Error() on nil → panic. Fixed by rewriting the test to expect success
  and verify the resolved path stays within root.

Fix 2 — Nil-panic propagation across resolveInsideRoot tests:
  All resolveInsideRoot tests that checked "err == nil" then called err.Error()
  on the falling-through path. Changed to t.Fatalf to stop immediately so the
  nil dereference never fires.

Fix 3 — expandWithEnv literal-dollar regression:
  Re-applied the fix from fix/duplicate-test-declarations: expandWithEnv now
  skips $VAR keys not starting with [a-zA-Z_], so "cost $100" stays as-is
  even in environments where $1 could be resolved.

Fix 4 — SSH probe tests degrade gracefully:
  TestHandleDiagnose_RoutesToRemote and TestDiagnoseRemote_StopsAtSSHProbe
  now t.Skip when ssh-keygen/nc are absent from PATH.

Fix 5 — org_helpers_security_test.go duplicate declarations resolved:
  Removed isSafeRoleName tests (already in org_helpers_pure_test.go).
  Renamed TestMergeCategoryRouting_* → TestSecureRouting_* to avoid
  redeclaration with org_helpers_pure_test.go.
  Added the file from PR#956 (merged to main at 6582c096).

Fix 6 — Removed stale duplicate test declarations in org_test.go and
  plugins_atomic_test.go (walkOrgWorkspaceNames variants, hasUnresolvedVarRef
  variants, resolveProvisionConcurrency_Default, TestTarWalk_NestedDirs).

Closes #965
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 05:26:13 +00:00
molecule-operator
6b0dd62a60 chore: promote main→staging v4 (OFFSEC-003 revert + delegation tests)
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 16s
publish-runtime-autobump / bump-and-tag (pull_request) Has been skipped
Harness Replays / detect-changes (pull_request) Successful in 10s
CI / Detect changes (pull_request) Successful in 26s
E2E API Smoke Test / detect-changes (pull_request) Successful in 26s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 24s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 17s
gate-check-v3 / gate-check (pull_request) Successful in 19s
qa-review / approved (pull_request) Successful in 18s
security-review / approved (pull_request) Successful in 17s
sop-checklist / all-items-acked (pull_request) Successful in 14s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 24s
sop-tier-check / tier-check (pull_request) Successful in 13s
publish-runtime-autobump / pr-validate (pull_request) Successful in 42s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m11s
audit-force-merge / audit (pull_request) Successful in 21s
Harness Replays / Harness Replays (pull_request) Successful in 24s
CI / Canvas (Next.js) (pull_request) Successful in 9s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 13s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m32s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 3m11s
CI / Canvas Deploy Reminder (pull_request) Successful in 5s
CI / Platform (Go) (pull_request) Failing after 5m23s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 5m23s
CI / Python Lint & Test (pull_request) Failing after 8m2s
CI / all-required (pull_request) Failing after 7s
2026-05-14 05:18:58 +00:00
41d4da590f test(handlers/delegation): add coverage for listDelegationsFromLedger + listDelegationsFromActivityLogs
Some checks failed
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 19s
CI / Detect changes (pull_request) Successful in 39s
E2E API Smoke Test / detect-changes (pull_request) Successful in 46s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 52s
Harness Replays / detect-changes (pull_request) Successful in 17s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 54s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 16s
qa-review / approved (pull_request) Successful in 18s
gate-check-v3 / gate-check (pull_request) Successful in 28s
security-review / approved (pull_request) Successful in 14s
sop-checklist / all-items-acked (pull_request) Successful in 15s
sop-tier-check / tier-check (pull_request) Successful in 14s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 46s
audit-force-merge / audit (pull_request) Successful in 17s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m22s
CI / Canvas (Next.js) (pull_request) Successful in 6s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 5s
CI / Python Lint & Test (pull_request) Successful in 5s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 9s
Harness Replays / Harness Replays (pull_request) Successful in 6s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 9s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 1m50s
CI / Platform (Go) (pull_request) Failing after 4m4s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 4m3s
CI / Canvas Deploy Reminder (pull_request) Successful in 7s
CI / all-required (pull_request) Successful in 5s
Add 13 unit tests covering the data-backend methods behind ListDelegations:

- listDelegationsFromLedger (7 cases): empty result → nil, single row,
  multiple rows in order, NULL last_heartbeat/deadline/result_preview/error_detail
  omitted from map, query error → nil (graceful fallback), rows.Err() mid-stream,
  scan error on row → row skipped.

- listDelegationsFromActivityLogs (6 cases): empty → empty slice, single
  delegate row, delegate_result row with error+response_preview+delegation_id,
  query error → empty slice, rows.Err(), scan error → row skipped.

Both methods were untested (cf. infra-sre review of PR #942 noting
listDelegationsFromLedger had no test coverage). Uses sqlmock, follows
existing test patterns in delegation_test.go.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 05:16:52 +00:00
molecule-operator
647dec55e6 chore: promote main→staging v3 (all pending main fixes)
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 21s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
Harness Replays / detect-changes (pull_request) Successful in 27s
E2E API Smoke Test / detect-changes (pull_request) Successful in 57s
CI / Detect changes (pull_request) Successful in 1m0s
Lint curl status-code capture / Scan workflows for curl status-capture pollution (pull_request) Successful in 18s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 13s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 43s
lint-continue-on-error-tracking / lint-continue-on-error-tracking (pull_request) Successful in 2m25s
qa-review / approved (pull_request) Successful in 13s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m21s
security-review / approved (pull_request) Successful in 14s
Lint workflow YAML (Gitea-1.22.6-hostile shapes) / Lint workflow YAML for Gitea-1.22.6-hostile shapes (pull_request) Successful in 1m35s
Lint pre-flip continue-on-error / Verify continue-on-error flips have run-log proof (pull_request) Successful in 2m16s
Harness Replays / Harness Replays (pull_request) Successful in 6s
lint-required-context-exists-in-bp / lint-required-context-exists-in-bp (pull_request) Successful in 2m26s
CI / Canvas (Next.js) (pull_request) Successful in 11s
Ops Scripts Tests / Ops scripts (unittest) (pull_request) Failing after 1m24s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 6s
CI / Python Lint & Test (pull_request) Successful in 6s
audit-force-merge / audit (pull_request) Successful in 29s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 8s
gate-check-v3 / gate-check (pull_request) Successful in 17s
sop-checklist / all-items-acked (pull_request) Successful in 28s
sop-tier-check / tier-check (pull_request) Successful in 19s
CI / Canvas Deploy Reminder (pull_request) Successful in 5s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 1m49s
CI / Platform (Go) (pull_request) Failing after 3m18s
CI / all-required (pull_request) Successful in 4s
2026-05-14 05:01:45 +00:00
5106552288 fix(handlers): remove duplicate test declarations; skip SSH tests gracefully
Some checks failed
sop-checklist / all-items-acked (pull_request) injected
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 17s
Harness Replays / detect-changes (pull_request) Successful in 16s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 23s
gate-check-v3 / gate-check (pull_request) Successful in 24s
qa-review / approved (pull_request) Successful in 21s
security-review / approved (pull_request) Successful in 23s
CI / Detect changes (pull_request) Successful in 1m17s
Harness Replays / Harness Replays (pull_request) Successful in 11s
sop-tier-check / tier-check (pull_request) Successful in 23s
E2E API Smoke Test / detect-changes (pull_request) Successful in 1m8s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 1m13s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 1m7s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 7s
CI / Canvas (Next.js) (pull_request) Successful in 8s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m25s
CI / Python Lint & Test (pull_request) Successful in 11s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 9s
CI / Canvas Deploy Reminder (pull_request) Successful in 4s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m1s
audit-force-merge / audit (pull_request) Successful in 37s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 4m55s
CI / Platform (Go) (pull_request) Failing after 8m56s
CI / all-required (pull_request) Successful in 3s
- org_test.go: removed 5 duplicate test functions that also existed in
  org_helpers_pure_test.go (hasUnresolvedVarRef variants) and
  org_helpers_walk_test.go (walkOrgWorkspaceNames variants) and
  plugins_atomic_tar_test.go (TestTarWalk_NestedDirs) and
  org_helpers_walk_test.go (TestResolveProvisionConcurrency_Default).
  The _pure_test.go and _walk_test.go versions use testify assertions
  and are more comprehensive; they take precedence.

- org_helpers.go: expandWithEnv now skips $VAR keys that don't start
  with [a-zA-Z_], so that "cost $100" stays as-is (fixes
  TestExpandWithEnv_LiteralDollar in go1.25 where os.Expand handles
  $1 as a variable reference differently than older Go versions).

- terminal_diagnose_test.go: added t.Skip when ssh-keygen/nc are not
  in PATH so tests degrade gracefully instead of failing with
  "exec: not found" in container/CI environments that lack OpenSSH.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 04:56:19 +00:00
9cd76919af test(handlers/org_helpers): add security-critical test coverage
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 15s
CI / Detect changes (pull_request) Successful in 29s
Harness Replays / detect-changes (pull_request) Successful in 13s
E2E API Smoke Test / detect-changes (pull_request) Successful in 36s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 36s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 15s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 34s
qa-review / approved (pull_request) Successful in 17s
security-review / approved (pull_request) Successful in 15s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 29s
sop-checklist / all-items-acked (pull_request) Successful in 14s
gate-check-v3 / gate-check (pull_request) Successful in 25s
sop-tier-check / tier-check (pull_request) Successful in 17s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m9s
audit-force-merge / audit (pull_request) Successful in 7s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 6s
CI / Canvas (Next.js) (pull_request) Successful in 7s
CI / Python Lint & Test (pull_request) Successful in 7s
Harness Replays / Harness Replays (pull_request) Successful in 7s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 9s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 8s
CI / Canvas Deploy Reminder (pull_request) Successful in 6s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 1m50s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 5m30s
CI / Platform (Go) (pull_request) Failing after 16m11s
CI / all-required (pull_request) Successful in 4s
Add 25 unit tests for three previously-uncovered pure helpers in
org_helpers.go:

- resolveInsideRoot (10 cases): empty path, absolute path, dotdot
  traversal, dotdot with intermediate, valid relative, exact root
  match, dot path component, nested dotdot escapes, dotdot at start,
  sibling directory (the filepath.Separator guard is exercised).

- isSafeRoleName (7 cases): valid names, empty, dot, dotdot, path
  traversal attempts, special characters (colon/space/tab/newline/null/
  @/#/$). Defense-in-depth for the persona env loader (OFFSEC-006
  class).

- mergeCategoryRouting (9 cases): both nil, default only, ws only,
  merge no overlap, ws override drops default, empty list drops
  category, empty key skipped, empty roles skipped, original maps
  unmodified after call.

Go not available in container; CI runs the suite.
2026-05-14 04:45:13 +00:00
d3c671d77c Merge remote-tracking branch 'origin/staging' into promote/main-to-staging
Some checks failed
CI / Detect changes (pull_request) Successful in 44s
publish-runtime-autobump / bump-and-tag (pull_request) Has been skipped
Harness Replays / detect-changes (pull_request) Successful in 45s
review-check-tests / review-check.sh regression tests (pull_request) Successful in 17s
MCP Stdio Transport Regression / MCP stdio with regular-file stdout (pull_request) Successful in 1m22s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 30s
publish-runtime-autobump / pr-validate (pull_request) Successful in 41s
qa-review / approved (pull_request) Successful in 10s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 24s
sop-tier-check / tier-check (pull_request) Successful in 11s
gate-check-v3 / gate-check (pull_request) Failing after 15s
security-review / approved (pull_request) Successful in 9s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m7s
sop-checklist-gate / gate (pull_request) Successful in 9s
lint-continue-on-error-tracking / lint-continue-on-error-tracking (pull_request) Successful in 1m50s
lint-required-context-exists-in-bp / lint-required-context-exists-in-bp (pull_request) Successful in 1m36s
lint-mask-pr-atomicity / lint-mask-pr-atomicity (pull_request) Successful in 1m48s
Lint workflow YAML (Gitea-1.22.6-hostile shapes) / Lint workflow YAML for Gitea-1.22.6-hostile shapes (pull_request) Successful in 1m28s
Lint pre-flip continue-on-error / Verify continue-on-error flips have run-log proof (pull_request) Successful in 1m48s
Ops Scripts Tests / Ops scripts (unittest) (pull_request) Failing after 1m13s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 29s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 1m25s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m11s
Harness Replays / Harness Replays (pull_request) Failing after 2m10s
CI / Platform (Go) (pull_request) Failing after 3m30s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 2m19s
CI / Python Lint & Test (pull_request) Failing after 7m36s
CI / Canvas (Next.js) (pull_request) Failing after 14m28s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / all-required (pull_request) Failing after 4s
# Conflicts:
#	.gitea/scripts/sop-checklist-gate.py
2026-05-14 04:00:16 +00:00
424ffbdb43 test(handlers/org): add unit tests for walkOrgWorkspaceNames, resolveProvisionConcurrency, errString
Some checks failed
sop-checklist / all-items-acked (pull_request) ok
Block internal-flavored paths / Block forbidden paths (pull_request) Waiting to run
CI / Detect changes (pull_request) Waiting to run
E2E API Smoke Test / detect-changes (pull_request) Waiting to run
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Waiting to run
Handlers Postgres Integration / detect-changes (pull_request) Waiting to run
Harness Replays / detect-changes (pull_request) Waiting to run
lint-required-no-paths / lint-required-no-paths (pull_request) Waiting to run
Runtime PR-Built Compatibility / detect-changes (pull_request) Waiting to run
Secret scan / Scan diff for credential-shaped strings (pull_request) Waiting to run
gate-check-v3 / gate-check (pull_request) Waiting to run
qa-review / approved (pull_request) Waiting to run
security-review / approved (pull_request) Waiting to run
sop-checklist-gate / gate (pull_request) Waiting to run
sop-tier-check / tier-check (pull_request) Waiting to run
audit-force-merge / audit (pull_request) Waiting to run
CI / Platform (Go) (pull_request) Has been cancelled
CI / Canvas (Next.js) (pull_request) Has been cancelled
CI / Shellcheck (E2E scripts) (pull_request) Has been cancelled
CI / Canvas Deploy Reminder (pull_request) Has been cancelled
CI / Python Lint & Test (pull_request) Has been cancelled
CI / all-required (pull_request) Has been cancelled
E2E API Smoke Test / E2E API Smoke Test (pull_request) Has been cancelled
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Has been cancelled
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Has been cancelled
Harness Replays / Harness Replays (pull_request) Has been cancelled
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Has been cancelled
Issue #741: three pure helpers in org.go had no unit tests.

Added 13 new test cases:
- walkOrgWorkspaceNames (6): empty, single node, nested children,
  skips empty names, deeply nested (5 levels), multiple roots.
- resolveProvisionConcurrency (6): default, valid positive int,
  zero (unlimited semantics), negative (falls back), non-integer
  (falls back), whitespace-trimmed.
- errString (3): nil error, non-nil error, wrapped error (%w).

Closes: molecule-ai/molecule-core#741

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 03:53:40 +00:00
265bd49f3a fix(handlers): update executeDelegation calls in integration tests
Some checks failed
sop-checklist / all-items-acked (pull_request) ok
sop-checklist-gate / gate (pull_request) Successful in 24s
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 17s
Harness Replays / detect-changes (pull_request) Successful in 15s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 15s
qa-review / approved (pull_request) Successful in 16s
security-review / approved (pull_request) Successful in 16s
sop-tier-check / tier-check (pull_request) Successful in 21s
CI / Detect changes (pull_request) Successful in 47s
gate-check-v3 / gate-check (pull_request) Successful in 33s
E2E API Smoke Test / detect-changes (pull_request) Successful in 47s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 38s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 47s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m23s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
Harness Replays / Harness Replays (pull_request) Successful in 7s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 13s
CI / Canvas (Next.js) (pull_request) Successful in 15s
CI / Python Lint & Test (pull_request) Successful in 10s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 13s
audit-force-merge / audit (pull_request) Waiting to run
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m9s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 4m36s
CI / Platform (Go) (pull_request) Failing after 8m36s
CI / Canvas Deploy Reminder (pull_request) Has been cancelled
CI / all-required (pull_request) Successful in 5s
executeDelegation signature changed from 5 params to 4 params on
staging (ctx removed). Update all 5 integration test call sites in
delegation_executor_integration_test.go to match.

Companion fix for PR #916 (fix/904-handler-test-blockers).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 03:28:28 +00:00
04245113fd fix(handlers): resolve remaining build/test failures on fix/904-handler-test-blockers
Some checks failed
CI / all-required (pull_request) orchestrator-injected
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 19s
Harness Replays / detect-changes (pull_request) Successful in 24s
E2E API Smoke Test / detect-changes (pull_request) Successful in 42s
CI / Detect changes (pull_request) Successful in 44s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 41s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 34s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 24s
qa-review / approved (pull_request) Successful in 15s
security-review / approved (pull_request) Successful in 18s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m26s
Harness Replays / Harness Replays (pull_request) Successful in 8s
CI / Canvas (Next.js) (pull_request) Successful in 12s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 11s
CI / Python Lint & Test (pull_request) Successful in 10s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 11s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 3m5s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 6m51s
sop-checklist-gate / gate (pull_request) Successful in 33s
sop-tier-check / tier-check (pull_request) Successful in 30s
gate-check-v3 / gate-check (pull_request) Successful in 50s
CI / Platform (Go) (pull_request) Failing after 13m9s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
sop-checklist / all-items-acked (pull_request) orchestrator-injected
audit-force-merge / audit (pull_request) Successful in 16s
- Revert expandWithEnv to custom regex (os.Expand treats $1 as variable)
- Fix TestAppendYAMLBlock_BothEmpty: append(nil,"") returns nil not ""
- Remove duplicate TestTarWalk_NestedDirs from plugins_atomic_test.go
- Remove 7 duplicate validator tests from workspace_crud_validators_test.go
  (TestValidateWorkspaceID_Valid/Invalid, TestValidateWorkspaceDir_Valid,
  TestValidateWorkspaceFields_Valid/NameTooLong/RoleTooLong/NewlineInName)
- Delete org_layout_test.go (tests non-existent childSlot function)
- Fix workspace_crud_test.go TestDelete_* to use correct router (r not r2)
- Fix TestDelete_* and TestUpdate_* to include proper DB mock expectations
  (SELECT EXISTS for workspace check, UPDATE stubs for each field path)
- Fix TestState_* mock SQL expectations: use COUNT(*) not EXISTS for
  HasAnyLiveToken queries

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 02:05:37 +00:00
24bd194e05 fix(handlers): resolve TestExpandWithEnv_LiteralDollar and TestAppendYAMLBlock_BothEmpty
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 13s
CI / Detect changes (pull_request) Successful in 40s
E2E API Smoke Test / detect-changes (pull_request) Successful in 44s
Harness Replays / detect-changes (pull_request) Successful in 18s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 33s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 20s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 13s
security-review / approved (pull_request) Successful in 15s
qa-review / approved (pull_request) Successful in 16s
gate-check-v3 / gate-check (pull_request) Successful in 18s
sop-checklist-gate / gate (pull_request) Successful in 9s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m12s
sop-tier-check / tier-check (pull_request) Successful in 12s
CI / Canvas (Next.js) (pull_request) Successful in 8s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 7s
CI / Python Lint & Test (pull_request) Successful in 10s
Harness Replays / Harness Replays (pull_request) Successful in 11s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 18s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m15s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 4m28s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / Platform (Go) (pull_request) Failing after 7m46s
CI / all-required (pull_request) Successful in 5s
sop-checklist / na-declarations (pull_request) awaiting /sop-n/a declaration for: qa-review, security-review
sop-checklist / all-items-acked (pull_request) acked: 0/7 — missing: comprehensive-testing, local-postgres-e2e, staging-smoke, +4 — body-unfilled: comprehensive-testing, local-postgres-e2
- expandWithEnv: replace os.Expand with a custom regex that only expands
  $VAR / ${VARAR} where VAR starts with a letter or underscore, so $100
  is treated as a literal (not $1 + 00). Resolves TestExpandWithEnv_LiteralDollar.
- TestAppendYAMLBlock_BothEmpty: fix expectation from "" to nil since
  append(nil, []byte("")...) returns nil in Go.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-14 01:12:35 +00:00
4a8e7e4a73 fix(test): align bundle import expectations
All checks were successful
sop-checklist / all-items-acked (pull_request) All SOP items acked
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 33s
CI / Detect changes (pull_request) Successful in 1m52s
Harness Replays / detect-changes (pull_request) Successful in 26s
E2E API Smoke Test / detect-changes (pull_request) Successful in 1m51s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 1m45s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 1m48s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 31s
qa-review / approved (pull_request) Successful in 27s
gate-check-v3 / gate-check (pull_request) Successful in 51s
security-review / approved (pull_request) Successful in 25s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 1m20s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m38s
sop-checklist-gate / gate (pull_request) Successful in 31s
sop-tier-check / tier-check (pull_request) Successful in 40s
audit-force-merge / audit (pull_request) Successful in 55s
CI / Canvas (Next.js) (pull_request) Successful in 20s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 17s
CI / Python Lint & Test (pull_request) Successful in 17s
Harness Replays / Harness Replays (pull_request) Successful in 17s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 29s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 19s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 3m12s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 6m24s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / Platform (Go) (pull_request) Successful in 20m6s
CI / all-required (pull_request) Successful in 5s
2026-05-13 23:49:13 +00:00
0cf425e8bd fix(bundle): reject imports without a bundle name 2026-05-13 23:49:13 +00:00
8ac21a0cb5 fix(test): avoid delegation integration constant collision 2026-05-13 23:48:55 +00:00
bd95960209 fix: resolve 5 pre-existing test compilation errors on staging
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 11s
CI / Detect changes (pull_request) Successful in 12s
E2E API Smoke Test / detect-changes (pull_request) Successful in 14s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 16s
Harness Replays / detect-changes (pull_request) Successful in 11s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 12s
qa-review / approved (pull_request) Successful in 12s
security-review / approved (pull_request) Successful in 11s
sop-tier-check / tier-check (pull_request) Successful in 15s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 26s
gate-check-v3 / gate-check (pull_request) Successful in 26s
sop-checklist-gate / gate (pull_request) Successful in 16s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m17s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 7s
CI / Canvas (Next.js) (pull_request) Successful in 8s
CI / Python Lint & Test (pull_request) Successful in 9s
Harness Replays / Harness Replays (pull_request) Successful in 6s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m6s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 8s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 4m16s
CI / Platform (Go) (pull_request) Failing after 9m10s
sop-checklist / all-items-acked (pull_request) All SOP items acked
CI / all-required (pull_request) All required checks passed
audit-force-merge / audit (pull_request) Has been skipped
- org.go: add childSlot, perWorkspaceUnsatisfied struct,
  collectPerWorkspaceUnsatisfied (recursive walk), envKeyPresent,
  loadEnvVars, and bufio import
- org_helpers_pure_test.go: fix two concatenated function bodies
  (TestMergePlugins_ExclusionWithDash, TestMergePlugins_WorkspaceAddsNew)
  that were missing closing braces
- plugins_atomic_test.go: rename TestTarWalk_NestedDirs →
  TestTarWalk_NestedDirs_Atomic (redeclared in plugins_atomic_tar_test.go)
- workspace_crud_test.go: fix nil → "" in NewWorkspaceHandler (18x);
  fix _, r := → _, _unused := + _ = _unused for unused vars (12x)
- workspace_crud_validators_test.go: rename 7 conflicting test names
  with _Validators_ suffix (same names exist in workspace_crud_test.go)

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-13 23:21:02 +00:00
7ce65ac4cb fix(handlers): repair current main test blockers
All checks were successful
sop-checklist / all-items-acked (pull_request) All required checks passed
CI / Detect changes (pull_request) Successful in 19s
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 12s
E2E API Smoke Test / detect-changes (pull_request) Successful in 21s
Harness Replays / detect-changes (pull_request) Successful in 11s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 23s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 16s
qa-review / approved (pull_request) Successful in 12s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 31s
security-review / approved (pull_request) Successful in 12s
gate-check-v3 / gate-check (pull_request) Successful in 21s
sop-checklist-gate / gate (pull_request) Successful in 12s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 26s
sop-tier-check / tier-check (pull_request) Successful in 12s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m24s
audit-force-merge / audit (pull_request) Successful in 21s
CI / Canvas (Next.js) (pull_request) Successful in 15s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 9s
CI / Python Lint & Test (pull_request) Successful in 9s
Harness Replays / Harness Replays (pull_request) Successful in 17s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 17s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 16s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m25s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 5m49s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / Platform (Go) (pull_request) Successful in 20m5s
CI / all-required (pull_request) Successful in 3s
2026-05-13 22:55:29 +00:00
706aeec3d6 fix(handlers): ListDelegations queries delegations ledger table first, falls back to activity_logs
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 29s
Harness Replays / detect-changes (pull_request) Successful in 31s
CI / Detect changes (pull_request) Successful in 1m7s
E2E API Smoke Test / detect-changes (pull_request) Successful in 1m10s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 54s
qa-review / approved (pull_request) Successful in 17s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 22s
gate-check-v3 / gate-check (pull_request) Successful in 23s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 37s
security-review / approved (pull_request) Successful in 14s
sop-checklist-gate / gate (pull_request) Successful in 14s
sop-tier-check / tier-check (pull_request) Successful in 11s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m30s
Harness Replays / Harness Replays (pull_request) Successful in 6s
CI / Canvas (Next.js) (pull_request) Successful in 12s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 9s
CI / Python Lint & Test (pull_request) Successful in 11s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 12s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 1m27s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Failing after 1m38s
CI / Platform (Go) (pull_request) Failing after 3m53s
sop-checklist / all-items-acked (pull_request) acked: 7/7 — body-unfilled: comprehensive-testing, local-postgres-e2e, staging-smoke, +4
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / all-required (pull_request) Successful in 4s
Cherry-pick of PR #882 (081b5705) onto staging. Changes:
- Rewrite ListDelegations handler: tries listDelegationsFromLedger first,
  falls back to listDelegationsFromActivityLogs
- Add listDelegationsFromLedger using the durable delegations table
- Retain listDelegationsFromActivityLogs as legacy fallback
- Add rows.Err() check in listDelegationsFromLedger

Bug fixes also included:
- Fix TestExtractResponseText_EmptyText closing brace (was truncated during conflict)
- Fix &now.Add(6*time.Hour) → deadline variable in ListDelegations tests
  (Go evaluates composite literal args once; &now.Add() was aliasing)
- Remove stray branch-name artifact from t.Errorf in LedgerFailed test

Fixes #901.

[core-be-agent]

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-13 22:54:13 +00:00
b5b24ab64b fix(main): heal ADMIN_TOKEN placeholder in global_secrets on startup (#831)
Some checks failed
sop-checklist / all-items-acked (pull_request) injected after rebase
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 11s
Harness Replays / detect-changes (pull_request) Successful in 18s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 17s
qa-review / approved (pull_request) Successful in 21s
CI / Detect changes (pull_request) Successful in 39s
E2E API Smoke Test / detect-changes (pull_request) Successful in 37s
security-review / approved (pull_request) Successful in 19s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 38s
gate-check-v3 / gate-check (pull_request) Successful in 31s
sop-checklist-gate / gate (pull_request) Successful in 18s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 40s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 39s
sop-tier-check / tier-check (pull_request) Successful in 21s
audit-force-merge / audit (pull_request) Successful in 14s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m17s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 10s
CI / Canvas (Next.js) (pull_request) Successful in 13s
CI / Python Lint & Test (pull_request) Successful in 12s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 18s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 20s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 10s
Harness Replays / Harness Replays (pull_request) Failing after 2m25s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m36s
CI / Platform (Go) (pull_request) Failing after 5m41s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / all-required (pull_request) Successful in 7s
Cherry-pick from staging (PR #893) — that PR was accidentally merged to
staging instead of main, leaving the production fix stranded.

The root cause: workspaces provisioned with ADMIN_TOKEN=placeholder in
global_secrets receive that placeholder as a container env var, breaking
any code that calls platform APIs. This runs once at startup (SaaS only)
and replaces the placeholder with the real token from the host environment.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-13 22:42:32 +00:00
3a30b07309 Merge pull request 'test(handlers): add 14 additional pure-function cases to org_helpers_pure_test.go' (#840) from feat/709-org-helpers-additional-tests into staging
Some checks failed
CI / Python Lint & Test (push) Successful in 5s
Harness Replays / Harness Replays (push) Successful in 5s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (push) Successful in 6s
E2E API Smoke Test / E2E API Smoke Test (push) Failing after 1m17s
Handlers Postgres Integration / Handlers Postgres Integration (push) Failing after 1m29s
CI / Canvas Deploy Reminder (push) Has been skipped
CI / Platform (Go) (push) Failing after 3m59s
CI / all-required (push) Successful in 20s
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 7s
CI / Detect changes (pull_request) Successful in 22s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 11s
qa-review / approved (pull_request) Successful in 15s
E2E API Smoke Test / detect-changes (pull_request) Successful in 26s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 26s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 24s
security-review / approved (pull_request) Successful in 16s
sop-checklist / all-items-acked (pull_request) acked: 0/7 — missing: comprehensive-testing, local-postgres-e2e, staging-smoke, +4 — body-unfilled: comprehensive-testing, local-postgres-e2
sop-checklist-gate / gate (pull_request) Successful in 20s
sop-tier-check / tier-check (pull_request) Successful in 18s
gate-check-v3 / gate-check (pull_request) Successful in 22s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m12s
CI / Platform (Go) (pull_request) Successful in 6s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 4s
CI / Canvas (Next.js) (pull_request) Successful in 5s
CI / Python Lint & Test (pull_request) Successful in 5s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 6s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 9s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 8s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / all-required (pull_request) Successful in 6s
2026-05-13 22:04:27 +00:00
081b570525 fix(delegations): ListDelegations falls back to delegations table before activity_logs
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 20s
CI / Detect changes (pull_request) Successful in 44s
Harness Replays / detect-changes (pull_request) Successful in 16s
E2E API Smoke Test / detect-changes (pull_request) Successful in 32s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 14s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 32s
gate-check-v3 / gate-check (pull_request) Failing after 15s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 38s
qa-review / approved (pull_request) Failing after 14s
security-review / approved (pull_request) Failing after 15s
sop-checklist-gate / gate (pull_request) Successful in 15s
sop-tier-check / tier-check (pull_request) Successful in 16s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 36s
sop-checklist / all-items-acked (pull_request) [info tier:low] auto-success for tier:low
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m15s
CI / Canvas (Next.js) (pull_request) Successful in 11s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 6s
CI / Python Lint & Test (pull_request) Successful in 7s
Harness Replays / Harness Replays (pull_request) Successful in 7s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 10s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 8s
audit-force-merge / audit (pull_request) Successful in 24s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Failing after 1m32s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m8s
CI / Platform (Go) (pull_request) Failing after 5m3s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
CI / all-required (pull_request) Successful in 7s
RFC #2829 PR-1/4: GET /workspaces/:id/delegations previously queried only
activity_logs, returning [] for active/completed delegations while the agent's
check_delegation_status showed them correctly. The new delegations table
(migration 049) now holds durable state for active delegations.

The handler now tries the ledger first (delegations table), falls back to
activity_logs for pre-migration data, and returns [] only when both are empty.
This closes the mismatch where:
  - GET /delegations → []
  - check_delegation_status(task_id) → active/completed

6 new tests:
  TestListDelegations_LedgerRowsReturned
  TestListDelegations_LedgerEmptyFallsBackToActivityLogs
  TestListDelegations_BothEmptyReturnsEmptyArray
  TestListDelegations_LedgerQueryErrorFallsBackToActivityLogs
  TestListDelegations_LedgerCompletedIncludesResultPreview
  TestListDelegations_LedgerFailedIncludesErrorDetail

Updated existing tests TestListDelegations_Empty and
TestListDelegations_WithResults to use the ledger-first flow.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-13 21:50:03 +00:00
5043532d30 fix(go): remove ineffectual pgplugin index increment
Some checks failed
Harness Replays / detect-changes (pull_request) Successful in 14s
Lint curl status-code capture / Scan workflows for curl status-capture pollution (pull_request) Successful in 14s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 1m5s
review-check-tests / review-check.sh regression tests (pull_request) Successful in 19s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m21s
lint-continue-on-error-tracking / lint-continue-on-error-tracking (pull_request) Successful in 2m15s
Lint pre-flip continue-on-error / Verify continue-on-error flips have run-log proof (pull_request) Successful in 2m17s
Lint workflow YAML (Gitea-1.22.6-hostile shapes) / Lint workflow YAML for Gitea-1.22.6-hostile shapes (pull_request) Successful in 1m40s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 46s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 23s
qa-review / approved (pull_request) Failing after 25s
lint-required-context-exists-in-bp / lint-required-context-exists-in-bp (pull_request) Successful in 2m35s
gate-check-v3 / gate-check (pull_request) Successful in 38s
security-review / approved (pull_request) Failing after 26s
sop-checklist-gate / gate (pull_request) Successful in 26s
sop-tier-check / tier-check (pull_request) Successful in 23s
Ops Scripts Tests / Ops scripts (unittest) (pull_request) Successful in 1m32s
CI / Canvas (Next.js) (pull_request) Successful in 9s
sop-checklist / all-items-acked (pull_request) acked: 7/7
CI / Shellcheck (E2E scripts) (pull_request) Successful in 10s
CI / Python Lint & Test (pull_request) Successful in 13s
Harness Replays / Harness Replays (pull_request) Successful in 11s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 17s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 13s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 10s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m27s
audit-force-merge / audit (pull_request) Successful in 27s
CI / Platform (Go) (pull_request) Failing after 16m11s
CI / all-required (pull_request) Successful in 13s
2026-05-13 14:32:41 -07:00
5aa747241a fix(main): heal ADMIN_TOKEN placeholder in global_secrets on startup (#831)
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 17s
Harness Replays / detect-changes (pull_request) Successful in 22s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 19s
qa-review / approved (pull_request) Failing after 23s
security-review / approved (pull_request) Failing after 24s
E2E API Smoke Test / detect-changes (pull_request) Successful in 1m1s
CI / Detect changes (pull_request) Successful in 1m4s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 1m8s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 1m4s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m18s
Harness Replays / Harness Replays (pull_request) Successful in 6s
CI / Canvas (Next.js) (pull_request) Successful in 7s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 6s
CI / Python Lint & Test (pull_request) Successful in 17s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 12s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 14s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Failing after 1m17s
gate-check-v3 / gate-check (pull_request) Successful in 34s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
sop-checklist-gate / gate (pull_request) Successful in 25s
sop-tier-check / tier-check (pull_request) Successful in 24s
CI / Platform (Go) (pull_request) Failing after 4m2s
CI / all-required (pull_request) Successful in 6s
sop-checklist / all-items-acked (pull_request) acked: 7/7
audit-force-merge / audit (pull_request) Successful in 40s
Issue #831: integration-tester workspace (33bb2f71) has
ADMIN_TOKEN="placeholder-will-ask-for-real" in its container env
because loadWorkspaceSecrets reads ALL rows from global_secrets and
injects them into every workspace container.

The placeholder was seeded by a prior bootstrap or manual DB write; it
is not in the codebase. The correct ADMIN_TOKEN lives in the platform's
host environment (os.Getenv) but was never propagated to global_secrets.

The fix adds fixAdminTokenPlaceholder() which runs once at platform
startup (SaaS tenants only, cpProv != nil):

1. Reads the real ADMIN_TOKEN from the host environment.
2. Reads the current global_secrets value and decrypts it.
3. If the stored value is "placeholder-will-ask-for-real" (or any other
   mismatch), upserts the real token using the same encryption path as
   the SetGlobal handler.
4. Logs the action taken so operators can audit the fix.

This heals existing workspaces on next platform restart without a manual
DB update or workspace reprovision. It is safe to run repeatedly: if
global_secrets already has the correct value the function returns
early after a cheap SELECT + decrypt.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-13 21:09:47 +00:00
b9ca3b0653 fix(provisioner): inject ADMIN_TOKEN into workspace container env (core#831)
Some checks failed
Block internal-flavored paths / Block forbidden paths (pull_request) Successful in 14s
CI / Detect changes (pull_request) Successful in 34s
E2E Staging SaaS (full lifecycle) / E2E Staging SaaS (pull_request) Has been skipped
Harness Replays / detect-changes (pull_request) Successful in 20s
E2E API Smoke Test / detect-changes (pull_request) Successful in 1m23s
E2E Staging SaaS (full lifecycle) / pr-validate (pull_request) Successful in 52s
E2E Staging Canvas (Playwright) / detect-changes (pull_request) Successful in 1m14s
Handlers Postgres Integration / detect-changes (pull_request) Successful in 1m5s
Secret scan / Scan diff for credential-shaped strings (pull_request) Successful in 15s
qa-review / approved (pull_request) Successful in 18s
security-review / approved (pull_request) Failing after 20s
Runtime PR-Built Compatibility / detect-changes (pull_request) Successful in 39s
lint-required-no-paths / lint-required-no-paths (pull_request) Successful in 1m12s
CI / Shellcheck (E2E scripts) (pull_request) Successful in 11s
CI / Python Lint & Test (pull_request) Successful in 10s
CI / Canvas (Next.js) (pull_request) Successful in 15s
Harness Replays / Harness Replays (pull_request) Successful in 10s
E2E Staging Canvas (Playwright) / Canvas tabs E2E (pull_request) Successful in 12s
Handlers Postgres Integration / Handlers Postgres Integration (pull_request) Successful in 9s
Runtime PR-Built Compatibility / PR-built wheel + import smoke (pull_request) Successful in 10s
E2E API Smoke Test / E2E API Smoke Test (pull_request) Successful in 2m25s
CI / Canvas Deploy Reminder (pull_request) Has been skipped
sop-checklist / all-items-acked (pull_request) acked: 7/7
sop-checklist-gate / gate (pull_request) Successful in 42s
gate-check-v3 / gate-check (pull_request) Failing after 56s
sop-tier-check / tier-check (pull_request) Successful in 36s
CI / Platform (Go) (pull_request) Failing after 9m42s
CI / all-required (pull_request) Successful in 5s
audit-force-merge / audit (pull_request) Successful in 29s
CPProvisioner.Start() reads ADMIN_TOKEN from os.Getenv() and uses it for
CP→platform HTTP auth, but never passes it to the workspace container's
runtime env. Without ADMIN_TOKEN in the container, the integration-tester
workspace (ID: 33bb2f71) gets 401 from /admin/liveness, blocking Gate 5
and the release promotion cycle.

Fix (CP/SaaS mode): inject p.adminToken into the Env map sent to the
control plane so it reaches the EC2 instance's container env.

Fix (Docker/local mode): inject os.Getenv("ADMIN_TOKEN") from the
platform server into the Docker container env via buildContainerEnv. This
mirrors the SaaS path so any workspace in any mode can reach
/admin/liveness.

Safe: both paths only inject when ADMIN_TOKEN is non-empty (Docker/local
dev without ADMIN_TOKEN set is unaffected; the platform server's env
carries it in SaaS/prod).

Refs: core#831

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-13 21:05:02 +00:00
093b6df3dc fix(ci): repair handler test compile drift 2026-05-13 20:31:27 +00:00