Files
dance-lessons-coach/.vibe/skills/commit_message/SKILL.md
Gabriel Radureau 9336178d73 📝 docs: add ADR for staged-only Git hooks formatting
- Add ADR-0012 documenting the decision to format only staged Go files
- Update ADR README.md with new entry
- Document rationale, alternatives, and verification results
- Include future considerations for monitoring and CI/CD integration

Generated by Mistral Vibe.
Co-Authored-By: Mistral Vibe <vibe@mistral.ai>
2026-04-04 21:36:57 +02:00

8.1 KiB

name, description, license, metadata
name description license metadata
commit_message Helps create proper Gitmoji commit messages following the Common Gitmoji Reference from AGENTS.md. Use when creating commits to ensure consistent, visual commit messages. Includes Git hooks for automatic code formatting and dependency management. MIT
author version based-on
DanceLessonsCoach Team 1.1.0 AGENTS.md Common Gitmoji Reference

Commit Message Skill

This skill helps create proper Gitmoji commit messages following the Common Gitmoji Reference from AGENTS.md. It also includes Git hooks for automatic code formatting and dependency management.

Gitmoji Reference

Feature Changes

  • :sparkles: feat: New feature
  • 🐛 :bug: fix: Bug fix
  • ♻️ :recycle: refactor: Code refactoring
  • 🔥 :fire: remove: Remove code/files
  • 🚀 :rocket: perf: Performance improvements
  • 🔒 :lock: security: Security fixes

Documentation & Style

  • 📝 :memo: docs: Documentation
  • 🎨 :art: style: Code formatting
  • 📦 :package: dependencies: Dependency changes

Platform-Specific

  • 🐧 :penguin: linux: Linux-specific changes
  • 🍎 :apple: macos: macOS-specific changes
  • 🪟 :window: windows: Windows-specific changes

Testing & CI

  • 🧪 :test_tube: test: Tests
  • 🤖 :robot: ci: CI/CD changes

Other

  • 📈 :chart_with_upwards_trend: analytics: Analytics/SEO
  • 🌐 :globe_with_meridians: i18n: Internationalization
  • :zap: performance: Performance improvements
  • 🔧 :wrench: chore: Build/config changes

Usage Examples

New Feature

git commit -m "✨ feat: add user authentication"
git commit -m "✨ feat: implement BDD testing framework"

Bug Fix

git commit -m "🐛 fix: resolve port conflict in test server"
git commit -m "🐛 fix: handle JSON escaping in feature files"

Documentation

git commit -m "📝 docs: add comprehensive BDD testing guide"
git commit -m "📝 docs: update AGENTS.md with commit conventions"

Refactoring

git commit -m "♻️ refactor: move log setup to config package"
git commit -m "♻️ refactor: improve step pattern matching"

Tests

git commit -m "🧪 test: add BDD scenarios for greet service"
git commit -m "🧪 test: implement health endpoint validation"

Configuration

git commit -m "🔧 chore: add log output file configuration"
git commit -m "🔧 chore: update build system scripts"

Git Hooks for Code Quality

The project includes Git hooks that automatically run before commits to ensure code quality:

Pre-commit Hook

  • Location: .git/hooks/pre-commit
  • Automatically runs:
    • go mod tidy - Cleans up and organizes Go dependencies
    • go fmt - Formats all Go code according to standards
    • Auto-adds modified files to the commit

How It Works

# When you commit:
git add .
git commit -m "✨ feat: add new feature"

# The hook automatically:
1. Runs `go mod tidy`
2. Runs `go fmt` on all Go files
3. Adds any modified files to your commit
4. Allows commit if successful

Benefits

  • Ensures consistent code formatting
  • Maintains clean dependency management
  • Prevents common Go code issues
  • Runs automatically - no manual steps needed

Best Practices

Commit Message Structure

<gitmoji> <type>: <description>

<optional body with details>

<optional footer with references>

Examples

Simple commit:

✨ feat: add skill_creator framework

Detailed commit:

✨ feat: implement BDD testing with Godog

- Add features/greet.feature and features/health.feature
- Implement step definitions in pkg/bdd/steps/
- Create hybrid in-process test server
- Add comprehensive documentation

Generated by Mistral Vibe.
Co-Authored-By: Mistral Vibe <vibe@mistral.ai>

