forked from Rockachopa/Timmy-time-dashboard
## Summary Complete refactoring of Timmy Time from monolithic architecture to microservices using Test-Driven Development (TDD) and optimized Docker builds. ## Changes ### Core Improvements - Optimized dashboard startup: moved blocking tasks to async background processes - Fixed model fallback logic in agent configuration - Enhanced test fixtures with comprehensive conftest.py ### Microservices Architecture - Created separate Dockerfiles for dashboard, Ollama, and agent services - Implemented docker-compose.microservices.yml for service orchestration - Added health checks and non-root user execution for security - Multi-stage Docker builds for lean, fast images ### Testing - Added E2E tests for dashboard responsiveness - Added E2E tests for Ollama integration - Added E2E tests for microservices architecture validation - All 36 tests passing, 8 skipped (environment-specific) ### Documentation - Created comprehensive final report - Generated issue resolution plan - Added interview transcript demonstrating core agent functionality ### New Modules - skill_absorption.py: Dynamic skill loading and integration system for Timmy ## Test Results ✅ 36 passed, 8 skipped, 6 warnings ✅ All microservices tests passing ✅ Dashboard responsiveness verified ✅ Ollama integration validated ## Files Added/Modified - docker/: Multi-stage Dockerfiles for all services - tests/e2e/: Comprehensive E2E test suite - src/timmy/skill_absorption.py: Skill absorption system - src/dashboard/app.py: Optimized startup logic - tests/conftest.py: Enhanced test fixtures - docker-compose.microservices.yml: Service orchestration ## Breaking Changes None - all changes are backward compatible ## Next Steps - Integrate skill absorption system into agent workflow - Test with microservices-tdd-refactor skill - Deploy to production with docker-compose orchestration
66 lines
2.1 KiB
Docker
66 lines
2.1 KiB
Docker
# ── Timmy Agent — Multi-stage Optimized Build ────────────────────────────────
|
|
#
|
|
# Lightweight agent container for running Timmy or swarm workers.
|
|
#
|
|
# Build: docker build -f docker/Dockerfile.agent -t timmy-agent:latest .
|
|
# Run: docker run -e COORDINATOR_URL=http://dashboard:8000 timmy-agent:latest
|
|
|
|
# ── Stage 1: Builder ──────────────────────────────────────────────────────────
|
|
FROM python:3.12-slim as builder
|
|
|
|
WORKDIR /build
|
|
|
|
# Install build dependencies
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
gcc \
|
|
curl \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Copy only pyproject.toml
|
|
COPY pyproject.toml .
|
|
|
|
# Create minimal package structure
|
|
RUN mkdir -p src/timmy src/swarm src/infrastructure && \
|
|
touch src/__init__.py src/timmy/__init__.py src/swarm/__init__.py \
|
|
src/infrastructure/__init__.py config.py
|
|
|
|
# Install dependencies
|
|
RUN pip install --no-cache-dir --user -e ".[swarm]"
|
|
|
|
|
|
# ── Stage 2: Runtime ─────────────────────────────────────────────────────────
|
|
FROM python:3.12-slim as runtime
|
|
|
|
WORKDIR /app
|
|
|
|
# Install only runtime dependencies
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
curl \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Copy Python packages from builder
|
|
COPY --from=builder /root/.local /root/.local
|
|
|
|
# Copy application source
|
|
COPY src/ ./src/
|
|
COPY config.py .
|
|
|
|
# Create data directory
|
|
RUN mkdir -p /app/data
|
|
|
|
# Create non-root user
|
|
RUN groupadd -r timmy && useradd -r -g timmy -d /app -s /sbin/nologin timmy && \
|
|
chown -R timmy:timmy /app
|
|
|
|
# Set environment
|
|
ENV PATH=/root/.local/bin:$PATH
|
|
ENV PYTHONPATH=/app/src
|
|
ENV PYTHONUNBUFFERED=1
|
|
ENV PYTHONDONTWRITEBYTECODE=1
|
|
|
|
# Switch to non-root user
|
|
USER timmy
|
|
|
|
# Default: run Timmy agent (can be overridden)
|
|
CMD ["python", "-m", "timmy.docker_agent"]
|