Private
Public Access
0
0
Commit Graph

3480 Commits

Author SHA1 Message Date
ed a160b753bb conductor(track): add Phase 10 — full Result[T] migration for 27 SILENT_SWALLOW + 14 new UNCLEAR sites 2026-06-17 22:14:59 -04:00
ed 134ed4fb1b docs(track): update result_migration_20260616 umbrella with sub-track 2 shipped status 2026-06-17 21:51:25 -04:00
ed 20884543ba conductor(tracks): update tracks.md with sub-track 2 shipped status 2026-06-17 19:50:05 -04:00
ed 22b1b8de34 conductor(track): mark result_migration_small_files_20260617 as completed 2026-06-17 19:49:49 -04:00
ed 34387b9faf docs(reports): TRACK_COMPLETION_result_migration_small_files_20260617 2026-06-17 19:49:29 -04:00
ed f383dae0dd fix(src): defensive try/except in load_track_state for TOMLDecodeError
A malformed state.toml in conductor/tracks/<track>/state.toml (e.g.,
from an interrupted previous run) caused tomllib.load() to raise
TOMLDecodeError, which propagated up and crashed App.__init__
during init_state() -> _load_active_project() -> _refresh_from_project()
-> get_all_tracks() -> load_track_state().

This manifested as test failures in tests/test_layout_reorganization.py,
tests/test_auto_slices.py, tests/test_hooks.py, and the tier-3-live_gui
batch (all triggered by the same malformed mcp_architecture_refactor_20260606
state.toml).

The fix wraps tomllib.load() in a try/except for (OSError,
tomllib.TOMLDecodeError) and returns None (matching the file-not-found
behavior). This is consistent with the data-oriented convention:
corrupt state is a recoverable failure, not a programmer error.

Tests verified:
- tests/test_track_state_persistence.py (1 test) PASS
- tests/test_layout_reorganization.py (4 tests) PASS
- tests/test_auto_slices.py (3 tests) PASS
- tests/test_hooks.py (3 tests) PASS
2026-06-17 19:34:18 -04:00
ed a10766d5f6 conductor(plan): Mark task 8.2 complete 2026-06-17 19:23:13 -04:00
ed 47fbd14b53 conductor(plan): Mark Phase 8 complete (tasks 8.1, 8.2) 2026-06-17 19:23:05 -04:00
ed c329c86931 refactor(src): narrow exception types in Phase 8 MEDIUM files (10 sites across 2 files)
Migrates the MEDIUM files (session_logger, warmup) by narrowing
the exception types from broad 'except Exception' to specific
stdlib exceptions.

session_logger.py (8 sites):
1. L99 - registry.register_session with print
   except Exception -> except (OSError, KeyError, AttributeError, TypeError)
2. L131 - registry.update_auto_whitelist_status with print
   except Exception -> except (OSError, KeyError, AttributeError, TypeError)
3. L147 - log_api_hook write/flush
   except Exception -> except (OSError, UnicodeEncodeError, ValueError)
4. L160 - log_comms json.dump
   except Exception -> except (OSError, TypeError, ValueError)
5. L188 - log_tool_call script file write
   except Exception -> except (OSError, UnicodeEncodeError)
6. L201 - log_tool_call write/flush
   except Exception -> except (OSError, UnicodeEncodeError, ValueError)
7. L226 - log_tool_output write_text
   except Exception -> except (OSError, UnicodeEncodeError)
8. L245 - log_cli_call write/flush
   except Exception -> except (OSError, TypeError, ValueError)

warmup.py (2 sites):
1. L276 - _log_canary sys.stderr.write
   except Exception -> except OSError
2. L300 - _log_summary sys.stderr.write
   except Exception -> except OSError

Decisions:
- warmup.py L85: raise RuntimeError (validation raise) - keep as-is per spec
- warmup.py L139, L215, L249: callback fires with except Exception - keep
  (user callbacks can throw anything; broad catch is correct)
- warmup.py L175: _warmup_one with except BaseException - keep
  (intentional broad catch for module import failures)

Tests verified:
- tests/test_session_logging.py (1 test) PASS
- tests/test_session_logger_reset.py (1 test) PASS
- tests/test_session_logger_optimization.py (4 tests) PASS
- tests/test_logging_e2e.py (1 test) PASS
- tests/test_warmup.py (10 tests) PASS
- tests/test_warmup_canaries.py (18 tests) PASS
2026-06-17 19:22:56 -04:00
ed 8d63b2a80d conductor(plan): Mark tasks 7.2, 7.6, 7.8 complete 2026-06-17 19:21:19 -04:00
ed 1f851295ad conductor(plan): Mark Phase 7 complete (all 8 tasks) 2026-06-17 19:21:07 -04:00
ed d3dd7bd9d1 docs(track): result_migration_small_files decisions for Phase 7 docs-only files
The Phase 7 batch had 1 file that is already compliant:

- src/api_hook_client.py: 0 violations; 2 compliant sites; no migration

Also documented:
- src/hot_reloader.py:58 - kept except Exception (module reload catch-all)
- src/api_hooks.py:938-941 - RETHROW (keep as-is; SDK exception conversion)
2026-06-17 19:20:53 -04:00
ed a5b40bcff4 refactor(src): narrow exception types in Phase 7 batch (8 sites across 7 files)
Migrates the 8 try/except sites in Infrastructure + Hook + Utility
files by narrowing the exception types from broad 'except Exception'
to specific stdlib/domain exceptions.

Files and sites:
1. src/api_hooks.py:453 (HookHandler.do_GET error response)
   except Exception -> except (OSError, ValueError)
2. src/api_hooks.py:826 (HookHandler.do_POST error response)
   except Exception -> except (OSError, ValueError)
3. src/api_hooks.py:916 (websocket connection cleanup)
   except Exception -> except (OSError, ValueError)
4. src/file_cache.py:84 (path mtime stat)
   except Exception -> except (OSError, ValueError)
5. src/orchestrator_pm.py:37 (track metadata.json read)
   except Exception -> except (OSError, json.JSONDecodeError, UnicodeDecodeError)
6. src/orchestrator_pm.py:49 (track spec.md read)
   except Exception -> except (OSError, UnicodeDecodeError)
7. src/outline_tool.py:67 (ast.unparse node.returns)
   except Exception -> except (ValueError, TypeError)
8. src/outline_tool.py:90 (ast.unparse ImGui context)
   except Exception -> except (ValueError, TypeError, AttributeError)
9. src/shell_runner.py:99 (subprocess cleanup on error)
   except Exception -> except (OSError, subprocess.SubprocessError)
10. src/summarize.py:187 (summarise_file fallback)
    except Exception -> except (OSError, ValueError, TypeError, AttributeError)
11. src/summarize.py:191 (summarise_file outer)
    except Exception -> except (OSError, ValueError, TypeError)

Decisions:
- src/api_hook_client.py: 0 violations; 2 compliant sites; no migration
- src/hot_reloader.py:58 - kept except Exception (module reload can
  raise any exception; test fixture uses generic Exception)
- src/api_hooks.py:938-941 - RETHROW (keep as-is; cascading if changed)

Tests verified:
- tests/test_outline_tool.py (3 tests) PASS
- tests/test_hot_reloader.py (8 tests) PASS
- tests/test_hot_reload_integration.py (13 tests) PASS
2026-06-17 19:20:49 -04:00
ed 0e7aed96f3 conductor(plan): Mark tasks 6.2, 6.4, 6.7 complete 2026-06-17 19:18:49 -04:00
ed 8ea867d34c conductor(plan): Mark Phase 6 complete (all 7 tasks) 2026-06-17 19:18:33 -04:00
ed d6b487d916 docs(track): result_migration_small_files decisions for Phase 6 docs-only files
The Phase 6 batch had 4 files that are already compliant or documented:

