PluginBench
Skill
Pass
Audit score 90

golang-pro

jeffallan/claude-skills

Senior Go developer for concurrent systems, microservices, and production-grade performance optimization.

What is golang-pro?

Implements idiomatic Go patterns for concurrent programming, microservices architecture, and high-performance systems. Use when building goroutine-based applications, gRPC/REST services, or optimizing Go performance with profiling and benchmarks.

  • Design and implement concurrent patterns with goroutines, channels, and context cancellation
  • Build microservices with gRPC or REST APIs following Go best practices
  • Optimize performance using pprof profiling, benchmarks, and allocation elimination
  • Enforce idiomatic Go with generics, interfaces, composition, and robust error handling
  • Write table-driven tests with race detector and fuzzing for 80%+ coverage
  • Validate code with gofmt, golangci-lint, and go vet before committing

How to install golang-pro

npx skills add https://github.com/jeffallan/claude-skills --skill golang-pro
Prerequisites
  • Go 1.21 or later installed
  • golangci-lint configured in your project
  • Basic familiarity with goroutines and channels
Claude Code
Cursor
Windsurf
Cline

How to use golang-pro

  1. 1.Review your module structure and identify concurrency or architecture needs
  2. 2.Load the relevant reference guide (concurrency, interfaces, generics, testing, or project structure)
  3. 3.Follow the core workflow: analyze architecture, design interfaces, implement with error handling, lint with golangci-lint, optimize with pprof, test with race detector
  4. 4.Run `go vet ./...` and `golangci-lint run` to validate before proceeding
  5. 5.Write table-driven tests with `-race` flag and aim for 80%+ coverage
  6. 6.Profile with pprof and benchmarks to eliminate allocations and optimize hot paths

Use cases

Good for
  • Building concurrent worker pools and pipeline systems with proper lifecycle management
  • Designing microservices with gRPC or REST endpoints and error propagation
  • Profiling and optimizing Go applications to reduce allocations and latency
  • Creating reusable generic types and interfaces for cloud-native systems
  • Implementing CLI tools with context-aware cancellation and timeout handling
Who it's for
  • Go developers building concurrent or distributed systems
  • Backend engineers designing microservices architectures
  • Performance engineers optimizing Go applications
  • Teams enforcing idiomatic Go patterns and code quality

golang-pro FAQ

When should I use this skill?

Use golang-pro when building Go applications that require concurrent programming (goroutines/channels), microservices architecture (gRPC/REST), performance optimization, or enforcing idiomatic Go patterns with generics and interfaces.

What Go version is required?

Go 1.21 or later is required to access all features including generics, union constraints, and modern standard library patterns.

How does this skill handle errors?

Errors are propagated explicitly using fmt.Errorf with %w wrapping, context cancellation is always checked in select statements, and all blocking operations receive context.Context for proper lifecycle management.

What testing approach is enforced?

Table-driven tests with subtests are the standard, all tests run with the `-race` flag to detect concurrency issues, and coverage targets 80%+ with fuzzing for critical paths.

How do I optimize performance?

Profile with pprof to identify hot paths, write benchmarks to measure improvements, eliminate allocations by reusing buffers and preallocating slices, and validate optimizations with race detector enabled.

Full instructions (SKILL.md)

Source of truth, from jeffallan/claude-skills.


name: golang-pro description: Implements concurrent Go patterns using goroutines and channels, designs and builds microservices with gRPC or REST, optimizes Go application performance with pprof, and enforces idiomatic Go with generics, interfaces, and robust error handling. Use when building Go applications requiring concurrent programming, microservices architecture, or high-performance systems. Invoke for goroutines, channels, Go generics, gRPC integration, CLI tools, benchmarks, or table-driven testing. license: MIT metadata: author: https://github.com/Jeffallan version: "1.1.0" domain: language triggers: Go, Golang, goroutines, channels, gRPC, microservices Go, Go generics, concurrent programming, Go interfaces role: specialist scope: implementation output-format: code related-skills: devops-engineer, microservices-architect, test-master

Golang Pro

Senior Go developer with deep expertise in Go 1.21+, concurrent programming, and cloud-native microservices. Specializes in idiomatic patterns, performance optimization, and production-grade systems.

Core Workflow

  1. Analyze architecture — Review module structure, interfaces, and concurrency patterns
  2. Design interfaces — Create small, focused interfaces with composition
  3. Implement — Write idiomatic Go with proper error handling and context propagation; run go vet ./... before proceeding
  4. Lint & validate — Run golangci-lint run and fix all reported issues before proceeding
  5. Optimize — Profile with pprof, write benchmarks, eliminate allocations
  6. Test — Table-driven tests with -race flag, fuzzing, 80%+ coverage; confirm race detector passes before committing

Reference Guide

Load detailed guidance based on context:

TopicReferenceLoad When
Concurrencyreferences/concurrency.mdGoroutines, channels, select, sync primitives
Interfacesreferences/interfaces.mdInterface design, io.Reader/Writer, composition
Genericsreferences/generics.mdType parameters, constraints, generic patterns
Testingreferences/testing.mdTable-driven tests, benchmarks, fuzzing
Project Structurereferences/project-structure.mdModule layout, internal packages, go.mod

Core Pattern Example

Goroutine with proper context cancellation and error propagation:

// worker runs until ctx is cancelled or an error occurs.
// Errors are returned via the errCh channel; the caller must drain it.
func worker(ctx context.Context, jobs <-chan Job, errCh chan<- error) {
    for {
        select {
        case <-ctx.Done():
            errCh <- fmt.Errorf("worker cancelled: %w", ctx.Err())
            return
        case job, ok := <-jobs:
            if !ok {
                return // jobs channel closed; clean exit
            }
            if err := process(ctx, job); err != nil {
                errCh <- fmt.Errorf("process job %v: %w", job.ID, err)
                return
            }
        }
    }
}

func runPipeline(ctx context.Context, jobs []Job) error {
    ctx, cancel := context.WithTimeout(ctx, 30*time.Second)
    defer cancel()

    jobCh := make(chan Job, len(jobs))
    errCh := make(chan error, 1)

    go worker(ctx, jobCh, errCh)

    for _, j := range jobs {
        jobCh <- j
    }
    close(jobCh)

    select {
    case err := <-errCh:
        return err
    case <-ctx.Done():
        return fmt.Errorf("pipeline timed out: %w", ctx.Err())
    }
}

Key properties demonstrated: bounded goroutine lifetime via ctx, error propagation with %w, no goroutine leak on cancellation.

Constraints

MUST DO

  • Use gofmt and golangci-lint on all code
  • Add context.Context to all blocking operations
  • Handle all errors explicitly (no naked returns)
  • Write table-driven tests with subtests
  • Document all exported functions, types, and packages
  • Use X | Y union constraints for generics (Go 1.18+)
  • Propagate errors with fmt.Errorf("%w", err)
  • Run race detector on tests (-race flag)

MUST NOT DO

  • Ignore errors (avoid _ assignment without justification)
  • Use panic for normal error handling
  • Create goroutines without clear lifecycle management
  • Skip context cancellation handling
  • Use reflection without performance justification
  • Mix sync and async patterns carelessly
  • Hardcode configuration (use functional options or env vars)

Output Templates

When implementing Go features, provide:

  1. Interface definitions (contracts first)
  2. Implementation files with proper package structure
  3. Test file with table-driven tests
  4. Brief explanation of concurrency patterns used

Knowledge Reference

Go 1.21+, goroutines, channels, select, sync package, generics, type parameters, constraints, io.Reader/Writer, gRPC, context, error wrapping, pprof profiling, benchmarks, table-driven tests, fuzzing, go.mod, internal packages, functional options

Documentation

Related skills

More from jeffallan/claude-skills and the wider catalog.

LA

laravel-specialist

jeffallan/claude-skills

Build Laravel 10+ applications with Eloquent models, Sanctum auth, queues, APIs, and Livewire components.

17k installsAudited
FL

flutter-expert

jeffallan/claude-skills

Senior Flutter engineer for cross-platform apps with Riverpod, Bloc, GoRouter, and performance optimization.

12k installsAudited
PH

php-pro

jeffallan/claude-skills

Senior PHP developer for modern PHP 8.3+, Laravel, Symfony with strict typing, PHPStan level 9, and enterprise patterns.

12k installsAudited
KU

kubernetes-specialist

jeffallan/claude-skills

Deploy and manage Kubernetes workloads with secure manifests, RBAC, networking, and troubleshooting.

11k installs
DE

devops-engineer

jeffallan/claude-skills

Creates Dockerfiles, configures CI/CD pipelines, writes Kubernetes manifests, and generates Terraform/Pulumi infrastructure templates. Handles deployment automation, GitOps configuration, incident response runbooks, and internal developer platform tooling. Use when setting up CI/CD pipelines, containerizing applications, managing infrastructure as code, deploying to Kubernetes clusters, configuring cloud platforms, automating releases, or responding to production incidents. Invoke for pipelines, Docker, Kubernetes, GitOps, Terraform, GitHub Actions, on-call, or platform engineering.

6.8k installs
SP

spring-boot-engineer

jeffallan/claude-skills

Generates Spring Boot 3.x configurations, creates REST controllers, implements Spring Security 6 authentication flows, sets up Spring Data JPA repositories, and configures reactive WebFlux endpoints. Use when building Spring Boot 3.x applications, microservices, or reactive Java applications; invoke for Spring Data JPA, Spring Security 6, WebFlux, Spring Cloud integration, Java REST API design, or Microservices Java architecture.

6.8k installsAudited