2020-06-18 16:13:24 +02:00
|
|
|
/*
|
2020-09-22 12:13:00 +02:00
|
|
|
Copyright 2020 Docker Compose CLI authors
|
2020-06-18 16:13:24 +02:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2020-06-16 09:42:07 +02:00
|
|
|
package progress
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2020-07-06 13:52:36 +02:00
|
|
|
"sync"
|
2020-06-16 09:42:07 +02:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2020-08-04 13:53:54 +02:00
|
|
|
"gotest.tools/v3/assert"
|
2020-06-16 09:42:07 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestLineText(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
ev := Event{
|
|
|
|
ID: "id",
|
|
|
|
Text: "Text",
|
|
|
|
Status: Working,
|
|
|
|
StatusText: "Status",
|
|
|
|
endTime: now,
|
|
|
|
startTime: now,
|
|
|
|
spinner: &spinner{
|
|
|
|
chars: []string{"."},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
lineWidth := len(fmt.Sprintf("%s %s", ev.ID, ev.Text))
|
|
|
|
|
2023-02-14 16:13:38 +01:00
|
|
|
out := tty().lineText(ev, "", 50, lineWidth, false)
|
2024-04-15 08:34:38 +02:00
|
|
|
assert.Equal(t, out, " . id Text Status \x1b[34m0.0s \x1b[0m\n")
|
2020-06-18 14:16:14 +02:00
|
|
|
|
2020-06-16 09:42:07 +02:00
|
|
|
ev.Status = Done
|
2023-02-14 16:13:38 +01:00
|
|
|
out = tty().lineText(ev, "", 50, lineWidth, false)
|
|
|
|
assert.Equal(t, out, " \x1b[32m✔\x1b[0m id Text \x1b[32mStatus\x1b[0m \x1b[34m0.0s \x1b[0m\n")
|
2020-06-16 09:42:07 +02:00
|
|
|
|
|
|
|
ev.Status = Error
|
2023-02-14 16:13:38 +01:00
|
|
|
out = tty().lineText(ev, "", 50, lineWidth, false)
|
2023-04-04 23:00:10 +02:00
|
|
|
assert.Equal(t, out, " \x1b[31m\x1b[1m✘\x1b[0m id Text \x1b[31m\x1b[1mStatus\x1b[0m \x1b[34m0.0s \x1b[0m\n")
|
2022-09-13 15:38:13 +02:00
|
|
|
|
|
|
|
ev.Status = Warning
|
2023-02-14 16:13:38 +01:00
|
|
|
out = tty().lineText(ev, "", 50, lineWidth, false)
|
2023-04-04 23:00:10 +02:00
|
|
|
assert.Equal(t, out, " \x1b[33m\x1b[1m!\x1b[0m id Text \x1b[33m\x1b[1mStatus\x1b[0m \x1b[34m0.0s \x1b[0m\n")
|
2020-06-16 09:42:07 +02:00
|
|
|
}
|
2020-07-06 13:52:36 +02:00
|
|
|
|
2021-02-03 15:18:16 +01:00
|
|
|
func TestLineTextSingleEvent(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
ev := Event{
|
|
|
|
ID: "id",
|
|
|
|
Text: "Text",
|
|
|
|
Status: Done,
|
|
|
|
StatusText: "Status",
|
|
|
|
startTime: now,
|
|
|
|
spinner: &spinner{
|
|
|
|
chars: []string{"."},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
lineWidth := len(fmt.Sprintf("%s %s", ev.ID, ev.Text))
|
|
|
|
|
2023-02-14 16:13:38 +01:00
|
|
|
out := tty().lineText(ev, "", 50, lineWidth, false)
|
|
|
|
assert.Equal(t, out, " \x1b[32m✔\x1b[0m id Text \x1b[32mStatus\x1b[0m \x1b[34m0.0s \x1b[0m\n")
|
2021-02-03 15:18:16 +01:00
|
|
|
}
|
|
|
|
|
2020-07-06 13:52:36 +02:00
|
|
|
func TestErrorEvent(t *testing.T) {
|
|
|
|
w := &ttyWriter{
|
|
|
|
events: map[string]Event{},
|
2021-09-30 16:33:13 +02:00
|
|
|
mtx: &sync.Mutex{},
|
2020-07-06 13:52:36 +02:00
|
|
|
}
|
|
|
|
e := Event{
|
|
|
|
ID: "id",
|
|
|
|
Text: "Text",
|
|
|
|
Status: Working,
|
|
|
|
StatusText: "Working",
|
|
|
|
startTime: time.Now(),
|
|
|
|
spinner: &spinner{
|
|
|
|
chars: []string{"."},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
// Fire "Working" event and check end time isn't touched
|
|
|
|
w.Event(e)
|
|
|
|
event, ok := w.events[e.ID]
|
2020-08-04 13:53:54 +02:00
|
|
|
assert.Assert(t, ok)
|
|
|
|
assert.Assert(t, event.endTime.Equal(time.Time{}))
|
2020-07-06 13:52:36 +02:00
|
|
|
|
|
|
|
// Fire "Error" event and check end time is set
|
|
|
|
e.Status = Error
|
|
|
|
w.Event(e)
|
|
|
|
event, ok = w.events[e.ID]
|
2020-08-04 13:53:54 +02:00
|
|
|
assert.Assert(t, ok)
|
|
|
|
assert.Assert(t, event.endTime.After(time.Now().Add(-10*time.Second)))
|
2020-07-06 13:52:36 +02:00
|
|
|
}
|
2022-09-13 15:38:13 +02:00
|
|
|
|
|
|
|
func TestWarningEvent(t *testing.T) {
|
|
|
|
w := &ttyWriter{
|
|
|
|
events: map[string]Event{},
|
|
|
|
mtx: &sync.Mutex{},
|
|
|
|
}
|
|
|
|
e := Event{
|
|
|
|
ID: "id",
|
|
|
|
Text: "Text",
|
|
|
|
Status: Working,
|
|
|
|
StatusText: "Working",
|
|
|
|
startTime: time.Now(),
|
|
|
|
spinner: &spinner{
|
|
|
|
chars: []string{"."},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
// Fire "Working" event and check end time isn't touched
|
|
|
|
w.Event(e)
|
|
|
|
event, ok := w.events[e.ID]
|
|
|
|
assert.Assert(t, ok)
|
|
|
|
assert.Assert(t, event.endTime.Equal(time.Time{}))
|
|
|
|
|
|
|
|
// Fire "Warning" event and check end time is set
|
|
|
|
e.Status = Warning
|
|
|
|
w.Event(e)
|
|
|
|
event, ok = w.events[e.ID]
|
|
|
|
assert.Assert(t, ok)
|
|
|
|
assert.Assert(t, event.endTime.After(time.Now().Add(-10*time.Second)))
|
|
|
|
}
|
2023-02-14 16:13:38 +01:00
|
|
|
|
|
|
|
func tty() *ttyWriter {
|
|
|
|
tty := &ttyWriter{
|
|
|
|
eventIDs: []string{},
|
|
|
|
events: map[string]Event{},
|
|
|
|
done: make(chan bool),
|
|
|
|
mtx: &sync.Mutex{},
|
|
|
|
}
|
|
|
|
return tty
|
|
|
|
}
|