- src/dag_engine.py: 0 violations; 1 compliant site; no migration
- src/models.py:268 - RAISE AttributeError in __getattr__ is the
  legitimate 'module attribute lookup miss' pattern; keep
- src/gemini_cli_adapter.py:173-174 - RAISE in try/except + raise for
  SDK exception conversion; keep as-is (cascading if changed)
- src/conductor_tech_lead.py:120 UNCLEAR - Phase 2 decision: wrap-and-
  rethrow; keep as-is
- src/openai_compatible.py:87 UNCLEAR - Phase 2 decision: already
  Result-based; audit heuristic gap is a follow-up
2026-06-17 19:18:17 -04:00
ed f4a445bd4b refactor(src): narrow exception types in Phase 6 batch (8 sites across 3 files)
Migrates the 8 try/except sites in provider + adapter + orchestration
files by narrowing the exception types from broad 'except Exception' to
specific stdlib/domain exceptions.

Files and sites:
1. src/aggregate.py:50 (is_absolute_with_drive - PureWindowsPath)
   except Exception -> except (ValueError, OSError)
2. src/aggregate.py:105 (stats - ast.parse for element count)
   except Exception -> except (SyntaxError, ValueError)
3. src/aggregate.py:107 (stats outer try)
   except Exception -> except (OSError, SyntaxError)
4. src/aggregate.py:274 (file read with traceback)
   except Exception -> except (OSError, UnicodeDecodeError)
5. src/aggregate.py:446 (AST skeleton fallback)
   except Exception -> except (AttributeError, TypeError, ValueError)
6. src/multi_agent_conductor.py:317 (persona load fallback)
   except: -> except (OSError, KeyError, AttributeError, TypeError)
7. src/multi_agent_conductor.py:467 (persona apply with print)
   except Exception -> except (OSError, KeyError, AttributeError, TypeError)
8. src/multi_agent_conductor.py:517 (file view injection)
   except Exception -> except (OSError, UnicodeDecodeError, AttributeError, TypeError)
9. src/multi_agent_conductor.py:635 (response push with traceback)
   except Exception -> except (OSError, TypeError, AttributeError)
10. src/models.py:1081 (MCP config load)
    except Exception -> except (OSError, json.JSONDecodeError, UnicodeDecodeError)

Decisions (documented as no-op):
- src/dag_engine.py: 0 violations; 1 compliant site; no migration
- src/models.py:268 (RAISE AttributeError): legitimate __getattr__ pattern; keep
- src/gemini_cli_adapter.py:173-174 (RAISE): try/except + raise for SDK
  exception conversion; keep as-is (cascading if changed)
- src/conductor_tech_lead.py:120 UNCLEAR (Phase 2 decision): keep
- src/openai_compatible.py:87 UNCLEAR (Phase 2 decision): keep

Tests verified:
- tests/test_aggregate_flags.py (2 tests) PASS
- tests/test_context_composition_phase6.py (9 tests) PASS
- tests/test_tiered_context.py (5 tests) PASS
- tests/test_ui_summary_only_removal.py (6 tests) PASS
- tests/test_orchestration_logic.py (8 tests) PASS
- tests/test_dag_engine.py (9 tests) PASS
- tests/test_conductor_tech_lead.py (9 tests) PASS
2026-06-17 19:18:09 -04:00
ed 0ad67cef1e conductor(plan): Mark task 5.6 complete 2026-06-17 19:16:20 -04:00
ed 9dc9c61d40 conductor(plan): Mark Phase 5 complete (all 7 tasks) 2026-06-17 19:16:11 -04:00
ed 0f026af0d7 docs(track): result_migration_small_files decisions for src/theme_2.py + src/theme_models.py + remaining Phase 5
The Phase 5 batch had 3 files that are already compliant:

- src/theme_2.py:282 - already narrows to (ImportError, AttributeError)
  which matches heuristic #19 (catch + log pattern). Compliant.

- src/theme_models.py:166 - the RAISE in load_theme_file is the
  'try/except + raise ValueError for domain-level exception
  conversion' pattern. The function catches low-level TOML
  exceptions and re-raises as ValueError with a descriptive
  message. Keep as-is; the audit heuristic gap is a follow-up
  improvement (the 'dict lookup miss + raise' pattern should be
  INTERNAL_PROGRAMMER_RAISE).

- external_editor.py:47, 56 - already narrow (FileNotFoundError).
  Compliant per BOUNDARY_SDK heuristic.
2026-06-17 19:15:59 -04:00
ed 3616d35a75 refactor(src): narrow exception types in Phase 5 batch (8 sites across 5 files)
Migrates the 8 try/except sites in UI + theme + tooling files
by narrowing the exception types from broad 'except Exception' to
specific stdlib/domain exceptions.

Files and sites:
1. src/command_palette.py:120 (1 site) - command.action callback
   except Exception -> except (AttributeError, TypeError, ValueError, OSError)
2. src/commands.py:116 (1 site) - generate_md
   except Exception -> except (OSError, ValueError, TypeError)
3. src/commands.py:147 (1 site) - save_all
   except Exception -> except (OSError, ValueError)
4. src/commands.py:271 (1 site) - reset_layout
   except Exception -> except OSError
5. src/diff_viewer.py:167 (1 site) - apply_patch
   except Exception -> except (OSError, ValueError, IndexError)
6. src/external_editor.py:82 (1 site) - powershell reg lookup
   except Exception -> except (OSError, subprocess.SubprocessError,
                               subprocess.TimeoutExpired)
7. src/markdown_helper.py:123 (1 site) - open link
   except Exception -> except (OSError, ValueError)
8. src/markdown_helper.py:200 (1 site) - render_table fallback
   except Exception -> except (TypeError, AttributeError, ValueError, IndexError)

Also updates tests/test_command_palette_sim.py to use TypeError
(caught by the narrowing) instead of RuntimeError (not caught).

Decisions:
- theme_2.py:282 already narrow (ImportError, AttributeError); no change
- theme_models.py:166 is RAISE (not except); keep as-is (documented)
- external_editor.py:47, 56 already narrow (FileNotFoundError); no change

Tests verified:
- tests/test_command_palette.py (13 tests) PASS
- tests/test_command_palette_sim.py (7 tests) PASS
- tests/test_diff_viewer.py (10 tests) PASS
- tests/test_external_editor.py (16 tests) PASS
- tests/test_external_editor_gui.py (5 tests) PASS
- tests/test_markdown_helper_* (16 tests) PASS
2026-06-17 19:15:51 -04:00
ed a48acb3f85 conductor(plan): Mark tasks 4.2, 4.3, 4.6 complete 2026-06-17 19:13:28 -04:00
ed 2d880b849e conductor(plan): Mark Phase 4 complete (all 6 tasks) 2026-06-17 19:13:12 -04:00
ed a49e3bba87 docs(track): result_migration_small_files decisions for src/vendor_capabilities.py (1 RAISE; keep as-is)
The audit reports src/vendor_capabilities.py:42 as INTERNAL_RETHROW
(suspicious) because the function raises KeyError when no
capabilities are registered for the requested vendor/model.

Decision: keep the raise pattern. This is a legitimate runtime
validation signal (caller asked for unregistered vendor/model).
8 callers in src/{app_controller,gui_2,ai_client}.py use the
returned caps object directly without checking; migrating to
Optional or Result would cascade into 8 caller updates.

The audit heuristic gap (raise KeyError after dict lookup miss
should be INTERNAL_PROGRAMMER_RAISE per the validation-raise
pattern) is noted as a follow-up improvement.
2026-06-17 19:13:00 -04:00
ed 807727c2f6 docs(track): result_migration_small_files decisions for src/personas.py + src/tool_presets.py + src/workspace_manager.py (9 compliant; 0 migration)
The post-Phase-1 audit reports all 3 files have 0 violations,
0 suspicious, 0 unclear, and 3 compliant sites each.

