Borg/pkg/tim/tim_more_test.go
Claude fe0f85a069
Some checks failed
Go / build (push) Failing after 3s
mkdocs / deploy (push) Failing after 10s
Release / release (push) Failing after 4s
chore: migrate module path from github.com to forge.lthn.ai
Move module declaration and all internal imports from
github.com/Snider/Borg to forge.lthn.ai/Snider/Borg. Also updates
Enchantrix dependency path to forge.lthn.ai/Snider/Enchantrix.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-22 21:39:18 +00:00

54 lines
1 KiB
Go

package tim
import (
"os"
"testing"
"forge.lthn.ai/Snider/Borg/pkg/datanode"
)
func TestMain(m *testing.M) {
os.Exit(m.Run())
}
func TestFromDataNode_Good(t *testing.T) {
dn := setupDataNode(t)
m, err := FromDataNode(dn)
if err != nil {
t.Fatalf("FromDataNode() error = %v", err)
}
if m == nil {
t.Fatal("FromDataNode() returned a nil tim")
}
if m.RootFS != dn {
t.Error("FromDataNode() did not set the RootFS correctly")
}
}
func TestToTar_Good(t *testing.T) {
m := setupTestTim(t)
_, err := m.ToTar()
if err != nil {
t.Fatalf("ToTar() error = %v", err)
}
}
// setupDataNode creates a simple DataNode for testing.
func setupDataNode(t *testing.T) *datanode.DataNode {
t.Helper()
dn := datanode.New()
dn.AddData("test.txt", []byte("hello"))
return dn
}
// setupTestTim creates a simple TerminalIsolationMatrix for testing.
func setupTestTim(t *testing.T) *TerminalIsolationMatrix {
t.Helper()
m, err := New()
if err != nil {
t.Fatalf("New() failed: %v", err)
}
m.RootFS = setupDataNode(t)
return m
}