Write git clone progress only if terminal is a TTY (#670)
This commit is contained in:
parent
37a98f134a
commit
a07cb440c2
2 changed files with 18 additions and 20 deletions
1
go.mod
1
go.mod
|
@ -20,6 +20,7 @@ require (
|
||||||
github.com/joho/godotenv v1.3.0
|
github.com/joho/godotenv v1.3.0
|
||||||
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51
|
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51
|
||||||
github.com/kevinburke/ssh_config v0.0.0-20201106050909-4977a11b4351 // indirect
|
github.com/kevinburke/ssh_config v0.0.0-20201106050909-4977a11b4351 // indirect
|
||||||
|
github.com/mattn/go-isatty v0.0.12
|
||||||
github.com/mitchellh/go-homedir v1.1.0
|
github.com/mitchellh/go-homedir v1.1.0
|
||||||
github.com/moby/buildkit v0.8.1
|
github.com/moby/buildkit v0.8.1
|
||||||
github.com/moby/sys/mount v0.2.0 // indirect
|
github.com/moby/sys/mount v0.2.0 // indirect
|
||||||
|
|
|
@ -17,6 +17,7 @@ import (
|
||||||
"github.com/go-git/go-git/v5/plumbing"
|
"github.com/go-git/go-git/v5/plumbing"
|
||||||
"github.com/go-git/go-git/v5/plumbing/transport/http"
|
"github.com/go-git/go-git/v5/plumbing/transport/http"
|
||||||
"github.com/go-ini/ini"
|
"github.com/go-ini/ini"
|
||||||
|
"github.com/mattn/go-isatty"
|
||||||
log "github.com/sirupsen/logrus"
|
log "github.com/sirupsen/logrus"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -238,29 +239,25 @@ func CloneIfRequired(ctx context.Context, refName plumbing.ReferenceName, input
|
||||||
r, err := git.PlainOpen(input.Dir)
|
r, err := git.PlainOpen(input.Dir)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
var progressWriter io.Writer
|
var progressWriter io.Writer
|
||||||
if entry, ok := logger.(*log.Entry); ok {
|
if isatty.IsTerminal(os.Stdout.Fd()) || isatty.IsCygwinTerminal(os.Stdout.Fd()) {
|
||||||
progressWriter = entry.WriterLevel(log.DebugLevel)
|
if entry, ok := logger.(*log.Entry); ok {
|
||||||
} else if lgr, ok := logger.(*log.Logger); ok {
|
progressWriter = entry.WriterLevel(log.DebugLevel)
|
||||||
progressWriter = lgr.WriterLevel(log.DebugLevel)
|
} else if lgr, ok := logger.(*log.Logger); ok {
|
||||||
} else {
|
progressWriter = lgr.WriterLevel(log.DebugLevel)
|
||||||
log.Errorf("Unable to get writer from logger (type=%T)", logger)
|
} else {
|
||||||
progressWriter = os.Stdout
|
log.Errorf("Unable to get writer from logger (type=%T)", logger)
|
||||||
|
progressWriter = os.Stdout
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var cloneOptions git.CloneOptions
|
cloneOptions := git.CloneOptions{
|
||||||
|
URL: input.URL,
|
||||||
|
Progress: progressWriter,
|
||||||
|
}
|
||||||
if input.Token != "" {
|
if input.Token != "" {
|
||||||
cloneOptions = git.CloneOptions{
|
cloneOptions.Auth = &http.BasicAuth{
|
||||||
URL: input.URL,
|
Username: "token",
|
||||||
Progress: progressWriter,
|
Password: input.Token,
|
||||||
Auth: &http.BasicAuth{
|
|
||||||
Username: "token",
|
|
||||||
Password: input.Token,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
cloneOptions = git.CloneOptions{
|
|
||||||
URL: input.URL,
|
|
||||||
Progress: progressWriter,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue