rtk-tdd

- Do NOT write production code without a failing test

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "rtk-tdd" with this command: npx skills add rtk-ai/rtk/rtk-ai-rtk-rtk-tdd

Rust TDD Workflow

Three Laws of TDD

  • Do NOT write production code without a failing test

  • Write only enough test to fail (including compilation failure)

  • Write only enough production code to pass the failing test

Cycle: RED (test fails) -> GREEN (minimum to pass) -> REFACTOR (cleanup, cargo test)

Red-Green-Refactor Steps

  1. Write test in #[cfg(test)] mod tests of the SAME file
  2. cargo test MODULE::tests::test_name -- must FAIL (red)
  3. Implement the minimum in the function
  4. cargo test MODULE::tests::test_name -- must PASS (green)
  5. Refactor if needed, re-run cargo test (still green)
  6. cargo fmt && cargo clippy --all-targets && cargo test (final gate)

Never skip step 2. If the test passes immediately, it tests nothing.

Idiomatic Rust Test Patterns

Pattern Usage When

Arrange-Act-Assert Base structure for every test Always

assert_eq! / assert!

Direct comparison / booleans Deterministic values

assert!(result.is_err())

Error path testing Invalid inputs

Result<()> return type Tests with ? operator Fallible functions

#[should_panic]

Expected panic Invariants, preconditions

tempfile::NamedTempFile

File/I/O tests Filesystem-dependent code

Patterns by Code Type

Code Type Test Pattern Example

Pure function (str -> str) Input literal -> assert output assert_eq!(truncate("hello", 3), "...")

Parsing/filtering Raw string -> filter -> contains/not-contains assert!(filter(raw).contains("expected"))

Validation/security Boundary inputs -> assert bool assert!(!is_valid("../etc/passwd"))

Error handling Bad input -> is_err()

assert!(parse("garbage").is_err())

Struct/enum roundtrip Construct -> serialize -> deserialize -> eq assert_eq!(from_str(to_str(x)), x)

Naming Convention

test_{function}{scenario} test{function}_{input_type}

Examples: test_truncate_edge_case , test_parse_invalid_input , test_filter_empty_string

When NOT to Use Pure TDD

  • Functions calling Command::new() -> test the parser, not the execution

  • std::process::exit() -> refactor to Result first, then test the Result

  • Direct I/O (SQLite, network) -> use tempfile/mock or test the pure logic separately

  • Main/CLI wiring -> covered by integration/smoke tests

Pre-Commit Gate

cargo fmt --all --check cargo clippy --all-targets cargo test

All 3 must pass. No exceptions. No #[allow(...)] without documented justification.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

openclaw-version-monitor

监控 OpenClaw GitHub 版本更新,获取最新版本发布说明,翻译成中文, 并推送到 Telegram 和 Feishu。用于:(1) 定时检查版本更新 (2) 推送版本更新通知 (3) 生成中文版发布说明

Archived SourceRecently Updated
Coding

ask-claude

Delegate a task to Claude Code CLI and immediately report the result back in chat. Supports persistent sessions with full context memory. Safe execution: no data exfiltration, no external calls, file operations confined to workspace. Use when the user asks to run Claude, delegate a coding task, continue a previous Claude session, or any task benefiting from Claude Code's tools (file editing, code analysis, bash, etc.).

Archived SourceRecently Updated
Coding

ai-dating

This skill enables dating and matchmaking workflows. Use it when a user asks to make friends, find a partner, run matchmaking, or provide dating preferences/profile updates. The skill should execute `dating-cli` commands to complete profile setup, task creation/update, match checking, contact reveal, and review.

Archived SourceRecently Updated