Agent Skills: Helm Chart Patterns

Helm chart development patterns for packaging and deploying Kubernetes applications. Use when creating reusable Helm charts, managing multi-environment deployments, or building application catalogs for Kubernetes.

UncategorizedID: NickCrew/claude-ctx-plugin/helm-chart-patterns

Skill Files

Browse the full folder contents for helm-chart-patterns.

Download Skill

Loading file tree…

skills/helm-chart-patterns/SKILL.md

Skill Metadata

Name
helm-chart-patterns
Description
Helm chart development patterns for packaging and deploying Kubernetes applications. Use when creating reusable Helm charts, managing multi-environment deployments, or building application catalogs for Kubernetes.

Helm Chart Patterns

Expert guidance for developing production-grade Helm charts covering chart structure, templating patterns, multi-environment configuration, dependency management, testing strategies, and distribution workflows for Kubernetes application packaging.

When to Use This Skill

  • Creating reusable Helm charts for applications and services
  • Building application catalogs and chart repositories
  • Managing multi-environment deployments (dev, staging, production)
  • Implementing advanced templating with conditionals and loops
  • Managing chart dependencies and subcharts
  • Implementing chart hooks for lifecycle management
  • Testing and validating chart templates
  • Packaging and distributing charts via repositories
  • Using Helmfile for multi-chart orchestration

Core Concepts

Chart Types

  • Application charts: Standard deployable charts for your services
  • Library charts: Reusable template helpers (not directly installable)

Key Files

| File | Purpose | |------|---------| | Chart.yaml | Metadata, version, dependencies | | values.yaml | Default configuration | | values.schema.json | Input validation | | templates/_helpers.tpl | Reusable template functions | | templates/*.yaml | Kubernetes manifests |

Template Essentials

  • Quote strings: {{ .Values.name | quote }}
  • Indent properly: {{- toYaml . | nindent 4 }}
  • Use helpers: {{ include "my-app.fullname" . }}
  • Check nil: {{- if .Values.optional }}

Quick Reference

| Task | Load reference | | --- | --- | | Chart structure & Chart.yaml | skills/helm-chart-patterns/references/chart-structure.md | | Values file patterns | skills/helm-chart-patterns/references/values-patterns.md | | Template patterns & functions | skills/helm-chart-patterns/references/template-patterns.md | | Dependencies & subcharts | skills/helm-chart-patterns/references/dependencies.md | | Hooks & lifecycle | skills/helm-chart-patterns/references/hooks.md | | Testing patterns | skills/helm-chart-patterns/references/testing.md | | Packaging & distribution | skills/helm-chart-patterns/references/packaging.md | | Helmfile multi-chart | skills/helm-chart-patterns/references/helmfile.md | | Best practices checklist | skills/helm-chart-patterns/references/best-practices.md |

Workflow

  1. Structure - Set up chart directory with Chart.yaml and values.yaml
  2. Template - Create Kubernetes manifests with Go templating
  3. Helpers - Extract common patterns into _helpers.tpl
  4. Validate - Use values.schema.json for input validation
  5. Test - Lint, template, and run chart tests
  6. Package - Create .tgz and publish to repository

Essential Commands

# Development
helm create my-app          # Scaffold new chart
helm lint ./my-app          # Validate chart
helm template my-app ./my-app  # Render templates

# Dependencies
helm dependency update      # Download dependencies
helm dependency list        # Show dependencies

# Testing
helm install my-app ./my-app --dry-run --debug
helm test my-app

# Distribution
helm package ./my-app
helm repo index . --url https://charts.example.com
helm push my-app-1.0.0.tgz oci://registry.example.com/charts

Common Mistakes

  • Forgetting to quote strings in templates
  • Not using nindent for proper YAML formatting
  • Committing secrets to values files
  • Missing security contexts (runAsNonRoot, drop capabilities)
  • Not pinning dependency versions
  • Skipping values.schema.json validation
  • Not testing upgrades from previous versions

Resources

  • Helm Documentation: https://helm.sh/docs/
  • Chart Template Guide: https://helm.sh/docs/chart_template_guide/
  • Best Practices: https://helm.sh/docs/chart_best_practices/
  • Helmfile: https://github.com/helmfile/helmfile
  • Chart Testing: https://github.com/helm/chart-testing