AgentSkillsCN

bitbucket-workflow

在Bitbucket中遵循Carefeed规范创建PR并调试流水线失败问题。自动从分支中提取Jira键,生成PR描述,并诊断CI失败。当用户提及PR、流水线或CI/CD时使用。

SKILL.md
--- frontmatter
name: bitbucket-workflow
description: Create PRs and debug pipeline failures in Bitbucket with Carefeed conventions. Auto-extracts Jira keys from branches, generates PR descriptions, and diagnoses CI failures. Use when user mentions PRs, pipelines, or CI/CD.

Bitbucket Workflow Skill

This skill handles Bitbucket PR creation and pipeline debugging using Carefeed team conventions. It integrates with Jira for ticket linking and follows team standards for PR formatting.

When to Use This Skill

Automatically trigger this skill when the user:

  • Wants to create a PR: "Create a PR", "Open a pull request", "Submit for review"
  • Mentions pipeline issues: "Pipeline failed", "CI is broken", "Build failed"
  • Asks about PR status: "What's the status of my PR?", "Any comments on the PR?"
  • Needs to debug failures: "Why did the build fail?", "What's wrong with the pipeline?"

Part 1: Creating Pull Requests

Prerequisites

  • Current branch follows naming: {type}/{JIRA-KEY}-{description}
  • Branch has commits ahead of target (usually master)
  • All changes are committed

Workflow

Step 1: Verify Branch State

bash
# Check commits ahead of target
git log origin/master..HEAD --oneline | wc -l

# Verify branch name format
git rev-parse --abbrev-ref HEAD

Step 2: Extract Jira Ticket

Parse Jira key from branch name:

  • feature/CORE-3982-null-safety-fuzzy-matching -> CORE-3982

Fetch ticket details:

code
mcp__jira__jira_get_issue(issueIdOrKey: "CORE-3982")

Step 3: Generate PR Description

Carefeed PR Template:

