Skip to content

Conversation

@deanq
Copy link
Member

@deanq deanq commented Feb 2, 2026

Prerequisite: #164

Summary

Removes deprecated handler generator code, adds comprehensive verification scripts, and includes bug fixes and refactoring for the deployment pipeline.

Changes

Handler Generator Deprecation & Cleanup

  • Remove deprecated handler generator files
  • Clean up handler file generation references from documentation and tests
  • Simplify build and deployment pipeline

Verification Scripts

  • Add comprehensive verification scripts for image constants consistency
  • Ensure Docker image configuration alignment across deployment environments

Refactoring

  • Centralize Docker image constants in dedicated configuration module
  • Clean up documentation and test fixtures

Test Status

All tests pass with deprecated patterns removed.

deanq and others added 30 commits January 28, 2026 07:39
- Add Python AST indexer (ast_to_sqlite.py) to extract framework symbols
- Add fast query CLI interface (code_intel.py) with Rich formatted output
- SQLite database with optimized indexes for symbol lookup
- Extract classes, functions, methods, decorators, type hints, docstrings
- Update Makefile with index/query targets
- Update CONTRIBUTING.md with setup and usage documentation
- Performance: 466 symbols indexed in 0.09s, database size 260KB
- Reduces token usage by ~85% when exploring framework structure

Commands:
  make index              - Generate/update code intelligence index
  make query SYMBOL=name  - Find symbol by name
  make query-classes      - List all classes
  make query-all          - List all symbols
…ude Code

Adds Model Context Protocol (MCP) server integration to expose the SQLite code
intelligence database as native Claude Code tools. This enables Claude to query
framework symbols, classes, and structure without reading full files, reducing
token usage by ~85% for code exploration tasks.

## Changes

- Add mcp_code_intel_server.py: MCP server with 5 specialized tools
  - find_symbol: Search for classes, functions, methods
  - list_classes: Browse all framework classes
  - get_class_interface: View class methods without implementations
  - list_file_symbols: Explore file structure
  - find_by_decorator: Find decorated symbols

- Create .mcp.json: MCP server configuration for automatic Claude Code discovery
- Add tetra-explorer skill: Guidance for using code intelligence tools
- Update CONTRIBUTING.md: Document MCP integration for developers
- Add mcp>=1.0.0 dependency to pyproject.toml
- Update .gitignore for .claude/ directory

## Benefits

- Zero-configuration Claude Code integration via MCP
- 85% token reduction for code exploration (from ~10k to ~2k tokens)
- <10ms query performance with SQLite indexing
- Type-safe tool interfaces with MCP schemas
- Automatic tool discovery by Claude Code

## Technical Details

- Database: 466 symbols indexed from tetra-rp source
- Storage: .code-intel/flash.db (~250KB)
- Transport: stdio for Claude Code integration
- Python 3.10+ compatible

All quality checks passed. Tests: 34 passed, code coverage: 68.78%
Allow additional open-source licenses used by transitive dependencies:
- Python-2.0: Python standard library and some tools
- Unlicense: Some utility libraries
- MPL-2.0: Some utility packages (certifi, pathspec)

These are all permissive licenses compatible with MIT distribution.
- Extract hardcoded LIMIT values into named constants for maintainability
- Rename handle_list_tools to list_tools for naming consistency
- Extract duplicated error handling into _log_indexing_error helper
- Add clarification about which dependencies require non-standard licenses
Implement two features for the code intelligence MCP server:

1. Smart Re-indexing
   - Index auto-rebuilds on MCP server startup when stale
   - Checks if any Python files in src/ changed since last index
   - Compares file mtimes against index_timestamp in metadata table
   - Triggers rebuilding only when necessary
   - Fast: only checks file mtimes, no AST parsing until rebuild needed

2. Test Output Parser MCP Tool
   - New tool parses pytest output and returns structured data
   - Extracts test summary (passed/failed/errors/skipped counts)
   - Lists failed tests with file locations and error messages
   - Parses coverage statistics if present
   - Returns markdown-formatted summary for easy reading
   - Reduces token usage by ~85% vs reading full test output

Changes to ast_to_sqlite.py:
- Track latest_file_mtime and file_count in metadata table
- Enables staleness detection in MCP server

Changes to mcp_code_intel_server.py:
- Add should_reindex() function for checking if index is stale
- Add smart re-indexing in main() before server starts
- Add parse_test_output() function to parse pytest output
- Add format_test_summary() for markdown formatting
- Add new parse_test_output MCP tool with clear description
- Tool description teaches Claude when/why to use it
- Add parse_test_output tool documentation with usage examples
- Add explicit prohibition of bash commands (tail/grep/cat) for MCP-compatible tasks
- Document bad patterns with token cost comparisons (99% reduction for test output)
- Expand skill file with:
  - Step 1.5: NEVER use bash commands for MCP tool tasks
  - Analyzing Test Results section with good/bad examples
  - Available MCP Tools reference list
  - Strong enforcement notes in Important Notes
- Add 200-token example showing difference between MCP tool vs bash approaches

This forces Claude Code to consistently use parse_test_output (~200 tokens) instead
of bash commands (~20,000+ tokens) when analyzing test output, reducing token usage
by 99% for test analysis workflows.
- Add .claude/settings.json with pre-approved permissions for all contributors
- Update code coverage requirement from 35% to 65% in CONTRIBUTING.md
- Simplify authors to generic Runpod email in pyproject.toml
- Remove empty [tool.ruff] section from pyproject.toml
- Remove outdated docs/PRD.md
- Update dependency lock file (uv.lock)
Manual dependency review during PR review is sufficient.
Removes automated license check that adds friction for legitimate dependencies.
The undeploy command was incorrectly showing NetworkVolumes in the
'Tracked RunPod Serverless Endpoints' list. NetworkVolumes are not
serverless endpoints and shouldn't be managed by the undeploy command.

Added _get_serverless_resources() filter function to exclude non-serverless
resources from undeploy operations. Updated test to use spec=ServerlessResource
for proper isinstance() checks.
Remove handler_generator.py, lb_handler_generator.py, and mothership_handler_generator.py along with their corresponding tests. The manifest builder no longer generates handler_file references, simplifying the build process and removing unused code generation.

- Delete deprecated handler generator modules and tests
- Update manifest tests to remove handler_file assertions
- Handler generation is now handled elsewhere in the deployment pipeline
- Delete docs/Runtime_Generic_Handler.md (handler architecture documentation)
- Remove handler_file fields from manifest examples
- Update build process documentation to remove handler generation steps
- Remove references to generated handler files in troubleshooting sections
- Update runtime architecture documentation to reflect current implementation
- Simplify build process documentation in README and cli docs

This cleanup reflects the removal of the handler generation system from the codebase,
as the runtime now discovers and registers functions dynamically at startup.

Fixes AE-1951
Remove handler_file fields from manifest fixture test data that were part
of deprecated handler file generation feature. These fields are no longer
used by any runtime code and remaining references only create confusion
about the manifest structure.

- Remove handler_file from test_service_registry.py fixtures (2 lines)
- Remove handler_file from test_cross_endpoint_routing.py fixtures (2 lines)
- Update outdated comment in test_manifest_mothership.py
Remove references to deprecated handler file generation feature from
documentation diagrams and build output examples:

- Flash_Deploy_Guide.md: Remove HandlerGenerator and LBHandlerGenerator
  from build phase diagrams, update flow to show Scanner going directly
  to ManifestBuilder
- LoadBalancer_Runtime_Architecture.md: Update deployment lifecycle to
  reflect packaging instead of handler generation
- flash-build.md: Update build output to show manifest creation and
  resource registration instead of handler generation
Move all Docker image constants from live_serverless.py to constants.py
to establish a single source of truth. This enables environment variable
overrides for testing and deployment flexibility, and eliminates scattered
hardcoded image names throughout the codebase.

- Centralized TETRA_*_IMAGE constants with env var support
- Added DEFAULT_WORKERS_MIN/MAX constants for consistent defaults
- Updated live_serverless.py to import from constants
- Updated manifest.py to use centralized image constants
- Updated test_mothership.py to respect environment overrides
- All 856 tests pass with 68.74% coverage
…ants fix

Add three verification scripts and documentation to validate the Docker image
constant configuration fix:

scripts/test-image-constants.py:
  - Quick, focused Python verification script
  - Tests constant definitions, manifest builder integration, LiveServerless
  - Validates environment variable overrides
  - Checks for hardcoded values (code quality)
  - 20 tests covering all aspects of the fix
  - Can be retained for future verification

scripts/verify-manifest-constants.sh:
  - Bash script for testing with actual flash build integration
  - Tests different environment configurations
  - Verifies manifest generation with environment variables
  - Comprehensive test suites for different scenarios

scripts/verify-image-constants.sh:
  - Detailed bash script for Docker and environment testing
  - Tests default behavior and custom overrides
  - Can be extended for additional verification scenarios

VERIFICATION.md:
  - Complete documentation for running verification tests
  - Step-by-step instructions for each test scenario
  - Environment variable reference
  - Troubleshooting guide
  - Can be used as permanent reference guide

All verification scripts pass with:
  ✓ 20/20 tests passed
  ✓ Constants properly centralized
  ✓ Manifest builder uses constants
  ✓ LiveServerless classes use constants
  ✓ Environment variables override constants
  ✓ No hardcoded values remain

These scripts can be retained indefinitely and re-run after any changes
to ensure the fix remains intact.
The test_live_load_balancer_creation_with_local_tag and
test_cpu_live_load_balancer_creation_with_local_tag tests were failing
on CI but passing locally due to module import caching.

The tests set the TETRA_IMAGE_TAG environment variable and reload the
live_serverless module, but the constants module (where the image names
are defined) was not being reloaded. This caused the tests to use stale
cached values on CI where test execution order or isolation differs.

Fix: Also reload the constants module after setting the environment
variable to ensure fresh evaluation of the image name constants.
@deanq deanq requested a review from Copilot February 2, 2026 06:08
Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

This PR removes deprecated handler generator code and introduces comprehensive verification scripts for Docker image configuration, along with various bug fixes and refactoring improvements.

