44 lines
2.1 KiB
Markdown
44 lines
2.1 KiB
Markdown
---
|
|
name: git-publish-workflow
|
|
description: Automates branching, conventional commits, testing, and PR creation for uncommitted or staged work.
|
|
version: 1.1.0
|
|
user-invocable: true
|
|
---
|
|
|
|
# Git Publish & PR Workflow
|
|
|
|
## **Objective**
|
|
To provide a hands-off, end-to-end automation for moving local changes into a formal Pull Request, ensuring code quality through automated and manual verification steps.
|
|
|
|
## **Execution Protocol**
|
|
|
|
### **Phase 1: Scope Determination**
|
|
Before execution, check the git index to determine the work boundary:
|
|
1. **Case A (Partial):** If staged changes exist, operate **ONLY** on staged changes.
|
|
2. **Case B (Full):** If no changes are staged, operate on **ALL** modified/untracked files.
|
|
|
|
### **Phase 2: The "Safe-Commit" Sequence**
|
|
1. **Branching**: Generate a `kebab-case` branch name (e.g., `feat-auth-logic` or `fix-header-css`).
|
|
2. **Naming**: Use **Conventional Commits** for the message (e.g., `feat(ui): add logout button`).
|
|
3. **Verification**:
|
|
* Identify the project type (e.g., Rust/Cargo, Python/Poetry, Node/NPM).
|
|
* Run the primary `test`, `lint`, or `build` command.
|
|
* **Abort Policy**: If verification fails, stop the sequence and report the error. Do not push.
|
|
|
|
### **Phase 3: Remote Integration**
|
|
1. **Push**: Upload the branch to `origin`.
|
|
2. **PR Creation**: Open a Pull Request targeting the default branch (usually `main` or `master`).
|
|
3. **Documentation**: Populate the PR description with:
|
|
* **Summary**: A high-level overview of "Why" and "What."
|
|
* **Manual Verification Checklist**: Provide a Markdown list (`- [ ]`) of 3-5 tactical steps for a human to verify the change in a live environment.
|
|
|
|
## **Constraints & Rules**
|
|
* **Atomic Commits**: If multiple distinct features are found in the scope, suggest splitting the work instead of one giant commit.
|
|
* **No Force Push**: Never use `--force` unless explicitly requested in the follow-up prompt.
|
|
* **Clean State**: Ensure the workflow ends with the user on the new branch, not the original branch.
|
|
|
|
## **Trigger Scenarios**
|
|
* User says: "Ship this."
|
|
* User says: "Make a PR for my current changes."
|
|
* Invoked via `/git-publish-workflow`.
|