Files
Reza Rezvani f4a9cde448 docs(workflow): implement branch protection and workflow documentation
Changes:
- Created documentation/WORKFLOW.md (comprehensive workflow guide)
  - Daily development workflow (feature → dev → main)
  - Branch naming conventions and examples
  - PR creation and review process
  - Common scenarios (new agent, bug fix, hotfix)
  - Quality checks and best practices
  - Emergency procedures

- Updated CLAUDE.md Git Workflow section
  - Document branch protection on main (PR required)
  - Add quick start workflow guide
  - Reference new WORKFLOW.md document
  - Update sprint status to complete

- Set up GitHub branch protection on main branch
  - Required PR approval (1 reviewer)
  - Dismiss stale reviews
  - Require conversation resolution
  - Enforce for admins
  - Block force pushes and deletions

- Synced dev branch with main (merged 18 commits)

Resolves violation of pushing directly to main (18 commits).
Going forward: All changes via feature branches → dev → main (PR only).

Issue: Process improvement post-sprint-11-05-2025
2025-11-05 16:41:29 +01:00

12 KiB

Development Workflow

Repository: claude-code-skills Branch Strategy: feature → dev → main (PR only) Last Updated: November 5, 2025


Quick Start

# 1. Always start from dev
git checkout dev
git pull origin dev

# 2. Create feature branch
git checkout -b feature/agents-{name}

# 3. Work and commit
git add .
git commit -m "feat(agents): implement {name}"

# 4. Push to remote
git push origin feature/agents-{name}

# 5. Create PR to dev (NOT main)
gh pr create --base dev --head feature/agents-{name}

# 6. After PR approved and merged, delete feature branch
git branch -d feature/agents-{name}

Branch Structure

Main Branches

main

  • Production-ready code only
  • Protected: requires PR approval
  • No direct pushes allowed
  • Tagged releases only

dev

  • Integration branch
  • All feature branches merge here first
  • Testing and validation happens here
  • Periodically merged to main via PR

Feature Branches

Naming Convention:

feature/{domain}-{component}      # New features
fix/{issue-number}-{description}  # Bug fixes
docs/{component}                  # Documentation updates
refactor/{component}              # Code refactoring
test/{feature}                    # Testing updates

Examples:

feature/agents-cfo-advisor
feature/marketing-email-campaign-tool
fix/42-broken-relative-paths
docs/installation-guide
refactor/skill-directory-structure
test/python-tool-integration

Daily Workflow

Starting New Work

# 1. Update dev branch
git checkout dev
git pull origin dev

# 2. Create feature branch (use correct naming)
git checkout -b feature/agents-data-scientist

# 3. Verify you're on the right branch
git branch
# Should show: * feature/agents-data-scientist

Making Changes

# 1. Make your changes
# ... edit files ...

# 2. Check status
git status

# 3. Stage changes
git add agents/engineering/cs-data-scientist.md

# 4. Commit with conventional commit format
git commit -m "feat(agents): implement cs-data-scientist agent

- Add YAML frontmatter with required fields
- Document 4 workflows (data analysis, ML pipeline, A/B testing, metrics dashboard)
- Add integration with data analysis Python tools
- Test relative path resolution

Issue: #25"

# 5. Continue working or push

Pushing to Remote

# 1. Push feature branch to remote
git push origin feature/agents-data-scientist

# 2. If first push, set upstream
git push -u origin feature/agents-data-scientist

Creating Pull Request

# 1. Create PR to dev (NOT main!)
gh pr create \
  --base dev \
  --head feature/agents-data-scientist \
  --title "feat(agents): implement cs-data-scientist agent" \
  --body "Closes #25

## Summary
Implements data scientist agent with ML pipeline workflows and statistical analysis tools.

## Changes
- Created cs-data-scientist.md (425 lines)
- Added 4 complete workflows
- Integrated with 3 Python tools
- Tested all relative paths

## Testing
- [x] YAML frontmatter valid
- [x] Relative paths resolve correctly
- [x] Python tools execute successfully
- [x] All workflows documented with examples
- [x] Success metrics defined

