155 lines
3.0 KiB
Go
155 lines
3.0 KiB
Go
|
package pb
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
"strings"
|
||
|
"sync"
|
||
|
"testing"
|
||
|
"time"
|
||
|
|
||
|
"github.com/fatih/color"
|
||
|
"github.com/mattn/go-colorable"
|
||
|
)
|
||
|
|
||
|
func Test_IncrementAddsOne(t *testing.T) {
|
||
|
count := 5000
|
||
|
bar := New(count)
|
||
|
expected := 1
|
||
|
actual := bar.Increment()
|
||
|
|
||
|
if actual != expected {
|
||
|
t.Errorf("Expected {%d} was {%d}", expected, actual)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_Width(t *testing.T) {
|
||
|
count := 5000
|
||
|
bar := New(count)
|
||
|
width := 100
|
||
|
bar.SetWidth(100).Callback = func(out string) {
|
||
|
if len(out) != width {
|
||
|
t.Errorf("Bar width expected {%d} was {%d}", len(out), width)
|
||
|
}
|
||
|
}
|
||
|
bar.Start()
|
||
|
bar.Increment()
|
||
|
bar.Finish()
|
||
|
}
|
||
|
|
||
|
func Test_MultipleFinish(t *testing.T) {
|
||
|
bar := New(5000)
|
||
|
bar.Add(2000)
|
||
|
bar.Finish()
|
||
|
bar.Finish()
|
||
|
}
|
||
|
|
||
|
func TestWriteRace(t *testing.T) {
|
||
|
outBuffer := &bytes.Buffer{}
|
||
|
totalCount := 20
|
||
|
bar := New(totalCount)
|
||
|
bar.Output = outBuffer
|
||
|
bar.Start()
|
||
|
var wg sync.WaitGroup
|
||
|
for i := 0; i < totalCount; i++ {
|
||
|
wg.Add(1)
|
||
|
go func() {
|
||
|
bar.Increment()
|
||
|
time.Sleep(250 * time.Millisecond)
|
||
|
wg.Done()
|
||
|
}()
|
||
|
}
|
||
|
wg.Wait()
|
||
|
bar.Finish()
|
||
|
}
|
||
|
|
||
|
func Test_Format(t *testing.T) {
|
||
|
bar := New(5000).Format(strings.Join([]string{
|
||
|
color.GreenString("["),
|
||
|
color.New(color.BgGreen).SprintFunc()("o"),
|
||
|
color.New(color.BgHiGreen).SprintFunc()("o"),
|
||
|
color.New(color.BgRed).SprintFunc()("o"),
|
||
|
color.GreenString("]"),
|
||
|
}, "\x00"))
|
||
|
w := colorable.NewColorableStdout()
|
||
|
bar.Callback = func(out string) {
|
||
|
w.Write([]byte(out))
|
||
|
}
|
||
|
bar.Add(2000)
|
||
|
bar.Finish()
|
||
|
bar.Finish()
|
||
|
}
|
||
|
|
||
|
func Test_MultiCharacter(t *testing.T) {
|
||
|
bar := New(5).Format(strings.Join([]string{"[[[", "---", ">>", "....", "]]"}, "\x00"))
|
||
|
bar.Start()
|
||
|
for i := 0; i < 5; i++ {
|
||
|
time.Sleep(500 * time.Millisecond)
|
||
|
bar.Increment()
|
||
|
}
|
||
|
|
||
|
time.Sleep(500 * time.Millisecond)
|
||
|
bar.Finish()
|
||
|
}
|
||
|
|
||
|
func Test_AutoStat(t *testing.T) {
|
||
|
bar := New(5)
|
||
|
bar.AutoStat = true
|
||
|
bar.Start()
|
||
|
time.Sleep(2 * time.Second)
|
||
|
//real start work
|
||
|
for i := 0; i < 5; i++ {
|
||
|
time.Sleep(500 * time.Millisecond)
|
||
|
bar.Increment()
|
||
|
}
|
||
|
//real finish work
|
||
|
time.Sleep(2 * time.Second)
|
||
|
bar.Finish()
|
||
|
}
|
||
|
|
||
|
func Test_Finish_PrintNewline(t *testing.T) {
|
||
|
bar := New(5)
|
||
|
buf := &bytes.Buffer{}
|
||
|
bar.Output = buf
|
||
|
bar.Finish()
|
||
|
|
||
|
expected := "\n"
|
||
|
actual := buf.String()
|
||
|
//Finish should write newline to bar.Output
|
||
|
if !strings.HasSuffix(actual, expected) {
|
||
|
t.Errorf("Expected %q to have suffix %q", expected, actual)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_FinishPrint(t *testing.T) {
|
||
|
bar := New(5)
|
||
|
buf := &bytes.Buffer{}
|
||
|
bar.Output = buf
|
||
|
bar.FinishPrint("foo")
|
||
|
|
||
|
expected := "foo\n"
|
||
|
actual := buf.String()
|
||
|
//FinishPrint should write to bar.Output
|
||
|
if !strings.HasSuffix(actual, expected) {
|
||
|
t.Errorf("Expected %q to have suffix %q", expected, actual)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_Reset(t *testing.T) {
|
||
|
bar := StartNew(5)
|
||
|
for i := 0; i < 5; i++ {
|
||
|
bar.Increment()
|
||
|
}
|
||
|
if actual := bar.Get(); actual != 5 {
|
||
|
t.Errorf("Expected: %d; actual: %d", 5, actual)
|
||
|
}
|
||
|
bar.Finish()
|
||
|
bar.Reset(10).Start()
|
||
|
defer bar.Finish()
|
||
|
if actual := bar.Get(); actual != 0 {
|
||
|
t.Errorf("Expected: %d; actual: %d", 0, actual)
|
||
|
}
|
||
|
if actual := bar.Total; actual != 10 {
|
||
|
t.Errorf("Expected: %d; actual: %d", 10, actual)
|
||
|
}
|
||
|
}
|