BREAKING CHANGES: - Remove -cskill suffix from all skill names (use standard kebab-case) - Simplify marketplace.json to only official fields (fixes Issue #5) - SKILL.md body must be <500 lines (progressive disclosure via references/) New features: - Cross-platform support for 8+ platforms (Claude Code, Copilot, Cursor, Windsurf, Cline, Codex CLI, Gemini CLI) - scripts/install-template.sh: Auto-detect platform installer with --dry-run - scripts/validate.py: Spec compliance checker for generated skills - scripts/security_scan.py: Security scanner for hardcoded keys and dangerous patterns - MIGRATION.md: v3.x to v4.0 migration guide - 6 new reference files for progressive disclosure from lean SKILL.md Key changes: - SKILL.md: 4,116 → 272 lines with spec-compliant YAML frontmatter - marketplace.json: Stripped to {name, plugins} only - article-to-prototype-cskill/ → article-to-prototype/ - stock-analyzer-cskill/ → stock-analyzer/ - Export system integrates validation + security scanning - README.md rewritten for all supported platforms - Phase 5 pipeline outputs SKILL.md-first, spec-compliant skills Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
28 lines
972 B
Markdown
28 lines
972 B
Markdown
# SC-032: Export System Produces API .zip Package Under 8MB
|
|
|
|
> Covers: FR-019 — Export system MUST continue to support API .zip variant
|
|
> Type: Happy Path
|
|
|
|
## Given
|
|
- A valid skill directory `log-analysis/` exists with all required files
|
|
- The export system (`scripts/export_utils.py`) is available
|
|
|
|
## When
|
|
- `export_skill("log-analysis/", variants=["api"])` is called
|
|
|
|
## Then
|
|
- A `.zip` file is generated for the API variant
|
|
- The zip file size is less than 8MB
|
|
- The zip contains an optimized subset of files suitable for API consumption
|
|
|
|
## Verification Method
|
|
|
|
**Method**: Automated test
|
|
|
|
**Steps**:
|
|
1. Call `export_skill("log-analysis/", variants=["api"])`
|
|
2. Assert the returned dict contains a path to a `.zip` file
|
|
3. Check file size: `os.path.getsize(zip_path) < 8 * 1024 * 1024`
|
|
4. Run: `unzip -t <output.zip>` to verify integrity
|
|
|
|
**Expected evidence**: A `.zip` file is produced. File size is less than 8,388,608 bytes (8MB). `unzip -t` reports no errors.
|