2022-04-05 07:07:01 +02:00
|
|
|
package lib
|
2022-01-09 06:59:28 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
2022-04-09 21:19:01 +02:00
|
|
|
"os/user"
|
2022-01-09 06:59:28 +01:00
|
|
|
"path"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
2022-01-10 01:39:13 +01:00
|
|
|
"time"
|
2022-04-05 07:07:01 +02:00
|
|
|
|
2022-04-08 05:59:40 +02:00
|
|
|
"github.com/ddworken/hishtory/client/data"
|
2022-04-05 07:07:01 +02:00
|
|
|
"github.com/ddworken/hishtory/shared"
|
2022-01-09 06:59:28 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestSetup(t *testing.T) {
|
2022-04-05 07:07:01 +02:00
|
|
|
defer shared.BackupAndRestore(t)()
|
2022-04-15 20:20:23 +02:00
|
|
|
defer shared.RunTestServer()()
|
2022-01-09 06:59:28 +01:00
|
|
|
homedir, err := os.UserHomeDir()
|
2022-04-05 07:07:01 +02:00
|
|
|
shared.Check(t, err)
|
|
|
|
if _, err := os.Stat(path.Join(homedir, shared.HISHTORY_PATH, shared.CONFIG_PATH)); err == nil {
|
2022-01-09 06:59:28 +01:00
|
|
|
t.Fatalf("hishtory secret file already exists!")
|
|
|
|
}
|
2022-04-05 07:07:01 +02:00
|
|
|
shared.Check(t, Setup([]string{}))
|
|
|
|
if _, err := os.Stat(path.Join(homedir, shared.HISHTORY_PATH, shared.CONFIG_PATH)); err != nil {
|
2022-01-09 06:59:28 +01:00
|
|
|
t.Fatalf("hishtory secret file does not exist after Setup()!")
|
|
|
|
}
|
2022-04-05 07:07:01 +02:00
|
|
|
data, err := os.ReadFile(path.Join(homedir, shared.HISHTORY_PATH, shared.CONFIG_PATH))
|
|
|
|
shared.Check(t, err)
|
2022-01-09 06:59:28 +01:00
|
|
|
if len(data) < 10 {
|
|
|
|
t.Fatalf("hishtory secret has unexpected length: %d", len(data))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBuildHistoryEntry(t *testing.T) {
|
2022-04-05 07:07:01 +02:00
|
|
|
defer shared.BackupAndRestore(t)()
|
2022-04-15 20:20:23 +02:00
|
|
|
defer shared.RunTestServer()()
|
2022-04-05 07:07:01 +02:00
|
|
|
shared.Check(t, Setup([]string{}))
|
2022-04-15 09:04:49 +02:00
|
|
|
|
2022-04-18 04:54:17 +02:00
|
|
|
// Test building an actual entry for bash
|
2022-04-19 07:45:07 +02:00
|
|
|
entry, err := BuildHistoryEntry([]string{"unused", "saveHistoryEntry", "bash", "120", " 123 ls /foo ", "1641774958"})
|
2022-04-05 07:07:01 +02:00
|
|
|
shared.Check(t, err)
|
2022-01-09 06:59:28 +01:00
|
|
|
if entry.ExitCode != 120 {
|
|
|
|
t.Fatalf("history entry has unexpected exit code: %v", entry.ExitCode)
|
|
|
|
}
|
2022-04-09 21:19:01 +02:00
|
|
|
user, err := user.Current()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to retrieve user: %v", err)
|
|
|
|
}
|
|
|
|
if entry.LocalUsername != user.Username {
|
2022-01-09 06:59:28 +01:00
|
|
|
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)
|
|
|
|
}
|
2022-04-18 04:54:17 +02:00
|
|
|
if entry.Command != "ls /foo" {
|
|
|
|
t.Fatalf("history entry has unexpected command: %v", entry.Command)
|
|
|
|
}
|
|
|
|
if !strings.HasPrefix(entry.StartTime.Format(time.RFC3339), "2022-01-09T") && !strings.HasPrefix(entry.StartTime.Format(time.RFC3339), "2022-01-10T") {
|
|
|
|
t.Fatalf("history entry has incorrect date in the start time: %v", entry.StartTime.Format(time.RFC3339))
|
|
|
|
}
|
|
|
|
if entry.StartTime.Unix() != 1641774958 {
|
|
|
|
t.Fatalf("history entry has incorrect Unix time in the start time: %v", entry.StartTime.Unix())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test building an entry for zsh
|
2022-04-19 07:50:26 +02:00
|
|
|
entry, err = BuildHistoryEntry([]string{"unused", "saveHistoryEntry", "zsh", "120", "ls /foo\n", "1641774958"})
|
2022-04-18 04:54:17 +02:00
|
|
|
shared.Check(t, err)
|
|
|
|
if entry.ExitCode != 120 {
|
|
|
|
t.Fatalf("history entry has unexpected exit code: %v", entry.ExitCode)
|
|
|
|
}
|
|
|
|
if entry.LocalUsername != user.Username {
|
|
|
|
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 /foo" {
|
2022-01-09 06:59:28 +01:00
|
|
|
t.Fatalf("history entry has unexpected command: %v", entry.Command)
|
|
|
|
}
|
2022-04-09 21:57:58 +02:00
|
|
|
if !strings.HasPrefix(entry.StartTime.Format(time.RFC3339), "2022-01-09T") && !strings.HasPrefix(entry.StartTime.Format(time.RFC3339), "2022-01-10T") {
|
2022-04-09 21:50:01 +02:00
|
|
|
t.Fatalf("history entry has incorrect date in the start time: %v", entry.StartTime.Format(time.RFC3339))
|
|
|
|
}
|
|
|
|
if entry.StartTime.Unix() != 1641774958 {
|
|
|
|
t.Fatalf("history entry has incorrect Unix time in the start time: %v", entry.StartTime.Unix())
|
2022-01-10 01:39:13 +01:00
|
|
|
}
|
2022-01-09 06:59:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetUserSecret(t *testing.T) {
|
2022-04-05 07:07:01 +02:00
|
|
|
defer shared.BackupAndRestore(t)()
|
2022-04-15 20:20:23 +02:00
|
|
|
defer shared.RunTestServer()()
|
2022-04-05 07:07:01 +02:00
|
|
|
shared.Check(t, Setup([]string{}))
|
2022-01-09 06:59:28 +01:00
|
|
|
secret1, err := GetUserSecret()
|
2022-04-05 07:07:01 +02:00
|
|
|
shared.Check(t, err)
|
2022-01-09 06:59:28 +01:00
|
|
|
if len(secret1) < 10 || strings.Contains(secret1, " ") || strings.Contains(secret1, "\n") {
|
|
|
|
t.Fatalf("unexpected secret: %v", secret1)
|
|
|
|
}
|
|
|
|
|
2022-04-05 07:07:01 +02:00
|
|
|
shared.Check(t, Setup([]string{}))
|
2022-01-09 06:59:28 +01:00
|
|
|
secret2, err := GetUserSecret()
|
2022-04-05 07:07:01 +02:00
|
|
|
shared.Check(t, err)
|
2022-01-09 06:59:28 +01:00
|
|
|
|
|
|
|
if secret1 == secret2 {
|
|
|
|
t.Fatalf("GetUserSecret() returned the same values for different setups! val=%v", secret1)
|
|
|
|
}
|
|
|
|
}
|
2022-04-07 07:43:07 +02:00
|
|
|
|
|
|
|
func TestPersist(t *testing.T) {
|
|
|
|
defer shared.BackupAndRestore(t)()
|
|
|
|
db, err := OpenLocalSqliteDb()
|
|
|
|
shared.Check(t, err)
|
|
|
|
|
2022-04-08 05:59:40 +02:00
|
|
|
entry := data.MakeFakeHistoryEntry("ls ~/")
|
2022-04-07 07:43:07 +02:00
|
|
|
db.Create(entry)
|
2022-04-08 05:59:40 +02:00
|
|
|
var historyEntries []*data.HistoryEntry
|
2022-04-07 07:43:07 +02:00
|
|
|
result := db.Find(&historyEntries)
|
|
|
|
shared.Check(t, result.Error)
|
|
|
|
if len(historyEntries) != 1 {
|
|
|
|
t.Fatalf("DB has %d entries, expected 1!", len(historyEntries))
|
|
|
|
}
|
|
|
|
dbEntry := historyEntries[0]
|
2022-04-08 05:59:40 +02:00
|
|
|
if !data.EntryEquals(entry, *dbEntry) {
|
2022-04-07 07:43:07 +02:00
|
|
|
t.Fatalf("DB data is different than input! \ndb =%#v \ninput=%#v", *dbEntry, entry)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSearch(t *testing.T) {
|
|
|
|
defer shared.BackupAndRestore(t)()
|
|
|
|
db, err := OpenLocalSqliteDb()
|
|
|
|
shared.Check(t, err)
|
|
|
|
|
|
|
|
// Insert data
|
2022-04-08 05:59:40 +02:00
|
|
|
entry1 := data.MakeFakeHistoryEntry("ls /foo")
|
2022-04-07 07:43:07 +02:00
|
|
|
db.Create(entry1)
|
2022-04-08 05:59:40 +02:00
|
|
|
entry2 := data.MakeFakeHistoryEntry("ls /bar")
|
2022-04-07 07:43:07 +02:00
|
|
|
db.Create(entry2)
|
|
|
|
|
|
|
|
// Search for data
|
2022-04-08 05:59:40 +02:00
|
|
|
results, err := data.Search(db, "ls", 5)
|
2022-04-07 07:43:07 +02:00
|
|
|
shared.Check(t, err)
|
|
|
|
if len(results) != 2 {
|
|
|
|
t.Fatalf("Search() returned %d results, expected 2!", len(results))
|
|
|
|
}
|
2022-04-08 05:59:40 +02:00
|
|
|
if !data.EntryEquals(*results[0], entry2) {
|
2022-04-07 07:43:07 +02:00
|
|
|
t.Fatalf("Search()[0]=%#v, expected: %#v", results[0], entry2)
|
|
|
|
}
|
2022-04-08 05:59:40 +02:00
|
|
|
if !data.EntryEquals(*results[1], entry1) {
|
2022-04-07 07:43:07 +02:00
|
|
|
t.Fatalf("Search()[0]=%#v, expected: %#v", results[1], entry1)
|
|
|
|
}
|
2022-04-07 07:44:10 +02:00
|
|
|
}
|
2022-04-09 22:09:46 +02:00
|
|
|
|
|
|
|
func TestAddToDbIfNew(t *testing.T) {
|
|
|
|
// Set up
|
|
|
|
defer shared.BackupAndRestore(t)()
|
|
|
|
db, err := OpenLocalSqliteDb()
|
|
|
|
shared.Check(t, err)
|
|
|
|
|
|
|
|
// Add duplicate entries
|
|
|
|
entry1 := data.MakeFakeHistoryEntry("ls /foo")
|
|
|
|
AddToDbIfNew(db, entry1)
|
|
|
|
AddToDbIfNew(db, entry1)
|
|
|
|
entry2 := data.MakeFakeHistoryEntry("ls /foo")
|
|
|
|
AddToDbIfNew(db, entry2)
|
|
|
|
AddToDbIfNew(db, entry2)
|
|
|
|
AddToDbIfNew(db, entry1)
|
|
|
|
|
|
|
|
// Check there should only be two entries
|
|
|
|
var entries []data.HistoryEntry
|
|
|
|
result := db.Find(&entries)
|
|
|
|
if result.Error != nil {
|
|
|
|
t.Fatal(result.Error)
|
|
|
|
}
|
|
|
|
if len(entries) != 2 {
|
|
|
|
t.Fatalf("entries has an incorrect length: %d", len(entries))
|
|
|
|
}
|
|
|
|
}
|
2022-04-17 20:09:30 +02:00
|
|
|
|
|
|
|
func TestParseCrossPlatformInt(t *testing.T) {
|
|
|
|
res, err := parseCrossPlatformInt("123")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to parse int: %v", err)
|
|
|
|
}
|
|
|
|
if res != 123 {
|
|
|
|
t.Fatalf("failed to parse cross platform int %d", res)
|
|
|
|
}
|
|
|
|
res, err = parseCrossPlatformInt("123N")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to parse int: %v", err)
|
|
|
|
}
|
|
|
|
if res != 123 {
|
|
|
|
t.Fatalf("failed to parse cross platform int %d", res)
|
|
|
|
}
|
|
|
|
}
|