pre-merge

Pre-Merge Verification

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 "pre-merge" with this command: npx skills add bobmatnyc/claude-mpm-skills/bobmatnyc-claude-mpm-skills-pre-merge

Pre-Merge Verification

Comprehensive verification workflow before merging changes to production.

When to Use This Skill

Use this skill when:

  • Creating a pull request for review

  • About to merge code to main/production branch

  • Need systematic verification checklist

  • Want to catch issues before code review

Pre-Commit Verification

Before committing code, verify:

  • Type checking passes (language-appropriate: tsc --noEmit , mypy , etc.)

  • Linting passes with no errors (ESLint, Pylint, etc.)

  • All existing tests pass locally

  • No console.log/debug statements left in code

  • Code follows project style guide

  • No commented-out code blocks

Commands by Language

TypeScript/JavaScript:

Type check

npx tsc --noEmit

Lint

npm run lint

or: pnpm lint

or: npx eslint .

Tests

npm test

or: pnpm test

Python:

Type check

mypy src/

Lint

pylint src/

or: flake8 src/

or: ruff check src/

Tests

pytest

or: python -m pytest

Go:

Format check

gofmt -l .

Lint

golangci-lint run

Tests

go test ./...

Pre-PR Verification

Before creating a pull request, ensure:

Required Information

  • Changeset added for user-facing changes (if using changesets)

  • PR description is complete with:

  • Summary of changes

  • Related ticket references (ENG-XXX, HEL-XXX, JIRA-XXX, etc.)

  • Screenshots for UI changes (desktop, tablet, mobile)

  • Breaking changes documented

  • Migration guide (if breaking changes)

  • New tests added for new functionality

  • Documentation updated if needed (README, API docs, etc.)

Security Checklist (if API changes)

  • Authentication required on protected routes

  • Authorization checks implemented

  • Input validation with schema (Zod, Pydantic, etc.)

  • No sensitive data in logs

  • No SQL injection vulnerabilities

  • No XSS vulnerabilities

  • Rate limiting considered

Database Changes (if schema changes)

  • Migration file created

  • Migration tested on local database

  • Migration tested on staging database

  • Down migration available (rollback plan)

  • No breaking changes without migration guide

  • Schema changes documented

UI Changes (if applicable)

  • Screenshots included:

  • Desktop view (1920x1080)

  • Tablet view (768x1024)

  • Mobile view (375x667)

  • Responsive behavior verified

  • Accessibility checked (keyboard navigation, screen readers)

  • Loading states implemented

  • Error states implemented

Pre-Merge Verification

Before merging to main branch, confirm:

CI/CD Checks

  • All CI checks pass (lint, type-check, tests, build)

  • Code review approved by at least one reviewer

  • No TypeScript errors in changed files

  • No merge conflicts with target branch

  • Build succeeds without warnings

Functional Verification

  • Database migrations run successfully (if applicable)

  • No regression in existing functionality

  • Performance benchmarks within acceptable range

  • Manual testing completed for critical paths

Documentation

  • CHANGELOG.md updated (if using)

  • API documentation updated (if API changes)

  • README updated (if setup/usage changes)

  • Migration guide provided (if breaking changes)

PR Description Template

Use this template for comprehensive PR descriptions:

Summary

[Brief description of what this PR does]

Related Tickets

  • Fixes #123
  • Closes ENG-456
  • Related to HEL-789

Changes

  • Feature: [Description]
  • Bug Fix: [Description]
  • Refactor: [Description]
  • Documentation: [Description]

Testing

Unit Tests

  • Added tests for [feature/function]
  • Coverage: X%

Manual Testing

  • Tested on desktop (Chrome, Firefox, Safari)
  • Tested on mobile (iOS Safari, Android Chrome)
  • Tested edge cases: [list specific cases]

Screenshots

Desktop

Desktop view

Tablet

Tablet view

Mobile

Mobile view

Breaking Changes

[List any breaking changes or write "None"]

Migration Guide

[If breaking changes, provide migration steps]

Performance Impact

[Describe any performance implications or write "No impact"]

Security Considerations

[Describe security implications or write "No security impact"]

Rollback Plan

[Describe how to rollback if issues occur]

Deployment Notes

[Any special deployment considerations or write "Standard deployment"]

Common Pitfalls to Avoid

Pre-Commit

  • ❌ Committing code with failing tests

  • ❌ Leaving console.log/debug statements

  • ❌ Committing without running type checker

  • ❌ Committing large blocks of commented code

Pre-PR

  • ❌ Creating PR without description

  • ❌ Missing screenshots for UI changes

  • ❌ Not linking to related tickets

  • ❌ Not documenting breaking changes

  • ❌ Missing test coverage for new code

Pre-Merge

  • ❌ Merging with failing CI checks

  • ❌ Merging without code review approval

  • ❌ Merging with merge conflicts

  • ❌ Merging without testing migrations

  • ❌ Merging without considering rollback plan

Quick Verification Script

Create a pre-commit verification script:

JavaScript/TypeScript (pre-commit.sh):

#!/bin/bash set -e

echo "Running type check..." npx tsc --noEmit

echo "Running linter..." npm run lint

echo "Running tests..." npm test -- --run

echo "✅ All checks passed!"

Python (pre-commit.sh):

#!/bin/bash set -e

echo "Running type check..." mypy src/

echo "Running linter..." pylint src/

echo "Running tests..." pytest

echo "✅ All checks passed!"

Make executable:

chmod +x pre-commit.sh

Automation with Git Hooks

Set up automatic pre-commit checks:

Using Husky (JavaScript/TypeScript)

npm install --save-dev husky npx husky install npx husky add .husky/pre-commit "npm run lint && npm test"

Using pre-commit (Python)

Create .pre-commit-config.yaml :

repos:

  • repo: local hooks:
    • id: type-check name: Type Check entry: mypy src/ language: system pass_filenames: false
    • id: lint name: Lint entry: pylint src/ language: system pass_filenames: false
    • id: test name: Test entry: pytest language: system pass_filenames: false

Install hooks:

pre-commit install

Success Criteria

Pre-Commit Success

  • ✅ All local checks pass

  • ✅ Code is formatted correctly

  • ✅ No debug statements remain

  • ✅ Tests pass locally

Pre-PR Success

  • ✅ PR description is comprehensive

  • ✅ All required information included

  • ✅ Screenshots attached (if UI changes)

  • ✅ Breaking changes documented

Pre-Merge Success

  • ✅ CI pipeline is green

  • ✅ Code review approved

  • ✅ No conflicts with target branch

  • ✅ Manual testing completed

Related Skills

  • universal-verification-screenshot

  • Screenshot verification for UI changes

  • universal-verification-bug-fix

  • Bug fix verification workflow

  • toolchains-universal-security-api-review

  • API security testing

  • universal-collaboration-git-workflow

  • Git workflow best practices

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.

General

drizzle-orm

No summary provided by upstream source.

Repository SourceNeeds Review
General

pydantic

No summary provided by upstream source.

Repository SourceNeeds Review
General

playwright-e2e-testing

No summary provided by upstream source.

Repository SourceNeeds Review
General

tailwind-css

No summary provided by upstream source.

Repository SourceNeeds Review