Skip to content

A tool for seamless branch creation by passing the Issue Key into the CLI and deletion.

Notifications You must be signed in to change notification settings

yaroslav-android/brcha

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

brcha brcha

Overview

Streamline your workflow with a CLI tool that integrates Git and Jira. Quickly create, name, and delete branches using the Issue Key, ensuring consistency and efficiency in branch management.

Features

  • Seamless Branch Creation: Easily create new Git branches by simply passing the Issue Key into the CLI.
  • Integration with Git and Jira: Leverages the Git and Jira APIs to streamline your workflow.
  • Automated Branch Naming: Automatically generates branch names based on Jira Ticket Summary, ensuring consistent and meaningful branch names.
  • Branch Deletion: Conveniently delete branches directly from the CLI for efficient repository management.

Installation

  1. Configure your Jira API settings in the .env file.
BRCHA_HOST=example.atlassian.net
BRCHA_EMAIL=[email protected]
BRCHA_TOKEN=api_token

NOTE: for Bearer auth leave BRCHA_EMAIL field empty!

  1. Define mappings for your Jira issue types in the configuration the .env file. Use zero if you want to ignore a specific type.
BRCHA_TYPE_MAPPING=build:0;chore:0;ci:0;docs:0;feat:0;fix:0;pref:0;refactor:0;revert:0;style:0;test:0

If you have multiple IDs of the same type, separate them with a comma (,).

BRCHA_TYPE_MAPPING=build:10001,10002,10003;...

You can curl available issuetypes from Jira.

curl \
    -D- \
    -X GET \
    -u "[email protected]:token" \
    -H "Content-Type: application/json" \
    https://{host}/rest/api/2/issuetype

or

curl \
    -D- \
    -X GET \
    -H "Authorization: Bearer {token}" \
    -H "Content-Type: application/json" \
    https://{host}/rest/api/2/issuetype
  1. Specify the branch that will serve as the base when checking out before deleting local branches. This ensures consistency and avoids issues during cleanup operations.
BRCHA_DEV_BRANCH_NAME=develop
  1. Specify any exclusion phrases to be removed from the branch name, if applicable.
BRCHA_EXCLUDE_PHRASES=front,mobile,android,ios,be,web,spike,eval
  1. Copy .env file into ~/.config/brcha/ folder.
mkdir -p ~/.config/brcha/ && \
cp .env ~/.config/brcha/
  1. Compile the tool into an executable file or download compiled executable.
go build
  1. Move the executable into /usr/local/bin for easy global access.
mv brcha /usr/local/bin

Usage

brcha [arguments]

Commands

Note: Remote branches can only be deleted if a corresponding local branch exists.

help - Displays help information for all available commands and options in the CLI tool, providing usage instructions and examples. Use this command to understand how to use the tool effectively.

brcha -help

i <issue-key> - The branch prefix after branch type. Uses Jira Issue Key.

brcha -i XXX-00

t <branch-type> - (optional) Overrides the type of branch to create, allowing the branch name ignore mapped Jira issue types. Branches are named according to the standard.

brcha -i XXX-00 -t ci

Available branch types

  • build, b - Changes that affect the build system or external dependencies (example scopes: gradle, npm)
  • chore, ch - Routine tasks that don't affect the functionality or user-facing aspects of a project
  • ci - Changes to our CI configuration files and scripts (example scopes: Travis, Circle, BrowserStack, SauceLabs)
  • docs, d - Documentation only changes
  • feat, ft - A new feature
  • fix, fx - A bug fix
  • perf, p - A code change that improves performance
  • refactor, rf - A code change that neither fixes a bug nor adds a feature
  • revert, rv - A code that restors to a previous or default condition
  • style, s - Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
  • test, t - Adding missing tests or correcting existing tests

clean - Deletes all local branches which have Jira tickets in 'Done' state.

brcha -clean

r <remote> - (optional) Allows the deletion of remote branches alongside their corresponding local branches.

brcha -clean -r origin

assignee <username> - (optional) Specifies the username (from the email) to verify that the Jira issue is assigned to you before permitting remote branch deletion. Use your Jira email, which might match BRCHA_EMAIL, e.g., [email protected].

brcha -clean -r origin -assignee example.user

Configuration

In case you want to experiment with custom branch formatting or extend existing methods go to branch.go file.

func BuildName(bt Type, jiraIssue network.JiraIssue, excludePhrases string) string {
    summary := replacePhrases(*jiraIssue.Fields.Summary, excludePhrases)
    summary = strings.ToLower(summary)
    summary = strings.TrimSpace(summary)
    summary = stripRegex(summary)
    summary = strings.TrimSuffix(summary, wordSeparator)

    ...

    // returns "branchType/jiraIssue.Key_summary"
}

Examples

~% brcha -i XX-111
~% branch created: task/XX-111_jira-issue-name
~% brcha -i XX-111 -t fx
~% branch created: fix/XX-111_jira-issue-name
~% brcha -clean
~% branch deleted: fix/XX-111_jira-issue-name
~% brcha -clean -r origin
~% branch deleted: fix/XX-111_jira-issue-name
~% remote branch deleted: origin/fix/XX-111_jira-issue-name
~% brcha -clean -r origin -assignee example.user
~% branch deleted: fix/XX-111_jira-issue-name
~% remote branch deleted: origin/fix/XX-111_jira-issue-name

About

A tool for seamless branch creation by passing the Issue Key into the CLI and deletion.

Topics

Resources

Stars

Watchers

Forks

Languages