2019-03-13 04:14:30 -07:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2022-01-26 01:23:18 -08:00
|
|
|
"oh-my-posh/environment"
|
|
|
|
"oh-my-posh/mock"
|
2022-01-26 04:53:35 -08:00
|
|
|
"oh-my-posh/properties"
|
2019-03-13 04:14:30 -07:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestExitWriterEnabled(t *testing.T) {
|
2021-01-19 01:08:11 -08:00
|
|
|
cases := []struct {
|
|
|
|
ExitCode int
|
|
|
|
Expected bool
|
|
|
|
}{
|
|
|
|
{ExitCode: 102, Expected: true},
|
|
|
|
{ExitCode: 0, Expected: false},
|
|
|
|
{ExitCode: -1, Expected: true},
|
2019-03-13 04:14:30 -07:00
|
|
|
}
|
|
|
|
|
2021-01-19 01:08:11 -08:00
|
|
|
for _, tc := range cases {
|
2022-01-26 01:23:18 -08:00
|
|
|
env := new(mock.MockedEnvironment)
|
2022-01-23 12:37:51 -08:00
|
|
|
env.On("ErrorCode").Return(tc.ExitCode)
|
2022-01-26 05:10:18 -08:00
|
|
|
e := &Exit{
|
2022-01-01 11:08:08 -08:00
|
|
|
env: env,
|
2022-01-26 04:53:35 -08:00
|
|
|
props: properties.Map{},
|
2021-01-19 01:08:11 -08:00
|
|
|
}
|
2022-01-26 05:26:56 -08:00
|
|
|
assert.Equal(t, tc.Expected, e.Enabled())
|
2019-03-13 04:14:30 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetMeaningFromExitCode(t *testing.T) {
|
|
|
|
errorMap := make(map[int]string)
|
|
|
|
errorMap[1] = "ERROR"
|
|
|
|
errorMap[2] = "USAGE"
|
|
|
|
errorMap[126] = "NOPERM"
|
|
|
|
errorMap[127] = "NOTFOUND"
|
|
|
|
errorMap[129] = "SIGHUP"
|
|
|
|
errorMap[130] = "SIGINT"
|
|
|
|
errorMap[131] = "SIGQUIT"
|
|
|
|
errorMap[132] = "SIGILL"
|
|
|
|
errorMap[133] = "SIGTRAP"
|
|
|
|
errorMap[134] = "SIGIOT"
|
|
|
|
errorMap[135] = "SIGBUS"
|
|
|
|
errorMap[136] = "SIGFPE"
|
|
|
|
errorMap[137] = "SIGKILL"
|
|
|
|
errorMap[138] = "SIGUSR1"
|
|
|
|
errorMap[139] = "SIGSEGV"
|
|
|
|
errorMap[140] = "SIGUSR2"
|
|
|
|
errorMap[141] = "SIGPIPE"
|
|
|
|
errorMap[142] = "SIGALRM"
|
|
|
|
errorMap[143] = "SIGTERM"
|
|
|
|
errorMap[144] = "SIGSTKFLT"
|
|
|
|
errorMap[145] = "SIGCHLD"
|
|
|
|
errorMap[146] = "SIGCONT"
|
|
|
|
errorMap[147] = "SIGSTOP"
|
|
|
|
errorMap[148] = "SIGTSTP"
|
|
|
|
errorMap[149] = "SIGTTIN"
|
|
|
|
errorMap[150] = "SIGTTOU"
|
|
|
|
errorMap[151] = "151"
|
|
|
|
errorMap[7000] = "7000"
|
|
|
|
for exitcode, want := range errorMap {
|
2022-01-26 05:10:18 -08:00
|
|
|
e := &Exit{}
|
2022-01-22 10:46:56 -08:00
|
|
|
assert.Equal(t, want, e.getMeaningFromExitCode(exitcode))
|
2019-03-13 04:14:30 -07:00
|
|
|
}
|
|
|
|
}
|
2020-11-27 05:51:13 -08:00
|
|
|
|
2021-11-14 04:39:00 -08:00
|
|
|
func TestExitWriterTemplateString(t *testing.T) {
|
|
|
|
cases := []struct {
|
|
|
|
Case string
|
|
|
|
ExitCode int
|
|
|
|
Expected string
|
|
|
|
Template string
|
|
|
|
}{
|
|
|
|
{Case: "Only code", ExitCode: 129, Expected: "129", Template: "{{ .Code }}"},
|
2020-11-27 05:51:13 -08:00
|
|
|
}
|
2021-11-14 04:39:00 -08:00
|
|
|
|
|
|
|
for _, tc := range cases {
|
2022-01-26 01:23:18 -08:00
|
|
|
env := new(mock.MockedEnvironment)
|
2022-01-23 12:37:51 -08:00
|
|
|
env.On("ErrorCode").Return(tc.ExitCode)
|
2022-01-26 01:23:18 -08:00
|
|
|
env.On("TemplateCache").Return(&environment.TemplateCache{
|
2022-01-18 00:48:47 -08:00
|
|
|
Code: tc.ExitCode,
|
|
|
|
})
|
2022-01-26 05:10:18 -08:00
|
|
|
e := &Exit{
|
2021-11-14 04:39:00 -08:00
|
|
|
env: env,
|
2022-01-26 04:53:35 -08:00
|
|
|
props: properties.Map{},
|
2021-11-14 04:39:00 -08:00
|
|
|
}
|
2022-01-23 12:37:51 -08:00
|
|
|
assert.Equal(t, tc.Expected, renderTemplate(env, tc.Template, e), tc.Case)
|
2020-11-27 05:51:13 -08:00
|
|
|
}
|
|
|
|
}
|