Git checks and how to use them
gitz
comes with a series of inbuilt checks for inspecting the environment and current repository.
Checking for the existence of a Git Client
When creating a new client, gitz
will check for the existence of git using the PATH
environment variable. An error is returned if no client exists.
| package main
import (
"fmt"
"log"
git "github.com/purpleclay/gitz"
)
func main() {
client, err := git.NewClient()
if err != nil {
log.Fatal(err.Error())
}
fmt.Println(client.Version())
}
|
Checking the integrity of a Repository
Check the integrity of a repository by running a series of tests and capturing the results for inspection.
| package main
import (
"fmt"
"log"
git "github.com/purpleclay/gitz"
)
func main() {
client, _ := git.NewClient()
repo, err := client.Repository()
if err != nil {
log.Fatal("failed to check the current repository")
}
fmt.Printf("Clone Depth: %d\n", repo.CloneDepth)
fmt.Printf("Default Branch: %s\n", repo.DefaultBranch)
fmt.Printf("Detached Head: %t\n", repo.DetachedHead)
fmt.Printf("Origin: %s\n", repo.Origin)
fmt.Printf("Ref: %s\n", repo.Ref)
fmt.Printf("Remotes: %#v\n", repo.Remotes)
fmt.Printf("Root Directory: %s\n", repo.RootDir)
fmt.Printf("Shallow Clone: %t\n", repo.ShallowClone)
}
|
Example output when checking the integrity of a repository cloned within a CI system:
Clone Depth: 10
Default Branch: main
Detached Head: true
Origin: git@github.com:purpleclay/gitz.git
Ref: ee755fa89b96323b504833ad6ac188417cb04123
Remotes: map[string]string{"origin":"git@github.com:purpleclay/gitz.git"}
Root Directory: /dev/github.com/purpleclay/gitz
Shallow Clone: false