Merge pull request #1820 from restic/fix-1803

termstatus: Fix panic for non-terminal runs
This commit is contained in:
Alexander Neumann 2018-05-27 13:08:25 +02:00
commit 0183fea926
2 changed files with 48 additions and 6 deletions

View file

@ -290,6 +290,20 @@ func (t *Terminal) Errorf(msg string, args ...interface{}) {
t.Error(s) t.Error(s)
} }
// truncate returns a string that has at most maxlen characters. If maxlen is
// negative, the empty string is returned.
func truncate(s string, maxlen int) string {
if maxlen < 0 {
return ""
}
if len(s) < maxlen {
return s
}
return s[:maxlen]
}
// SetStatus updates the status lines. // SetStatus updates the status lines.
func (t *Terminal) SetStatus(lines []string) { func (t *Terminal) SetStatus(lines []string) {
if len(lines) == 0 { if len(lines) == 0 {
@ -297,7 +311,7 @@ func (t *Terminal) SetStatus(lines []string) {
} }
width, _, err := getTermSize(t.fd) width, _, err := getTermSize(t.fd)
if err != nil || width < 0 { if err != nil || width <= 0 {
// use 80 columns by default // use 80 columns by default
width = 80 width = 80
} }
@ -305,11 +319,7 @@ func (t *Terminal) SetStatus(lines []string) {
// make sure that all lines have a line break and are not too long // make sure that all lines have a line break and are not too long
for i, line := range lines { for i, line := range lines {
line = strings.TrimRight(line, "\n") line = strings.TrimRight(line, "\n")
line = truncate(line, width-2) + "\n"
if len(line) >= width-2 {
line = line[:width-2]
}
line += "\n"
lines[i] = line lines[i] = line
} }

View file

@ -0,0 +1,32 @@
package termstatus
import "testing"
func TestTruncate(t *testing.T) {
var tests = []struct {
input string
maxlen int
output string
}{
{"", 80, ""},
{"", 0, ""},
{"", -1, ""},
{"foo", 80, "foo"},
{"foo", 4, "foo"},
{"foo", 3, "foo"},
{"foo", 2, "fo"},
{"foo", 1, "f"},
{"foo", 0, ""},
{"foo", -1, ""},
}
for _, test := range tests {
t.Run("", func(t *testing.T) {
out := truncate(test.input, test.maxlen)
if out != test.output {
t.Fatalf("wrong output for input %v, maxlen %d: want %q, got %q",
test.input, test.maxlen, test.output, out)
}
})
}
}