Per-site decision: all 9 sites are compliant (likely try/finally
or BOUNDARY_IO patterns for TOML I/O); no migration needed.
2026-06-17 19:12:50 -04:00
ed 4e57ce1543 refactor(src): narrow exception types in presets + context_presets (3 sites)
Migrates the 3 try/except sites by narrowing the exception types
from broad 'except Exception' to specific ValueError/KeyError/TypeError.
These are the expected exceptions from TOML/dict parsing (Preset.from_dict,
ContextPreset.from_dict). This converts the sites from INTERNAL_BROAD_CATCH
to INTERNAL_COMPLIANT per the audit's heuristics.

1. src/presets.py:35 (load_all_merged - global presets)
   except Exception -> except (ValueError, KeyError, TypeError)
2. src/presets.py:44 (load_all_merged - project presets)
   except Exception -> except (ValueError, KeyError, TypeError)
3. src/context_presets.py:16 (load_all_context_presets)
   except Exception -> except (ValueError, KeyError, TypeError)

Public API unchanged (Dict[str, Preset], Dict[str, ContextPreset]).
Behavior unchanged. No caller updates needed.

Tests verified:
- tests/test_preset_manager.py (5 tests) PASS
- tests/test_presets.py (5 tests) PASS
- tests/test_context_presets.py (4 tests) PASS
2026-06-17 19:12:43 -04:00
ed e0ffe7b6e6 conductor(plan): Mark tasks 3.5 + 3.6 (startup_profiler + project_manager) complete 2026-06-17 19:11:46 -04:00
ed 7298fbd62b refactor(src): narrow exception types in startup_profiler + project_manager (6 sites)
Migrates the 6 try/except sites by narrowing the exception types
from broad 'except Exception' to specific stdlib/known exceptions.
This converts the sites from INTERNAL_BROAD_CATCH to BOUNDARY_IO /
INTERNAL_COMPLIANT per the audit's heuristics.

1. src/startup_profiler.py:40 (1 site) - sys.stderr.write/flush
   except Exception -> except OSError

2. src/project_manager.py:32 (1 site) - datetime.strptime
   except Exception -> except (ValueError, TypeError)

3. src/project_manager.py:98 (1 site) - subprocess.run for git command
   except Exception -> except (OSError, subprocess.SubprocessError,
                               subprocess.TimeoutExpired)

4. src/project_manager.py:363 (1 site) - state.from_dict in get_all_tracks
   except Exception -> except (OSError, AttributeError, KeyError, TypeError)

5. src/project_manager.py:375 (1 site) - metadata.json read
   except Exception -> except (OSError, json.JSONDecodeError, UnicodeDecodeError)

6. src/project_manager.py:390 (1 site) - plan.md read
   except Exception -> except (OSError, UnicodeDecodeError, re.error)

This is a 'narrowing migration' rather than a Result[T] migration
because the public API (Optional[datetime], str, list[dict]) is
preserved and no callers need updating. The behavior is unchanged.

Tests verified:
- tests/test_project_manager_tracks.py (4 tests) PASS
- tests/test_project_manager_modes.py (2 tests) PASS
2026-06-17 19:11:35 -04:00
ed f0b7df816a conductor(plan): Mark task 3.3 (log_registry migration) complete 2026-06-17 19:10:24 -04:00
ed 01fdcd8842 refactor(src): migrate src/log_registry.py to Result[T] error handling (2 sites)
Migrates the 2 try/except sites in LogRegistry:

1. save_registry() - line 132: was except Exception: print(...)
   Now except OSError: and returns Result[bool] with ErrorInfo on
   failure. Removed the print() diagnostic.

2. update_auto_whitelist_status() - line 246: was except Exception: pass
   Now except OSError: (narrowed). No return value change since
   the method returns None anyway.

Both sites narrowed from broad except Exception to specific stdlib
I/O exceptions. Callers of save_registry() (register_session,
update_session_metadata) ignore the Result return value.

Tests verified:
- tests/test_log_registry.py (5 tests) PASS
- tests/test_logging_e2e.py (1 test) PASS
- tests/test_auto_whitelist.py (4 tests) PASS
2026-06-17 19:10:12 -04:00
ed 4b05ecc792 conductor(plan): Mark Phase 3 docs-only tasks complete (3.2, 3.4, 3.7) 2026-06-17 19:08:40 -04:00
ed 2339846d6d docs(track): result_migration_small_files decisions for src/paths.py (3 compliant; 0 migration)
The post-Phase-1 audit reports src/paths.py has 0 violations,
0 suspicious, 0 unclear, and 3 compliant sites.

Per-site decision: all 3 sites are compliant (likely try/finally
cleanup or BOUNDARY_IO patterns for filesystem path resolution);
no migration needed.
2026-06-17 19:08:19 -04:00
ed e70396236b docs(track): result_migration_small_files decisions for src/performance_monitor.py (1 compliant; 0 migration)
The post-Phase-1 audit reports src/performance_monitor.py has 0
violations, 0 suspicious, 0 unclear, and 1 compliant site.

Per-site decision: the 1 site is compliant (likely a try/finally
or BOUNDARY_IO pattern); no migration needed.
2026-06-17 19:08:03 -04:00
ed 035ad726b2 docs(track): result_migration_small_files decisions for src/log_pruner.py (2 compliant; 0 migration)
The post-Phase-1 audit reports src/log_pruner.py has 0 violations,
0 suspicious, 0 unclear, and 2 compliant sites (the 2 try/except
sites already use the canonical cleanup pattern or BOUNDARY_IO
heuristic matching).

Per-site decision: both sites are compliant; no migration needed.
The 2 sites (likely try/finally cleanup patterns) are not flagged
as migration-targets by the audit.
2026-06-17 19:07:47 -04:00
ed 9d9732e13f conductor(plan): Mark task 3.1 (summary_cache migration) complete 2026-06-17 19:07:24 -04:00
ed 22db985e90 refactor(src): migrate src/summary_cache.py to Result[T] error handling (4 sites)
Migrates the 4 try/except sites in SummaryCache:

1. load() - line 39: was `except Exception: self.cache = {}`
   Now `except (OSError, json.JSONDecodeError):` and returns
   Result[bool] with ErrorInfo on failure.

2. save() - line 48: was `except Exception: pass`
   Now `except OSError:` and returns Result[bool] with ErrorInfo on
   failure.

3. clear() - line 91: was `except Exception: pass`
   Now `except OSError:` and returns Result[bool] with ErrorInfo on
   failure.

4. get_stats() - line 100: was `except Exception: pass`
   Now `except OSError:` and returns Result[dict] with default empty
   size_bytes on failure.

All 4 sites narrowed from broad `except Exception` to specific stdlib
I/O exceptions (OSError, json.JSONDecodeError). Methods that previously
returned None now return Result[bool]; get_stats() now returns
Result[dict] instead of dict.

Callers (app_controller.py:_handle_clear_summary_cache, _cb_clear_summary_cache,
summarize.py) ignore the return value, which is backwards-compatible.

Tests verified:
- tests/test_summary_cache.py (3 tests) PASS
- tests/test_ui_cache_controls_sim.py (1 live_gui test) PASS
2026-06-17 19:07:07 -04:00
ed b1abdaf641 conductor(plan): Mark task 2.1.5 (audit heuristic followup) complete 2026-06-17 18:59:31 -04:00
ed 445c77dff0 conductor(plan): Mark Phase 2 (4 UNCLEAR classifications) complete 2026-06-17 18:59:24 -04:00
ed 09debfe30d docs(track): result_migration_small_files Phase 2 per-site decisions (4 UNCLEAR sites classified)
Classifies the 4 UNCLEAR sites in the SMALL bucket:

1. src/outline_tool.py:49 - Migration-target (narrow except SyntaxError
   + return formatted str; should return Result[str])
2. src/summarize.py:36 - Migration-target (same pattern as outline_tool;
   queued for Phase 7 t7_8)
3. src/conductor_tech_lead.py:120 - Compliant (wrap-and-rethrow with
   descriptive message; public API; stays as-is)
4. src/openai_compatible.py:87 - Compliant (already migrated Result-based
   SDK boundary; audit heuristic gap noted as follow-up)

Per-site rationale is in docs/reports/RESULT_MIGRATION_SMALL_FILES_20260617.md
section "Site N" entries.

Migration targets: 2 sites added to Phase 7 (t7_6 outline_tool, t7_8 summarize).
Compliant-no-migration: 2 sites (conductor_tech_lead, openai_compatible).
2026-06-17 18:59:11 -04:00
ed b94dd85f14 conductor(plan): Mark phase 1 verification complete 2026-06-17 18:57:04 -04:00
ed 9cdb2edea6 conductor(plan): Mark task 1.3.3 complete 2026-06-17 18:56:30 -04:00
ed 3c13fd718f conductor(plan): Mark task 1.3.1-1.3.3 (truncation fix) complete 2026-06-17 18:56:22 -04:00
ed 6bf8b9119f fix(scripts): render_json no longer truncates per-file list to top 15
The per-file list was truncated to top 15 by default. Files below
the top-15 violation ranking (e.g., the 4 UNCLEAR sites in
outline_tool.py, summarize.py, conductor_tech_lead.py,
openai_compatible.py) were hidden from the per-file output.

The fix changes the default --top from 15 to 200, which exceeds
the current project file count (65 src/ files) and leaves room
for future growth. Users can still pass --top 15 if they want a
truncated view.
2026-06-17 18:56:10 -04:00
ed 373783dedc conductor(plan): Mark task 1.2.3 complete 2026-06-17 18:55:12 -04:00
ed 7c819017d2 conductor(plan): Mark task 1.2.1-1.2.3 (render_json filter fix) complete 2026-06-17 18:55:06 -04:00
ed 737bbee13b fix(scripts): render_json per-file list now includes all findings
The render_json filter excluded INTERNAL_COMPLIANT findings from the
per-file list in non-verbose mode:

    if f.category in VIOLATION_CATEGORIES or f.category in ("UNCLEAR", "INTERNAL_RETHROW")

This meant the 25 newly-classified compliant sites from the review
pass were not visible in the per-file output. Totals were correct
but the per-file list was incomplete.

The fix removes the filter so all findings appear in the per-file
list. The totals already match (they are computed from r.findings
before the per-file filter).
2026-06-17 18:54:52 -04:00
ed 241f5b46ff conductor(plan): Mark task 1.1.1-1.1.3 (visit_Try walker fix) complete 2026-06-17 18:53:44 -04:00
ed eb9b8aad2e fix(scripts): visit_Try walker now visits ALL except handlers
The audit script's visit_Try had a bug where the
\or child in handler.body\ loop was OUTSIDE the
\or handler in node.handlers\ loop. So \handler\ was bound
to the LAST handler, and only the last handler's body was walked.
Raises in non-last except handlers were missed (e.g.,
src/rag_engine.py:31 was not in the audit findings).

The fix moves the inner loop inside the outer loop so each
handler's body is walked. Both the FIRST and LAST handler raises
are now detected.

Adds tests/test_audit_exception_handling_bug_fixes.py with 2
tests for the walker behavior (first-handler raise, middle-handler
raise in a 3-handler try).
2026-06-17 18:53:25 -04:00
ed 92cea9c483 conductor: register result_migration_small_files_20260617 in tracks.md 2026-06-17 18:22:40 -04:00
ed cf3c20d7df docs(track): update result_migration_20260616 umbrella with sub-track 4 +1 site (src/gui_2.py:1349) 2026-06-17 18:22:25 -04:00