## Checklist
- [x] Follows communication standards
- [x] Meets quality standards
- [x] Conventional commit format
- [x] Documentation updated
- [x] No security issues"

# 2. Verify PR created
gh pr list

After PR Approval

# 1. PR gets approved and merged to dev by reviewer
# (automatic via GitHub UI or gh CLI by reviewer)

# 2. Switch back to dev
git checkout dev

# 3. Pull latest (includes your merged changes)
git pull origin dev

# 4. Delete local feature branch
git branch -d feature/agents-data-scientist

# 5. Delete remote feature branch (if not auto-deleted)
git push origin --delete feature/agents-data-scientist

Branch Protection Rules

Main Branch (Protected)

Requirements:

  • Pull request required (no direct push)
  • 1 approval required
  • Dismiss stale reviews
  • Require conversation resolution
  • Enforce for admins
  • No force pushes
  • No deletions

Implications:

  • You cannot git push origin main directly
  • All changes must go through PR process
  • Reviewers must approve before merge
  • CI checks must pass (when configured)

Dev Branch (Unprotected)

Current State:

  • Direct push allowed (but discouraged)
  • PRs from feature branches preferred
  • Integration testing happens here

Best Practice:

  • Still use PRs for feature branches → dev
  • Allows multiple developers to work in parallel
  • Easier to review changes in isolation

Common Scenarios

Scenario 1: New Agent Development

# Start work
git checkout dev
git pull origin dev
git checkout -b feature/agents-product-designer

# Create agent file
vim agents/product/cs-product-designer.md

# Commit
git add agents/product/cs-product-designer.md
git commit -m "feat(agents): implement cs-product-designer agent"

# Push
git push origin feature/agents-product-designer

# Create PR to dev
gh pr create --base dev --head feature/agents-product-designer

# After merge, cleanup
git checkout dev
git pull origin dev
git branch -d feature/agents-product-designer

Scenario 2: Bug Fix

# Start from dev
git checkout dev
git pull origin dev
git checkout -b fix/34-yaml-validation-error

# Fix the bug
vim agents/marketing/cs-content-creator.md

# Commit
git add agents/marketing/cs-content-creator.md
git commit -m "fix(agents): correct YAML frontmatter in cs-content-creator

Problem: YAML frontmatter missing 'tools' field causing validation errors
Solution: Added tools: [Read, Write, Bash, Grep, Glob] to frontmatter
Impact: All agents now validate correctly

Fixes #34"

# Push and PR
git push origin fix/34-yaml-validation-error
gh pr create --base dev --head fix/34-yaml-validation-error

Scenario 3: Documentation Update

# Start from dev
git checkout dev
git pull origin dev
git checkout -b docs/workflow-guide

# Update documentation
vim documentation/WORKFLOW.md

# Commit
git add documentation/WORKFLOW.md
git commit -m "docs(workflow): add branch protection section"

# Push and PR
git push origin docs/workflow-guide
gh pr create --base dev --head docs/workflow-guide

Scenario 4: Sprint Work

# Sprint planning complete, ready to implement
git checkout dev
git pull origin dev
git checkout -b feature/sprint-11-12-2025

# Work on multiple related files
git add agents/engineering/cs-ml-engineer.md
git commit -m "feat(agents): implement cs-ml-engineer"

git add agents/engineering/cs-devops-engineer.md
git commit -m "feat(agents): implement cs-devops-engineer"

git add documentation/delivery/sprint-11-12-2025/PROGRESS.md
git commit -m "docs(sprint): update progress tracker"

# Push all commits
git push origin feature/sprint-11-12-2025

# Create PR
gh pr create --base dev --head feature/sprint-11-12-2025

Scenario 5: Hotfix (Critical Bug in Production)

# Start from main for hotfixes
git checkout main
git pull origin main
git checkout -b hotfix/critical-path-resolution

# Fix critical issue
vim agents/product/cs-product-manager.md

# Commit
git commit -am "fix(agents)!: resolve critical path resolution failure

BREAKING CHANGE: relative paths now require project root reference

Fixes #89
Priority: P0"