Changes:

  • Removes deprecated handler generator files and references
  • Adds verification scripts for Docker image constants consistency
  • Centralizes Docker image configuration in a dedicated constants module
  • Improves test fixtures and filtering logic

Reviewed changes

Copilot reviewed 43 out of 45 changed files in this pull request and generated 3 comments.

Show a summary per file
File Description
tests/unit/runtime/test_service_registry.py Removes deprecated handler_file references from test fixtures
tests/unit/resources/test_live_load_balancer.py Adds constants module reload for proper environment variable testing
tests/unit/cli/test_undeploy.py Improves mock resource creation using spec parameter
tests/unit/cli/commands/build_utils/test_mothership_handler_generator.py Removes entire deprecated test file
tests/unit/cli/commands/build_utils/test_manifest_mothership.py Updates tests to use centralized image constants
tests/unit/cli/commands/build_utils/test_manifest.py Removes handler_file assertions from manifest tests
tests/unit/cli/commands/build_utils/test_handler_generator.py Removes entire deprecated test file
tests/integration/test_lb_remote_execution.py Removes deprecated handler generation tests
tests/integration/test_cross_endpoint_routing.py Removes handler_file from test manifest fixtures
src/tetra_rp/runtime/models.py Removes handler_file field from ResourceConfig model
src/tetra_rp/core/resources/live_serverless.py Imports Docker image constants from centralized location
src/tetra_rp/core/resources/constants.py Adds centralized Docker image and worker configuration constants
src/tetra_rp/cli/docs/flash-build.md Updates documentation to reflect removal of handler generation
src/tetra_rp/cli/commands/undeploy.py Adds filtering to only show serverless resources
src/tetra_rp/cli/commands/test_mothership.py Uses centralized image constant
src/tetra_rp/cli/commands/build_utils/mothership_handler_generator.py Removes deprecated mothership handler generator
src/tetra_rp/cli/commands/build_utils/manifest.py Uses centralized constants instead of hardcoded values
src/tetra_rp/cli/commands/build_utils/lb_handler_generator.py Removes deprecated LB handler generator
src/tetra_rp/cli/commands/build_utils/handler_generator.py Removes deprecated handler generator
src/tetra_rp/cli/commands/build.py Removes handler generation logic from build command
scripts/verify-manifest-constants.sh Adds verification script for manifest constants
scripts/verify-image-constants.sh Adds verification script for image constants
scripts/test-image-constants.py Adds Python-based verification script
scripts/mcp_code_intel_server.py Adds MCP server for code intelligence
scripts/code_intel.py Adds code intelligence query interface
scripts/ast_to_sqlite.py Adds AST-based code indexer
pyproject.toml Updates project authors and adds mcp dependency
docs/* Updates multiple documentation files to remove handler generation references
VERIFICATION.md Adds comprehensive verification guide
README.md Updates to reflect handler generation removal
Makefile Adds code intelligence targets
CONTRIBUTING.md Adds code intelligence system documentation
CLAUDE.md Adds Claude Code configuration
.mcp.json Adds MCP server configuration
.github/workflows/dependency-review.yml Removes dependency review workflow
.claude/* Adds Claude Code skill and settings

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.


[tool.ruff]

[tool.mypy]
Copy link

Copilot AI Feb 2, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The [tool.ruff] section header was removed but no replacement section was added. If Ruff configuration is now managed elsewhere or no longer needed, this is fine. However, if Ruff is still being used (which it is, based on the dev dependencies), consider documenting where the configuration lives or adding a minimal [tool.ruff] section to make the configuration explicit.

Copilot uses AI. Check for mistakes.
Comment on lines 81 to 89
mock_resource1 = MagicMock(spec=ServerlessResource)
mock_resource1.name = "test-api-1"
mock_resource1.id = "endpoint-id-1"
mock_resource1.is_deployed.return_value = True
mock_resource1.__class__.__name__ = "ServerlessResource"

mock_resource2 = MagicMock()
mock_resource2 = MagicMock(spec=ServerlessResource)
mock_resource2.name = "test-api-2"
mock_resource2.id = "endpoint-id-2"
mock_resource2.is_deployed.return_value = True
Copy link

Copilot AI Feb 2, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The test verifies that the list command works with endpoints, but it doesn't verify the new _get_serverless_resources filtering logic introduced in undeploy.py. Consider adding a test case that includes both ServerlessResource and non-ServerlessResource types to verify the filtering works correctly.

Copilot uses AI. Check for mistakes.
- Add explicit [tool.ruff] configuration section for clarity
- Add test to verify _get_serverless_resources filtering logic excludes
  non-ServerlessResource types like NetworkVolume (fixes feedback comment)
@deanq deanq changed the base branch from main to deanq/ae-1965-bug-undeploy-should-only-show-endpoints February 2, 2026 12:28
Base automatically changed from deanq/ae-1965-bug-undeploy-should-only-show-endpoints to main February 2, 2026 23:27
@deanq deanq merged commit 5a253af into main Feb 2, 2026
6 checks passed
@deanq deanq deleted the deanq/ae-1951-fix-deployment-hosting branch February 2, 2026 23:32
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants