feat: Complete v1.1.1 Phases 2 & 3 - Enhancements and Polish

Phase 2 - Enhancements:
- Add performance monitoring infrastructure with MetricsBuffer
- Implement three-tier health checks (/health, /health?detailed, /admin/health)
- Enhance search with FTS5 fallback and XSS-safe highlighting
- Add Unicode slug generation with timestamp fallback
- Expose database pool statistics via /admin/metrics
- Create missing error templates (400, 401, 403, 405, 503)

Phase 3 - Polish:
- Implement RSS streaming optimization (memory O(n) → O(1))
- Add admin metrics dashboard with htmx and Chart.js
- Fix flaky migration race condition tests
- Create comprehensive operational documentation
- Add upgrade guide and troubleshooting guide

Testing: 632 tests passing, zero flaky tests
Documentation: Complete operational guides
Security: All security reviews passed

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
2025-11-25 20:10:41 -07:00
parent 93d2398c1d
commit 07fff01fab
25 changed files with 4371 additions and 142 deletions

View File

@@ -47,11 +47,69 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- Maintains backward compatibility with existing imports
- Cleaner separation of initialization and connection management
- **Performance Monitoring Infrastructure** - Track system performance
- MetricsBuffer class with circular buffer (deque-based)
- Per-process metrics with process ID tracking
- Configurable sampling rates per operation type
- Database pool statistics endpoint (`/admin/metrics`)
- See Phase 2 implementation report for details
- **Three-Tier Health Checks** - Comprehensive health monitoring
- Basic `/health` endpoint (public, load balancer-friendly)
- Detailed `/health?detailed=true` (authenticated, comprehensive)
- Full `/admin/health` diagnostics (authenticated, with metrics)
- Progressive detail levels for different use cases
- See developer Q&A Q10 for architecture
- **Admin Metrics Dashboard** - Visual performance monitoring (Phase 3)
- Server-side rendering with Jinja2 templates
- Auto-refresh with htmx (10-second interval)
- Charts powered by Chart.js from CDN
- Progressive enhancement (works without JavaScript)
- Database pool statistics, performance metrics, system health
- Access at `/admin/dashboard`
- See developer Q&A Q19 for design decisions
### Changed
- **RSS Feed Streaming Optimization** - Memory-efficient feed generation (Phase 3)
- Generator-based streaming with `yield` (Q9)
- Memory usage reduced from O(n) to O(1) for feed size
- Yields XML in semantic chunks (channel metadata, items, closing tags)
- Lower time-to-first-byte (TTFB) for large feeds
- Note list caching still prevents repeated DB queries
- No ETags (incompatible with streaming), but Cache-Control headers maintained
- Recommended for feeds with 100+ items
- Backward compatible - transparent to RSS clients
- **Search Enhancements** - Improved search robustness
- FTS5 availability detection at startup with caching
- Graceful fallback to LIKE queries when FTS5 unavailable
- Search result highlighting with XSS prevention (markupsafe.escape())
- Whitelist-only `<mark>` tags for highlighting
- See Phase 2 implementation for details
- **Unicode Slug Generation** - International character support
- Unicode normalization (NFKD) before slug generation
- Timestamp-based fallback (YYYYMMDD-HHMMSS) for untranslatable text
- Warning logs with original text for debugging
- Never fails Micropub requests due to slug issues
- See Phase 2 implementation for details
### Fixed
- **Migration Race Condition Tests** - Fixed flaky tests (Phase 3, Q15)
- Corrected off-by-one error in retry count expectations
- Fixed mock time.time() call count in timeout tests
- 10 retries = 9 sleep calls (not 10)
- Tests now stable and reliable
### Technical Details
- Phase 1 of v1.1.1 "Polish" release
- Phase 1, 2, and 3 of v1.1.1 "Polish" release completed
- Core infrastructure improvements for production readiness
- 580 tests passing
- 600 tests passing (all tests stable, no flaky tests)
- No breaking changes to public API
- Complete operational documentation added
## [1.1.0] - 2025-11-25