# Push to remote
git push origin hotfix/critical-path-resolution

# Create PR directly to main (exception for hotfixes)
gh pr create --base main --head hotfix/critical-path-resolution --label "P0,hotfix"

# After merge to main, also merge to dev
git checkout dev
git merge main
git push origin dev

Merge Strategy

Feature → Dev

# Prefer squash merge for clean history
gh pr merge feature/agents-new-agent \
  --squash \
  --delete-branch

Dev → Main

# Create PR from dev to main
git checkout dev
git pull origin dev
gh pr create --base main --head dev \
  --title "release: merge dev to main for v2.1.0" \
  --body "## Release v2.1.0

### New Features
- cs-data-scientist agent
- cs-ml-engineer agent
- cs-devops-engineer agent

### Bug Fixes
- Fixed YAML validation in cs-content-creator
- Corrected relative paths in cs-product-manager

### Documentation
- Added WORKFLOW.md
- Updated sprint progress trackers

### Testing
- All agents validated (100% pass rate)
- All Python tools tested
- All reference files accessible"

# After approval, use merge commit (preserve dev history)
gh pr merge dev --merge --delete-branch=false

Quality Checks

Before Committing

# 1. Verify no secrets
git diff --cached | grep -iE '(api[_-]?key|secret|password|token).*=.*[^x{5}]'

# 2. Validate Python syntax (if Python files changed)
python3 -m py_compile $(git diff --cached --name-only --diff-filter=ACM | grep '\.py$')

# 3. Check conventional commit format
# Use: <type>[(scope)]: <description>

Before Creating PR

# 1. Run full test suite (if available)
npm test

# 2. Validate all relative paths
find agents -name "cs-*.md" -exec echo "Testing: {}" \;

# 3. Check documentation links
# (manual review recommended)

# 4. Verify YAML frontmatter
find agents -name "cs-*.md" -exec head -10 {} \; | grep -E "^(name|description|skills|domain|model|tools):"

Emergency Procedures

Accidentally Pushed to Main

# This will fail now due to branch protection
git push origin main
# Error: protected branch hook declined

# Solution: Create PR instead
git checkout -b fix/emergency-correction
git push origin fix/emergency-correction
gh pr create --base main --head fix/emergency-correction

Need to Rollback Dev

# Revert specific commit
git checkout dev
git revert <commit-hash>
git push origin dev

# Or reset to previous state (use with caution!)
git checkout dev
git reset --hard <good-commit-hash>
git push origin dev --force  # Only on dev, never main!

Merge Conflict

# During PR merge, conflicts occur
git checkout feature/my-branch
git pull origin dev
# Resolve conflicts in editor
git add .
git commit -m "chore: resolve merge conflicts with dev"
git push origin feature/my-branch
# PR will update automatically

Best Practices

DO

  • Always start from dev branch
  • Use conventional commit format
  • Create PRs for all changes
  • Reference issue numbers in commits
  • Test changes before pushing
  • Delete branches after merge
  • Keep commits atomic (one logical change)
  • Write descriptive PR descriptions

DON'T

  • Push directly to main (blocked by protection)
  • Push directly to dev (use PRs instead)
  • Commit secrets or credentials
  • Mix multiple unrelated changes
  • Use vague commit messages
  • Leave stale branches unmerged
  • Skip quality checks
  • Force push to shared branches


FAQ

Q: Why can't I push to main anymore? A: Branch protection is now active. All changes must go through PR process with approval.

Q: Do I need approval for dev branch too? A: Not currently required, but PRs are still recommended for clean review process.

Q: What if I'm the only developer? A: Still use PRs. It provides review checkpoint, CI integration, and clear history.

Q: Can I merge my own PRs? A: For dev branch yes, for main branch you need another reviewer's approval.

Q: What happens to old commits made directly to main? A: They remain in history. Branch protection only affects new pushes.

Q: How do I bypass branch protection for emergencies? A: You can't (by design). Even admins are enforced. Use hotfix PR process.


Last Updated: November 5, 2025 Branch Protection: Active on main Status: Enforced for all contributors including admins