Complex commit:

🧪 test: add comprehensive BDD test suite

- Implement greet service scenarios
- Add health endpoint validation
- Create test server on port 9191
- Ensure no undefined/pending steps

Resolves: #42
Ref: AGENTS.md
Generated by Mistral Vibe.
Co-Authored-By: Mistral Vibe <vibe@mistral.ai>

Validation

Check Commit Message Format

# Verify gitmoji is present
echo "$commit_message" | grep -E "^[[:space:]]*[🎨✨🐛📝🔧♻️🚀🔒📦🔥🐧🍎🪟🤖🧪📈🌐⚡]"

# Verify type: description format
echo "$commit_message" | grep -E "^[🎨✨🐛📝🔧♻️🚀🔒📦🔥🐧🍎🪟🤖🧪📈🌐⚡][[:space:]]+[a-z_]+:"

Common Validation Issues

Issue Cause Solution
Missing gitmoji No emoji at start Add appropriate gitmoji from reference
Wrong type Type doesn't match emoji Use correct type from reference table
Missing colon No colon after type Add colon: feat: not feat
Long first line First line > 50 chars Keep first line concise, add details in body

Git Hooks Reference

Hook Location

.git/hooks/pre-commit

Hook Content

#!/bin/sh

# DanceLessonsCoach pre-commit hook
# Runs go mod tidy and go fmt before allowing commits

echo "Running pre-commit hooks..."

# Check if we're in a Go project
if [ ! -f "go.mod" ]; then
    echo "Not a Go project, skipping hooks"
    exit 0
fi

# Run go mod tidy
echo "Running go mod tidy..."
go mod tidy
if [ $? -ne 0 ]; then
    echo "ERROR: go mod tidy failed"
    exit 1
fi

# Check if go.mod or go.sum were modified
if git diff --cached --name-only | grep -qE '(go\.mod|go\.sum)'; then
    echo "go.mod or go.sum changed, adding to commit..."
    git add go.mod go.sum
fi

# Run go fmt on all Go files
echo "Running go fmt..."
GOFILES=$(find . -name '*.go' -not -path "./vendor/*" -not -path "./.git/*")
if [ -n "$GOFILES" ]; then
    gofmt -w $GOFILES
    if [ $? -ne 0 ]; then
        echo "ERROR: go fmt failed"
        exit 1
    fi
    
    # Add formatted files to commit
    git add $GOFILES
fi

echo "Pre-commit hooks completed successfully"
exit 0

Customization

To modify the hook:

# Edit the hook
nano .git/hooks/pre-commit

# Make it executable (if needed)
chmod +x .git/hooks/pre-commit

Disabling Hooks

To skip hooks for a single commit:

git commit --no-verify -m "✨ feat: add new feature"

References

Troubleshooting

Finding the Right Gitmoji

# Search for appropriate gitmoji
grep "feature\|new" .vibe/skills/commit_message/SKILL.md
# Result: ✨ :sparkles: feat - New feature

Commit Message Too Long

# Split into concise first line + detailed body
git commit -m "✨ feat: add BDD framework" -m "- Implement Godog testing" -m "- Add greet/health features" -m "- Create test server"

Multiple Changes in One Commit

# Use comprehensive description
git commit -m "♻️ refactor: improve BDD implementation" -m "- Update step patterns to match Godog exactly" -m "- Add JSON response validation" -m "- Implement server verification" -m "- Update all templates and documentation"

Git Hooks Issues

Hook fails with error:

# Check the specific error message
# Fix the underlying issue (e.g., Go syntax error, dependency issue)
# Commit again

Hook runs too slow:

# The hooks are optimized to only process necessary files
# If performance is an issue, check for very large Go files
# Consider splitting large files into smaller modules

Need to bypass hooks temporarily:

# Use --no-verify flag
git commit --no-verify -m "⚡ chore: quick fix"

# Remember to run hooks manually later
go mod tidy
gofmt -w .

Assets

  • gitmoji-cheatsheet.md: Quick reference for common gitmoji
  • commit-template.txt: Git commit message template
  • validate-commit.sh: Commit message validation script
  • git-hooks/: Git hooks for automatic code quality
    • pre-commit: Hook that runs go mod tidy and go fmt
    • README.md: Documentation for Git hooks