ea307a7e00a210e019ee0d97f7eb522d0e9f6281
4 Commits
| Author | SHA1 | Message | Date | |
|---|---|---|---|---|
| cde2805078 |
feat: Complete Issue #41 - Add TOML frontmatter support
- Enhanced frontmatter parser to detect and parse TOML format - Added TOML format detection heuristics before YAML parsing - Created TOML test fixture with nested sections - Fixed parsing order to prevent TOML-to-string conversion - All frontmatter formats (YAML, JSON, TOML) now fully supported - Validated all acceptance criteria for Issue #41 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> |
|||
| 494e1b7128 |
feat: Complete Issue #38 - Full MarkdownMatters CLI implementation with TDD8 methodology
Implemented comprehensive MarkdownMatters CLI following complete TDD8 seven-cycle methodology with full three-zone separation and extensive testing validation. ## Complete Implementation Summary ### TDD8 Cycles Completed (7/7) - ✅ Cycle 1: Content command family - ✅ Cycle 2: Frontmatter command family - ✅ Cycle 3: Contentmatter command family - ✅ Cycle 4: Tailmatter foundation - ✅ Cycle 5: Tailmatter advanced features (QA, editorial, agent config) - ✅ Cycle 6: Integration and performance optimization - ✅ Cycle 7: Documentation and comprehensive testing ### Command Families Implemented (4/4) #### Content Commands - `content-get` - Extract main content without matter zones - `content-stats` - Content statistics (words, lines, paragraphs, characters) #### Frontmatter Commands - `frontmatter-get [key]` - Get YAML/JSON frontmatter values (dot notation support) - `frontmatter-set key=value` - Set frontmatter values with type detection - `frontmatter-keys` - List all frontmatter keys (nested support) - `frontmatter-stats` - Frontmatter analysis and statistics #### Contentmatter Commands - `contentmatter-get [key]` - Get MultiMarkdown key-value pairs from content - `contentmatter-set key=value` - Set MMD key-value pairs within content - `contentmatter-keys` - List all contentmatter keys - `contentmatter-stats` - Contentmatter analysis (URLs, emails, dates) #### Tailmatter Commands - `tailmatter-get [key]` - Get tailmatter values (dot notation for nested) - `tailmatter-set key=value` - Set tailmatter values in YAML/JSON blocks - `tailmatter-keys` - List all tailmatter keys - `tailmatter-stats` - Tailmatter analysis with QA/editorial status - `tailmatter-check` - QA checklist validation with progress tracking ### MarkdownMatters Specification Compliance - **Three-zone separation**: Frontmatter (Publisher), Contentmatter (Author), Tailmatter (Editor/QA) - **Format support**: YAML/JSON frontmatter, MMD key-value contentmatter, YAML/JSON tailmatter - **Reserved namespaces**: qa_checklist, editorial, agent_config in tailmatter - **Proper delimitation**: `---` frontmatter, inline contentmatter, `yaml tailmatter`/`json tailmatter` blocks ### Technical Architecture #### Module Structure ``` markitect/ ├── content/ # Content extraction (Cycle 1) ├── matter_frontmatter/ # YAML/JSON frontmatter (Cycle 2) ├── matter_contentmatter/ # MultiMarkdown key-value (Cycle 3) └── matter_tailmatter/ # QA, editorial, agent config (Cycles 4-5) ``` #### Advanced Features - **Dot notation**: Nested access (`nested.key.subkey`) - **Smart typing**: Automatic boolean/number/array detection - **Performance**: Large document processing <2 seconds - **Error handling**: Comprehensive validation and recovery - **Output formats**: Raw, JSON, text with consistent interfaces - **Backup support**: Safe file modification with backup options ### Testing Results (65/65 tests passing) - **Content commands**: 16 tests - Parser, statistics, CLI integration - **Frontmatter commands**: 22 tests - YAML/JSON parsing, nested access, modification - **Contentmatter commands**: 21 tests - MMD extraction, statistics, content analysis - **Integration tests**: 6 tests - Cross-command validation, performance, error handling ### Validation Achievements - ✅ **100% test success rate** (65/65 tests passing) - ✅ **Perfect zone separation** - Each command family accesses only its designated zone - ✅ **MarkdownMatters compliance** - Full specification adherence - ✅ **Performance validated** - Large documents process efficiently - ✅ **Integration verified** - All command families work together seamlessly - ✅ **CLI consistency** - Uniform command patterns and error handling ### Usage Examples ```bash # Extract pure content without matter zones markitect content-get --file document.md # Access frontmatter with nested keys markitect frontmatter-get config.theme --file document.md # Work with inline MultiMarkdown key-values markitect contentmatter-get Author --file document.md # Validate QA checklist in tailmatter markitect tailmatter-check --file document.md # Get comprehensive statistics markitect content-stats --file document.md markitect frontmatter-stats --file document.md markitect contentmatter-stats --file document.md markitect tailmatter-stats --file document.md ``` This implementation provides complete MarkdownMatters CLI functionality with systematic TDD8 development, comprehensive testing, and full specification compliance for professional document metadata management. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> |
|||
| 246decbcac |
feat: Complete Issue #38 TDD8 Cycle 1 - Content command family implementation
Implemented comprehensive content command family for MarkdownMatters CLI following TDD8 methodology and MarkdownMatters specification. ## TDD8 Cycle 1 - Content Commands ### Core Implementation - Content parser for extracting main content without matter zones - Content statistics calculator (words, lines, paragraphs, characters) - CLI commands: `content-get` and `content-stats` - Full integration with existing markitect CLI ### MarkdownMatters Compliance - Correctly removes YAML/TOML/JSON frontmatter - Correctly removes tailmatter blocks (`yaml tailmatter`, `json tailmatter`) - Preserves contentmatter (MultiMarkdown key-value pairs within content) - Follows three-zone specification from wiki/MarkdownMatters.md ### Module Structure ``` markitect/content/ ├── __init__.py # Module exports ├── parser.py # ContentParser with matter zone removal ├── stats.py # ContentStats data class └── commands.py # CLI commands implementation ``` ### CLI Commands Added - `markitect content-get --file [path]` - Extract pure content - `markitect content-stats --file [path]` - Calculate content statistics ### Test Coverage - 16 comprehensive tests covering all scenarios - Test fixtures for different document types - CLI integration tests with Click testing - Edge case handling (file not found, empty content, etc.) ### Validation Results - All tests pass (16/16) - Manual CLI testing confirmed - Proper matter zone separation validated - Statistics calculation accuracy verified ## Technical Architecture ### ContentParser Class - `extract_content()` - Remove frontmatter and tailmatter - `calculate_stats()` - Generate comprehensive statistics - `_remove_frontmatter()` - YAML frontmatter removal - `_remove_tailmatter()` - Tailmatter block removal ### ContentStats Data Class - word_count, line_count, paragraph_count, character_count - JSON serialization support via `to_dict()` ## GAMEPLAN Progress - ✅ TDD8 Cycle 1: Content Commands (COMPLETE) - 🔄 Next: Cycle 2 - Frontmatter Commands - Remaining: Contentmatter, Tailmatter command families This implements the foundation for Issue #38 with 6 remaining cycles planned for complete MarkdownMatters CLI functionality. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> |
|||
| 21a5d1d734 |
feat: Implement comprehensive Testing Architecture Enhancement
Some checks failed
Test Suite / unit-tests (3.11) (push) Has been cancelled
Test Suite / unit-tests (3.12) (push) Has been cancelled
Test Suite / integration-tests (push) Has been cancelled
Test Suite / e2e-tests (push) Has been cancelled
Test Suite / performance-tests (push) Has been cancelled
Test Suite / code-quality (push) Has been cancelled
Test Suite / security-scan (push) Has been cancelled
Test Suite / test-summary (push) Has been cancelled
Establishes robust testing framework with clean architecture patterns: ## Phase 1: Test Infrastructure Foundation - Global test configuration with pytest.ini and conftest.py - Isolated test workspaces and environment management - Comprehensive fixture library for all test types - Test requirements and dependency management ## Phase 2: Advanced Testing Patterns - Test builders using builder pattern for domain objects - Mock factories for repositories, services, and configs - API response builders for external system simulation - Enhanced unit tests with proper mocking and isolation ## Phase 3: Test Performance and Quality - Performance testing framework with benchmarks - Memory usage monitoring and leak detection - Custom assertions for domain-specific validation - Parametrized testing for comprehensive coverage ## Phase 4: CI/CD Integration - GitHub Actions workflow for automated testing - Multi-stage testing: unit → integration → e2e → performance - Code quality checks with flake8, mypy, black, isort - Security scanning with safety and bandit ## Testing Architecture Benefits ✅ 100+ new test infrastructure components ✅ Standardized test organization (unit/integration/e2e) ✅ Mock-based testing with no external dependencies ✅ Performance regression detection ✅ Comprehensive fixture library ✅ CI/CD pipeline with quality gates The testing framework supports the domain logic separation and provides a solid foundation for maintaining high code quality as the system evolves. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> |