Agent skill

writing-go-tests

Applies current Go testing best practices. Use when writing or modifying Go test files or advising on Go testing strategies.

Stars 4
Forks 0

Install this agent skill to your Project

npx add-skill https://github.com/AJBcoding/claude-skill-eval/tree/main/agentic-coding-main/Claude/skills/go-testing

SKILL.md

Go Testing Best Practices

This skill provides actionable testing guidelines. For detailed implementation patterns, code examples, rationale, and production system references, consult go-testing-best-practices.md.

When Working with Go Tests

Always apply these current best practices:

1. Test Organisation

  • Place test files alongside source code using *_test.go naming
  • Use internal tests (same package) for unit testing unexported functions
  • Use external tests (package foo_test) for integration testing and examples
  • Split test files by functionality when they exceed 500-800 lines (e.g., handler_auth_test.go, handler_validation_test.go)

2. Table-Driven Testing

  • Prefer map-based tables over slice-based for automatic unique test names
  • Use descriptive test case names that appear in failure output
  • See detailed guide for complete pattern and examples

3. Concurrent Testing

  • Use testing/synctest for deterministic concurrent testing (Go 1.24+)
  • This eliminates flaky time-based tests and runs in microseconds instead of seconds
  • For traditional parallel tests, always call t.Parallel() first in test functions

4. Assertions and Comparisons

  • Use cmp.Diff() from google/go-cmp for complex comparisons
  • Standard library is sufficient for simple tests
  • Testify is the dominant third-party framework when richer assertions are needed

5. Mocking and Test Doubles

  • Favour integration testing with real dependencies over heavy mocking
  • Use Testcontainers for database/service integration tests
  • When mocking is necessary, prefer simple function-based test doubles over code generation
  • Use interface-based design ("accept interfaces, return structs")

6. Coverage Targets

  • Aim for 70-80% coverage as a practical target
  • Focus on meaningful tests over percentage metrics
  • Use go test -cover and go tool cover -html for analysis

7. Test Fixtures

  • Use testdata directory for test fixtures (automatically ignored by Go toolchain)
  • Implement golden file testing for validating complex output
  • Use functional builder patterns for complex test data

8. Helpers and Cleanup

  • Always mark helper functions with t.Helper() for accurate error reporting
  • Use t.Cleanup() for resource cleanup (superior to defer in tests)

9. Benchmarking (Go 1.24+)

  • Use B.Loop() method as the preferred pattern (prevents compiler optimisations)
  • Combine with benchstat for statistical analysis
  • Use -benchmem for memory profiling

10. Naming Conventions

  • Test functions: Test*, Benchmark*, Fuzz*, Example* (capital letter after prefix)
  • Use got and want for actual vs expected values
  • Use descriptive test case names in table-driven tests

Integration vs Unit Testing

  • Separate tests by environment variable (preferred over build tags)
  • See detailed guide for implementation pattern

Additional Reference Material

Load go-testing-best-practices.md when you need:

  • Complete code examples for table-driven tests, mocking patterns, golden files, helpers, or benchmarks
  • Detailed explanation of testing/synctest concurrent testing patterns
  • Rationale behind why specific patterns are preferred over alternatives
  • Production system examples and statistics (Kubernetes, Docker, Uber, Netflix, ByteDance)
  • Context on testing framework choices (Testify, GoMock, Testcontainers)
  • Comprehensive coverage strategies and tooling details
  • Integration testing patterns with containerisation

The detailed guide contains full context, examples with explanations, and production-proven patterns. This SKILL.md provides the actionable rules to apply.

Key Principle

Focus on meaningful tests that validate behaviour rather than implementation. Pragmatic excellence over theoretical perfection.

Expand your agent's capabilities with these related and highly-rated skills.

AJBcoding/claude-skill-eval

mcp-builder

Guide for creating high-quality MCP (Model Context Protocol) servers that enable LLMs to interact with external services through well-designed tools. Use when building MCP servers to integrate external APIs or services, whether in Python (FastMCP) or Node/TypeScript (MCP SDK).

4 0
Explore
AJBcoding/claude-skill-eval

performing-systematic-debugging-for-stubborn-problems

Applies a modified Fagan Inspection methodology to systematically resolve persistent bugs and complex issues. Use when multiple previous fix attempts have failed repeatedly, when dealing with intricate system interactions, or when a methodical root cause analysis is needed. Do not use for simple troubleshooting. Triggers after multiple failed debugging attempts on the same complex issue.

4 0
Explore
AJBcoding/claude-skill-eval

creating-development-plans

Creates structured development plans with phased task breakdowns, requirements, and QA checklists. Use when the user explicitly asks to create a dev plan, development plan, or document development requirements.

4 0
Explore
AJBcoding/claude-skill-eval

writing-documentation-with-diataxis

Applies the Diataxis framework to create or improve technical documentation. Use when being asked to write high quality tutorials, how-to guides, reference docs, or explanations, when reviewing documentation quality, or when deciding what type of documentation to create. Helps identify documentation types using the action/cognition and acquisition/application dimensions.

4 0
Explore
AJBcoding/claude-skill-eval

shell-scripting

Practical bash scripting guidance emphasising defensive programming, ShellCheck compliance, and simplicity. Use when writing shell scripts that need to be reliable and maintainable.

4 0
Explore
AJBcoding/claude-skill-eval

ia-presenter-themes

This skill should be used when creating, modifying, or troubleshooting custom themes for iA Presenter.

4 0
Explore

Didn't find tool you were looking for?

Be as detailed as possible for better results