molecule-core/workspace-server/internal
Molecule AI Fullstack Engineer e908772bcc
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
fix(handlers): fix 3 test regressions + bring PR#956 security tests to staging
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
..
artifacts
buildinfo feat(deploy): verify each tenant /buildinfo matches published SHA after redeploy 2026-04-30 10:55:08 -07:00
bundle fix(staging): resolve 3 go vet failures 2026-05-13 09:50:45 +00:00
channels fix(platform): clear golangci-lint findings 2026-05-12 22:53:22 -07:00
crypto
db fix(bundle): markFailed sets last_sample_error + AST gate 2026-05-04 21:08:08 -07:00
envx
events fix(platform): clear golangci-lint findings 2026-05-12 22:53:22 -07:00
handlers fix(handlers): fix 3 test regressions + bring PR#956 security tests to staging 2026-05-14 05:26:13 +00:00
imagewatch fix(workspace-server): respect MOLECULE_IMAGE_REGISTRY in imagewatch + admin_workspace_images (RFC #229 P2-4) 2026-05-10 04:21:27 -07:00
memory fix(go): remove ineffectual pgplugin index increment 2026-05-13 14:32:41 -07:00
messagestore feat(canvas/chat-server): canvas consumes /chat-history + server-side row-aware reverse (RFC #2945 PR-C-2) 2026-05-06 16:55:00 -07:00
metrics feat(rfc): poll-mode chat upload — phase 3 GC sweep + observability 2026-05-05 05:00:13 -07:00
middleware fix(platform): clear golangci-lint findings 2026-05-12 22:53:22 -07:00
models test(models+handlers): add delivery mode + workspace status coverage 2026-05-13 16:14:09 +00:00
orgtoken
pendinguploads fix(pendinguploads): accept done channel in StartSweeperWithIntervalForTest 2026-05-11 21:15:49 +00:00
plugins fix(platform): clear golangci-lint findings 2026-05-12 22:53:22 -07:00
provisioner fix(provisioner): inject ADMIN_TOKEN into workspace container env (core#831) 2026-05-13 21:05:02 +00:00
provlog feat(workspace-server): structured logging at provisioning boundaries 2026-05-05 12:30:11 -07:00
registry chore: reconcile main → staging post-suspension divergence 2026-05-07 14:24:37 -07:00
router [core-lead-agent] fix(core#228): cascade fixes for PluginResolver — make main compile 2026-05-10 09:46:35 +00:00
scheduler fix(textutil): SSOT for rune-safe string truncation, fix 3 audit-gap bugs 2026-05-05 23:01:21 -07:00
supervised
textutil fix(textutil): SSOT for rune-safe string truncation, fix 3 audit-gap bugs 2026-05-05 23:01:21 -07:00
ws chore: drop org_layout_test, hub.go, hub_test.go (already in staging with better coverage) 2026-05-13 18:04:00 +00:00
wsauth perf(wsauth): in-process cache for platform_inbound_secret reads 2026-05-03 00:04:38 -07:00