oh-my-posh/src/segment_executiontime_test.go
2021-11-26 11:11:07 +01:00

259 lines
7.2 KiB
Go

package main
import (
"testing"
"time"
"github.com/stretchr/testify/assert"
)
func TestExecutionTimeWriterDefaultThresholdEnabled(t *testing.T) {
env := new(MockedEnvironment)
env.On("executionTime", nil).Return(1337)
executionTime := &executiontime{
env: env,
}
assert.True(t, executionTime.enabled())
}
func TestExecutionTimeWriterDefaultThresholdDisabled(t *testing.T) {
env := new(MockedEnvironment)
env.On("executionTime", nil).Return(1)
executionTime := &executiontime{
env: env,
}
assert.False(t, executionTime.enabled())
}
func TestExecutionTimeWriterCustomThresholdEnabled(t *testing.T) {
env := new(MockedEnvironment)
env.On("executionTime", nil).Return(99)
var props properties = map[Property]interface{}{
ThresholdProperty: float64(10),
}
executionTime := &executiontime{
env: env,
props: props,
}
assert.True(t, executionTime.enabled())
}
func TestExecutionTimeWriterCustomThresholdDisabled(t *testing.T) {
env := new(MockedEnvironment)
env.On("executionTime", nil).Return(99)
var props properties = map[Property]interface{}{
ThresholdProperty: float64(100),
}
executionTime := &executiontime{
env: env,
props: props,
}
assert.False(t, executionTime.enabled())
}
func TestExecutionTimeWriterDuration(t *testing.T) {
input := 1337
expected := "1.337s"
env := new(MockedEnvironment)
env.On("executionTime", nil).Return(input)
executionTime := &executiontime{
env: env,
}
executionTime.enabled()
assert.Equal(t, expected, executionTime.FormattedMs)
}
func TestExecutionTimeWriterDuration2(t *testing.T) {
input := 13371337
expected := "3h 42m 51.337s"
env := new(MockedEnvironment)
env.On("executionTime", nil).Return(input)
executionTime := &executiontime{
env: env,
}
executionTime.enabled()
assert.Equal(t, expected, executionTime.FormattedMs)
}
func TestExecutionTimeFormatDurationAustin(t *testing.T) {
cases := []struct {
Input string
Expected string
}{
{Input: "0.001s", Expected: "1ms"},
{Input: "0.1s", Expected: "100ms"},
{Input: "1s", Expected: "1s"},
{Input: "2.1s", Expected: "2.1s"},
{Input: "1m", Expected: "1m 0s"},
{Input: "3m2.1s", Expected: "3m 2.1s"},
{Input: "1h", Expected: "1h 0m 0s"},
{Input: "4h3m2.1s", Expected: "4h 3m 2.1s"},
{Input: "124h3m2.1s", Expected: "5d 4h 3m 2.1s"},
{Input: "124h3m2.0s", Expected: "5d 4h 3m 2s"},
}
for _, tc := range cases {
duration, _ := time.ParseDuration(tc.Input)
executionTime := &executiontime{}
executionTime.Ms = duration.Milliseconds()
output := executionTime.formatDurationAustin()
assert.Equal(t, tc.Expected, output)
}
}
func TestExecutionTimeFormatDurationRoundrock(t *testing.T) {
cases := []struct {
Input string
Expected string
}{
{Input: "0.001s", Expected: "1ms"},
{Input: "0.1s", Expected: "100ms"},
{Input: "1s", Expected: "1s 0ms"},
{Input: "2.1s", Expected: "2s 100ms"},
{Input: "1m", Expected: "1m 0s 0ms"},
{Input: "3m2.1s", Expected: "3m 2s 100ms"},
{Input: "1h", Expected: "1h 0m 0s 0ms"},
{Input: "4h3m2.1s", Expected: "4h 3m 2s 100ms"},
{Input: "124h3m2.1s", Expected: "5d 4h 3m 2s 100ms"},
{Input: "124h3m2.0s", Expected: "5d 4h 3m 2s 0ms"},
}
for _, tc := range cases {
duration, _ := time.ParseDuration(tc.Input)
executionTime := &executiontime{}
executionTime.Ms = duration.Milliseconds()
output := executionTime.formatDurationRoundrock()
assert.Equal(t, tc.Expected, output)
}
}
func TestExecutionTimeFormatDallas(t *testing.T) {
cases := []struct {
Input string
Expected string
}{
{Input: "0.001s", Expected: "0.001"},
{Input: "0.1s", Expected: "0.1"},
{Input: "1s", Expected: "1"},
{Input: "2.1s", Expected: "2.1"},
{Input: "1m", Expected: "1:0"},
{Input: "3m2.1s", Expected: "3:2.1"},
{Input: "1h", Expected: "1:0:0"},
{Input: "4h3m2.1s", Expected: "4:3:2.1"},
{Input: "124h3m2.1s", Expected: "5:4:3:2.1"},
{Input: "124h3m2.0s", Expected: "5:4:3:2"},
}
for _, tc := range cases {
duration, _ := time.ParseDuration(tc.Input)
executionTime := &executiontime{}
executionTime.Ms = duration.Milliseconds()
output := executionTime.formatDurationDallas()
assert.Equal(t, tc.Expected, output)
}
}
func TestExecutionTimeFormatGalveston(t *testing.T) {
cases := []struct {
Input string
Expected string
}{
{Input: "0.001s", Expected: "00:00:00"},
{Input: "0.1s", Expected: "00:00:00"},
{Input: "1s", Expected: "00:00:01"},
{Input: "2.1s", Expected: "00:00:02"},
{Input: "1m", Expected: "00:01:00"},
{Input: "3m2.1s", Expected: "00:03:02"},
{Input: "1h", Expected: "01:00:00"},
{Input: "4h3m2.1s", Expected: "04:03:02"},
{Input: "124h3m2.1s", Expected: "124:03:02"},
{Input: "124h3m2.0s", Expected: "124:03:02"},
}
for _, tc := range cases {
duration, _ := time.ParseDuration(tc.Input)
executionTime := &executiontime{}
executionTime.Ms = duration.Milliseconds()
output := executionTime.formatDurationGalveston()
assert.Equal(t, tc.Expected, output)
}
}
func TestExecutionTimeFormatHouston(t *testing.T) {
cases := []struct {
Input string
Expected string
}{
{Input: "0.001s", Expected: "00:00:00.001"},
{Input: "0.1s", Expected: "00:00:00.1"},
{Input: "1s", Expected: "00:00:01.0"},
{Input: "2.1s", Expected: "00:00:02.1"},
{Input: "1m", Expected: "00:01:00.0"},
{Input: "3m2.1s", Expected: "00:03:02.1"},
{Input: "1h", Expected: "01:00:00.0"},
{Input: "4h3m2.1s", Expected: "04:03:02.1"},
{Input: "124h3m2.1s", Expected: "124:03:02.1"},
{Input: "124h3m2.0s", Expected: "124:03:02.0"},
}
for _, tc := range cases {
duration, _ := time.ParseDuration(tc.Input)
executionTime := &executiontime{}
executionTime.Ms = duration.Milliseconds()
output := executionTime.formatDurationHouston()
assert.Equal(t, tc.Expected, output)
}
}
func TestExecutionTimeFormatAmarillo(t *testing.T) {
cases := []struct {
Input string
Expected string
}{
{Input: "0.001s", Expected: "0.001s"},
{Input: "0.1s", Expected: "0.1s"},
{Input: "1s", Expected: "1s"},
{Input: "2.1s", Expected: "2.1s"},
{Input: "1m", Expected: "60s"},
{Input: "3m2.1s", Expected: "182.1s"},
{Input: "1h", Expected: "3,600s"},
{Input: "4h3m2.1s", Expected: "14,582.1s"},
{Input: "124h3m2.1s", Expected: "446,582.1s"},
{Input: "124h3m2.0s", Expected: "446,582s"},
}
for _, tc := range cases {
duration, _ := time.ParseDuration(tc.Input)
executionTime := &executiontime{}
executionTime.Ms = duration.Milliseconds()
output := executionTime.formatDurationAmarillo()
assert.Equal(t, tc.Expected, output)
}
}
func TestExecutionTimeFormatDurationRound(t *testing.T) {
cases := []struct {
Input string
Expected string
}{
{Input: "0.001s", Expected: "1ms"},
{Input: "0.1s", Expected: "100ms"},
{Input: "1s", Expected: "1s"},
{Input: "2.1s", Expected: "2s"},
{Input: "1m", Expected: "1m"},
{Input: "3m2.1s", Expected: "3m 2s"},
{Input: "1h", Expected: "1h"},
{Input: "4h3m2.1s", Expected: "4h 3m"},
{Input: "124h3m2.1s", Expected: "5d 4h"},
{Input: "124h3m2.0s", Expected: "5d 4h"},
}
for _, tc := range cases {
duration, _ := time.ParseDuration(tc.Input)
executionTime := &executiontime{}
executionTime.Ms = duration.Milliseconds()
output := executionTime.formatDurationRound()
assert.Equal(t, tc.Expected, output)
}
}