Skip to main content
MergeWatch can deliberately skip pull requests that do not need review. Skipped PRs are logged with a reason and visible in the dashboard, but no review comments are posted to GitHub.

What “Skipped” means

When a PR is skipped:
  • MergeWatch receives the webhook but does not run any agents against the diff.
  • The PR appears in the dashboard Reviews table with a status of Skipped and a reason explaining why.
  • Skipped reviews do not count toward billing. You are only billed for reviews that run agents against a diff.
Skipping is not the same as ignoring files. When individual files match ignorePatterns but other files in the PR do not, the PR is still reviewed — the matching files are simply excluded from the diff sent to agents.

Auto-skip rules

The following conditions cause MergeWatch to skip a pull request automatically:
ConditionDefault behaviorOverride
Draft PRSkipSet rules.skipDrafts: false
PR exceeds rules.maxFiles (default 50)SkipRaise rules.maxFiles
rules.autoReview: false and review not @mergewatch-triggeredSkipSet rules.autoReview: true or mention @mergewatch
PR has a label in rules.ignoreLabels (default: skip-review)SkipRemove the label or adjust ignoreLabels
All changed files match built-in trivial patterns (lock files, *.md, dist/**, build/**, node_modules/**, minified files, CI/editor config)SkipPass the PR through by changing a non-trivial file too
Bot comment loops are prevented at the webhook layer: @mergewatch mentions from senders of type Bot are ignored outright. This is orthogonal to skip rules — it applies to comment-triggered reviews regardless of your config.

Path-based exclusion

MergeWatch has two path-filtering mechanisms, and it’s important to understand they do different things:

Built-in PR-level skip (not configurable)

If every changed file in a PR matches one of the built-in trivial patterns, the PR is skipped entirely with a reason like “Only docs changed” or “Only lock files + config changed”. This list is baked in — you can’t add to it or remove from it. Built-in patterns include: lock files (*.lock, package-lock.json, yarn.lock, pnpm-lock.yaml, Gemfile.lock, Pipfile.lock, poetry.lock, composer.lock, go.sum), docs (*.md, *.mdx, *.txt, *.rst, docs/**, CHANGELOG*, LICENSE*), build artifacts (*.min.js, *.min.css, *.map, dist/**, build/**, node_modules/**), and editor/CI config (.github/**, .vscode/**, tsconfig.json, renovate.json, .eslintrc*, .prettierrc*, etc.).

File-level diff exclusion (configurable)

excludePatterns (top-level) and rules.ignorePatterns both filter individual files out of the diff sent to agents. They do not cause PR-level skipping — the PR is still reviewed as long as at least one non-built-in-skipped file is present.
.mergewatch.yml
version: 1
excludePatterns:
  - "**/*.generated.ts"
  - "**/fixtures/**"
rules:
  ignorePatterns:
    - "vendor/**"
    - "third_party/**"
Patterns use standard glob syntax relative to the repository root:
PatternMatches
*.lockAny file ending in .lock at any depth
dist/**All files under the dist/ directory
docs/*.mdMarkdown files directly in the docs/ directory
**/*.generated.tsGenerated TypeScript files at any depth

Label-based skip

Use ignoreLabels to skip PRs that carry specific GitHub labels:
.mergewatch.yml
version: 1
rules:
  ignoreLabels:
    - "skip-review"
    - "dependencies"
    - "automated"
When a PR has any label in the ignoreLabels list, it is skipped. This is useful for bot-generated PRs (such as Dependabot or Renovate) that you label consistently.

Skip log

Every skipped PR is logged to DynamoDB with the following information:
  • Repository and PR number
  • Skip reason (e.g., “All files matched ignorePatterns”, “Draft PR”, “Label: skip-review”)
  • Timestamp
You can view the full skip log in the dashboard:
1

Open the Reviews table

Navigate to Dashboard > Reviews and filter by status Skipped.
2

View the skip reason

Click on any skipped review to open the detail drawer. The Reason field explains why the PR was skipped.

Disabling configurable auto-skip

If you want MergeWatch to review every PR regardless of draft status, labels, or file patterns, relax the configurable rules:
.mergewatch.yml
version: 1
rules:
  skipDrafts: false
  ignorePatterns: []
  ignoreLabels: []
  maxFiles: 10000
excludePatterns: []
These settings relax the configurable rules. The built-in PR-level skip (lock-only, docs-only, build-artifacts-only) is not configurable — if every file in a PR is trivial, it is always skipped. Use @mergewatch review in a PR comment to force a review of a would-otherwise-be-skipped PR.

Next steps

Review Behavior

Understand when reviews trigger, status values, and re-triggering.

Custom Instructions

Inject project-specific guidance into agent prompts.