6
0
mirror of https://github.com/grdl/git-get.git synced 2026-02-07 21:39:15 +00:00

Add upstream info to branch status, simplify unit tests

This commit is contained in:
Grzegorz Dlugoszewski
2020-05-19 10:24:25 +02:00
parent ad7c3a4afc
commit 17ec470340
2 changed files with 37 additions and 17 deletions

View File

@@ -33,7 +33,7 @@ func Branches(repo *git.Repository) ([]BranchStatus, error) {
var statuses []BranchStatus var statuses []BranchStatus
for _, branch := range branches { for _, branch := range branches {
status, err := NewBranchStatus(branch) status, err := NewBranchStatus(repo, branch)
if err != nil { if err != nil {
// TODO: handle error // TODO: handle error
continue continue
@@ -44,7 +44,7 @@ func Branches(repo *git.Repository) ([]BranchStatus, error) {
return statuses, nil return statuses, nil
} }
func NewBranchStatus(branch *git.Branch) (BranchStatus, error) { func NewBranchStatus(repo *git.Repository, branch *git.Branch) (BranchStatus, error) {
var status BranchStatus var status BranchStatus
name, err := branch.Name() name, err := branch.Name()
@@ -55,12 +55,28 @@ func NewBranchStatus(branch *git.Branch) (BranchStatus, error) {
status.IsRemote = branch.IsRemote() status.IsRemote = branch.IsRemote()
_, err = branch.Upstream() upstream, err := branch.Upstream()
if err != nil { if err != nil && !git.IsErrorCode(err, git.ErrNotFound) {
if git.IsErrorCode(err, git.ErrNotFound) { return status, errors.Wrap(err, "Failed getting branch upstream")
status.HasUpstream = false }
} else {
return status, errors.Wrap(err, "Failed getting branch upstream") if upstream != nil {
status.HasUpstream = true
ahead, behind, err := repo.AheadBehind(branch.Target(), upstream.Target())
if err != nil {
return status, errors.Wrap(err, "Failed getting ahead/behind information")
}
status.Ahead = ahead
status.Behind = behind
if ahead > 0 {
status.NeedsPush = true
}
if behind > 0 {
status.NeedsPull = true
} }
} }

View File

@@ -2,11 +2,9 @@ package main
import ( import (
"testing" "testing"
"github.com/pkg/errors"
) )
func TestNewBranch(t *testing.T) { func TestNewLocalBranch(t *testing.T) {
repo := newTestRepo(t) repo := newTestRepo(t)
createFile(t, repo, "file") createFile(t, repo, "file")
@@ -14,14 +12,20 @@ func TestNewBranch(t *testing.T) {
createCommit(t, repo, "Initial commit") createCommit(t, repo, "Initial commit")
branch := createBranch(t, repo, "branch") branch := createBranch(t, repo, "branch")
status, err := NewBranchStatus(branch) status, err := NewBranchStatus(repo, branch)
checkFatal(t, errors.Wrap(err, "Failed getting branch status")) checkFatal(t, err)
if status.Name != "branch" { want := BranchStatus{
t.Errorf("Wrong branch name, got %s; want %s", status.Name, "branch") Name: "branch",
IsRemote: false,
HasUpstream: false,
NeedsPull: false,
NeedsPush: false,
Ahead: 0,
Behind: 0,
} }
if status.IsRemote != false { if status != want {
t.Errorf("Branch should be local") t.Errorf("Wrong branch status, got %+v; want %+v", status, want)
} }
} }