agent-skill-creator/scenarios/SC-020-security-scan-clean-skill.scenario.md
francylisboacharuto bac2b27bb8 feat: v4.0 Cross-Platform Modernization — Agent Skills Open Standard compliance
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>
2026-02-26 14:52:09 -03:00

29 lines
868 B
Markdown

# SC-020: Security Scan Passes on Clean Skill
> Covers: FR-013 — Security scan MUST check for hardcoded secrets (negative case: no findings)
> Type: Happy Path
## Given
- A generated skill directory `clean-skill/` contains:
- SKILL.md with valid frontmatter
- `scripts/main.py` using environment variables: `os.environ.get("API_KEY")`
- No `.env` files
- No hardcoded secrets
## When
- The security scan is run on `clean-skill/`
## Then
- The security scan passes with no findings
- The `security` list in the validation result is empty
## Verification Method
**Method**: Automated test
**Steps**:
1. Create `clean-skill/` with SKILL.md and scripts using `os.environ.get()` for all secrets
2. Run the security scan
3. Assert `result.security` is empty or `len(result.security) == 0`
**Expected evidence**: `security: []` -- no security issues found.