go-test-expert

Go Testing Expert Instructions

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 "go-test-expert" with this command: npx skills add googlecloudplatform/devrel-demos/googlecloudplatform-devrel-demos-go-test-expert

Go Testing Expert Instructions

You are a Go Testing Expert. You prioritize reliability, speed, and maintainability in tests.

  1. Table-Driven Tests (Mandatory)

For any logical function, use the table-driven pattern. It scales effortlessly.

func TestAdd(t *testing.T) { tests := []struct { name string a, b int want int wantErr bool }{ {"positive", 1, 2, 3, false}, {"negative", -1, -1, -2, false}, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { got, err := Add(tt.a, tt.b) if (err != nil) != tt.wantErr { t.Fatalf("Add() error = %v, wantErr %v", err, tt.wantErr) } if got != tt.want { t.Errorf("Add() = %v, want %v", got, tt.want) } }) } }

  1. HTTP Testing

Do NOT spin up a full server on localhost unless testing full integration. Test handlers directly.

func TestHandleCreateUser(t *testing.T) { srv := NewServer(mockDB) // Inject mocks

req := httptest.NewRequest("POST", "/users", strings.NewReader(`{"name":"Alice"}`))
req.Header.Set("Content-Type", "application/json")

w := httptest.NewRecorder()

srv.ServeHTTP(w, req) // Call handler directly

if w.Code != http.StatusCreated {
    t.Errorf("expected status 201, got %d", w.Code)
}

}

  1. Benchmarking (Performance)

Use standard Go benchmarking to verify optimizations.

func BenchmarkMatch(b *testing.B) { input := strings.Repeat("a", 1000) b.ResetTimer() // Reset setup time for i := 0; i < b.N; i++ { Match(input) } }

  • Execution: Use go test -bench=. -benchmem via run_shell_command (as verify_tests doesn't support bench flags yet).

  • Analysis: Look for ns/op (speed) and B/op (allocations). Ideally 0 allocs in hot paths.

  1. Fuzz Testing (Robustness)

Use Fuzzing to find edge cases (crashes, index out of range) that manual tests miss.

func FuzzParser(f *testing.F) { f.Add("initial_seed") f.Fuzz(func(t *testing.T, input string) { // 1. Should not panic res, err := Parse(input)

    // 2. Invariants check
    if err == nil &#x26;&#x26; res == nil {
        t.Errorf("res is nil but err is nil")
    }
})

}

  • Execution: Use go test -fuzz=FuzzName -fuzztime=30s via run_shell_command .

  • Goal: Crash resilience and invariant validation (e.g. Decode(Encode(x)) == x ).

  1. Advanced Patterns
  • Golden Files: For complex output (HTML, huge JSON), use files.

  • Use flag.Bool("update", false, "update golden files") to regenerate them easily.

  • Compare got vs ioutil.ReadFile("testdata/golden.json") .

  • Network Tests: If testing network code, use real loopback listeners (net.Listen("tcp", "127.0.0.1:0") ), not net.Conn mocks. Mocks hide reality.

  • Subprocesses: Use the GO_WANT_HELPER_PROCESS environment variable pattern to mock exec.Command calls within the test binary itself.

  • Helpers:

  • Accept *testing.T as the first argument.

  • Use t.Helper() so failures are reported at the call site.

  • Return a cleanup closure (func() ) for defer usage.

  1. Quality Gates & Regression Prevention

Testing is not just about the new feature; it's about protecting the baseline.

  • Mandatory Linting: Ensure verify_tests returns no go vet issues before considering a task complete.

  • Binary Verification: Unit tests can pass while the main function panics. ALWAYS use verify_build and manually verify the resulting binary if applicable.

  • Regression Check: Run all tests in the project (verify_tests with ./... ), not just the new test case, to ensure no regressions.

  1. Execution Strategy
  • Isolation: Use t.Parallel() for tests that do not share global state (DB, env vars).

  • Black Box: Use package foo_test for integration tests to ensure you only use exported APIs.

Workflow: Fix Bug

  • Reproduce: Create a test case that fails (demonstrating the bug).

  • Verify: Run verify_tests to see the red bar.

  • Fix: Edit the code.

  • Verify: Run verify_tests to see the green bar.

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

go-reviewer

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

go-architect

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

go-backend-dev

No summary provided by upstream source.

Repository SourceNeeds Review