markdown
## Jira Ticket
[CORE-3982](https://carefeed.atlassian.net/browse/CORE-3982)

## Summary
[Brief overview from Jira or custom text]

## Changes
* [List of key changes]

## Testing
* [How changes were tested]

## Related
* [Related PRs/issues if applicable]

Generated with [Claude Code](https://claude.com/claude-code)

Step 4: Create PR via MCP

code
mcp__bitbucket__bb_add_pr({
  repoSlug: "portal_dev",
  prTitle: "CORE-3982: Handle null facility names in fuzzy matching",
  sourceBranch: "feature/CORE-3982-null-safety-fuzzy-matching",
  destinationBranch: "master",
  description: "[Generated description]",
  closeSourceBranch: false
})

Step 5: Link to Jira

Add comment to Jira ticket:

code
mcp__jira__jira_add_comment(
  issueIdOrKey: "CORE-3982",
  commentBody: "Pull Request created: [PR #4067](pr_url)"
)

Optionally transition to "In Review":

code
mcp__jira__jira_transition_issue(
  issueIdOrKey: "CORE-3982",
  transitionId: "In Review"
)

PR Title Format

Always include Jira key:

code
{JIRA-KEY}: {Jira issue summary}

Example: CORE-3982: Handle null facility names in fuzzy matching

Team-Specific Practices

TeamRequirements
CoreTech lead approval, extra review for DB migrations
IntegrationPCC staging test, document env vars
PaymentsSecurity review, test with Stripe test mode

Part 2: Debugging Pipeline Failures

Workflow

Step 1: Identify Failed Pipeline

List recent failed pipelines:

code
mcp__bitbucket__bb_list_pipelines({
  repoSlug: "portal_dev",
  state: "COMPLETED",
  result: "FAILED",
  limit: 10
})

Or get pipeline from PR:

code
mcp__bitbucket__bb_get_pr({
  repoSlug: "portal_dev",
  prId: "4067"
})

Step 2: Get Pipeline Overview

code
mcp__bitbucket__bb_get_pipeline({
  repoSlug: "portal_dev",
  pipelineId: "13906"
})

Returns:

  • Build number and status
  • Branch and commit
  • Duration
  • Result (SUCCESSFUL, FAILED, ERROR)

Step 3: List Pipeline Steps

code
mcp__bitbucket__bb_list_pipeline_steps({
  repoSlug: "portal_dev",
  pipelineId: "13906"
})

Step Status Legend:

  • SUCCESSFUL - Step passed
  • FAILED - Investigate this one
  • IN_PROGRESS - Still running
  • SKIPPED - Dependency failed

Step 4: Analyze Failure

Note: Bitbucket API doesn't expose step logs programmatically. You must view logs in the browser using the step URL.

Common PHP Test Failures:

  • Fatal error: Undefined method
  • Failed asserting that null is...
  • PDOException: SQLSTATE[23000]

Common Build Failures:

  • composer install failed
  • npm install failed
  • Docker build failed

Common Lint Failures:

  • PHPStan: Found X errors
  • PHP_CodeSniffer: X violations

Step 5: Correlate with Changes

Find last successful pipeline and compare:

code
mcp__bitbucket__bb_list_pipelines({
  repoSlug: "portal_dev",
  branch: "feature/CORE-3982",
  result: "SUCCESSFUL",
  limit: 1
})

Then diff the commits:

bash
git diff --name-only [last-success-commit] [failed-commit]

Step 6: Suggest Fix

Match error patterns to common causes:

Error PatternLikely Cause
Undefined method XMissing/renamed method
Failed asserting nullTest expects value but got null
SQLSTATE[23000]Database constraint violation
composer install failedDependency conflict
Class not foundMissing import/autoload

Pipeline Structure

code
Pipeline (build #13906)
  +-- Step 1: Build (docker, composer, npm)
  +-- Step 2: Test (phpunit, jest)
  +-- Step 3: Lint (phpstan, eslint)
  +-- Step 4: Deploy (if tests pass)

Steps run sequentially by default. If a step fails, subsequent steps are SKIPPED.


Example Conversations

Creating a PR

User: "Create a PR for this branch"

Claude:

code
I'll create a PR for your current branch.

Current branch: feature/CORE-3982-null-safety-fuzzy-matching
Jira ticket: CORE-3982 - Handle null facility names in fuzzy matching
Target: master (1 commit ahead)

PR Title: CORE-3982: Handle null facility names in fuzzy matching

Creating PR...

Created PR #4067: CORE-3982: Handle null facility names in fuzzy matching
https://bitbucket.org/Bitbucketpassword1/portal_dev/pull-requests/4067

Jira ticket CORE-3982 updated with PR link.

Debugging a Pipeline

User: "Pipeline #13906 failed, can you help debug?"

Claude:

code
I'll investigate pipeline #13906.

Pipeline Overview:
  Build: 13906
  Result: FAILED
  Branch: feature/CORE-3982-null-safety
  Duration: 3m 32s

Pipeline Steps:
  SUCCESSFUL Build
  FAILED PHP Test  <-- This is where it failed
  SKIPPED Deploy

The PHP Test step failed. View logs at:
https://bitbucket.org/.../steps/{uuid}

Recent changes in this branch:
  - app/Services/MarketAnalytics/FacilityMatcher.php
  - tests/Unit/MarketAnalytics/FacilityMatcherTest.php

Likely cause: Test expects non-null value but code now returns null for edge case.

Would you like me to:
1. Show the specific changes to FacilityMatcher.php
2. Help fix the test
3. Run tests locally first

Error Handling

Branch doesn't contain Jira key

Ask user for the Jira ticket or suggest renaming the branch.

No commits ahead of target

User needs to make changes and commit first.

Bitbucket authentication failed

Check MCP server is running and credentials are configured.

Pipeline not found

List recent pipelines to find the correct ID.

Logs not accessible via API

Provide the step URL for browser access (API limitation).


Anti-Patterns

  • Don't create PRs without checking for existing open PRs on the branch
  • Don't skip Jira ticket extraction - always link PRs to tickets
  • Don't guess at failure causes without checking the changed files
  • Don't assume logs are available via API - they require browser access