mirror of
https://github.com/ddworken/hishtory.git
synced 2024-12-28 09:48:59 +01:00
71 lines
2.2 KiB
Go
71 lines
2.2 KiB
Go
package shared
|
|
|
|
import (
|
|
"os"
|
|
"path"
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestSetup(t *testing.T) {
|
|
defer BackupAndRestore(t)
|
|
homedir, err := os.UserHomeDir()
|
|
Check(t, err)
|
|
if _, err := os.Stat(path.Join(homedir, CONFIG_PATH)); err == nil {
|
|
t.Fatalf("hishtory secret file already exists!")
|
|
}
|
|
Check(t, Setup([]string{}))
|
|
if _, err := os.Stat(path.Join(homedir, CONFIG_PATH)); err != nil {
|
|
t.Fatalf("hishtory secret file does not exist after Setup()!")
|
|
}
|
|
data, err := os.ReadFile(path.Join(homedir, CONFIG_PATH))
|
|
Check(t, err)
|
|
if len(data) < 10 {
|
|
t.Fatalf("hishtory secret has unexpected length: %d", len(data))
|
|
}
|
|
}
|
|
|
|
func TestBuildHistoryEntry(t *testing.T) {
|
|
defer BackupAndRestore(t)
|
|
Check(t, Setup([]string{}))
|
|
entry, err := BuildHistoryEntry([]string{"unused", "saveHistoryEntry", "120", " 123 ls / ", "1641774958326745663"})
|
|
Check(t, err)
|
|
if entry.UserSecret == "" || len(entry.UserSecret) < 10 || strings.TrimSpace(entry.UserSecret) != entry.UserSecret {
|
|
t.Fatalf("history entry has unexpected user secret: %v", entry.UserSecret)
|
|
}
|
|
if entry.ExitCode != 120 {
|
|
t.Fatalf("history entry has unexpected exit code: %v", entry.ExitCode)
|
|
}
|
|
if entry.LocalUsername != "david" {
|
|
t.Fatalf("history entry has unexpected user name: %v", entry.LocalUsername)
|
|
}
|
|
if !strings.HasPrefix(entry.CurrentWorkingDirectory, "/") && !strings.HasPrefix(entry.CurrentWorkingDirectory, "~/") {
|
|
t.Fatalf("history entry has unexpected cwd: %v", entry.CurrentWorkingDirectory)
|
|
}
|
|
if entry.Command != "ls /" {
|
|
t.Fatalf("history entry has unexpected command: %v", entry.Command)
|
|
}
|
|
if entry.StartTime.Format(time.RFC3339) != "2022-01-09T16:35:58-08:00" {
|
|
t.Fatalf("history entry has incorrect start time: %v", entry.StartTime.Format(time.RFC3339))
|
|
}
|
|
}
|
|
|
|
func TestGetUserSecret(t *testing.T) {
|
|
defer BackupAndRestore(t)
|
|
Check(t, Setup([]string{}))
|
|
secret1, err := GetUserSecret()
|
|
Check(t, err)
|
|
if len(secret1) < 10 || strings.Contains(secret1, " ") || strings.Contains(secret1, "\n") {
|
|
t.Fatalf("unexpected secret: %v", secret1)
|
|
}
|
|
|
|
Check(t, Setup([]string{}))
|
|
secret2, err := GetUserSecret()
|
|
Check(t, err)
|
|
|
|
if secret1 == secret2 {
|
|
t.Fatalf("GetUserSecret() returned the same values for different setups! val=%v", secret1)
|
|
}
|
|
}
|