-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathgit_test.go
More file actions
112 lines (101 loc) · 2.92 KB
/
Copy pathgit_test.go
File metadata and controls
112 lines (101 loc) · 2.92 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
package main
import (
"os"
"os/exec"
"path/filepath"
"strings"
"testing"
)
func TestParseArgs_Defaults(t *testing.T) {
cfg, err := parseArgs(nil)
if err != nil {
t.Fatalf("parseArgs returned error: %v", err)
}
if cfg.theme != "default" {
t.Fatalf("expected default theme, got %q", cfg.theme)
}
if cfg.dir != "" {
t.Fatalf("expected empty dir, got %q", cfg.dir)
}
}
func TestParseArgs_WithDirectoryAndFlags(t *testing.T) {
cfg, err := parseArgs([]string{"--theme", "matrix", "--output", "out.gif", "/tmp/repo"})
if err != nil {
t.Fatalf("parseArgs returned error: %v", err)
}
if cfg.theme != "matrix" || cfg.output != "out.gif" || cfg.dir != "/tmp/repo" {
t.Fatalf("unexpected config: %+v", cfg)
}
}
func TestParseArgs_RejectsMultipleDirectories(t *testing.T) {
_, err := parseArgs([]string{"repo1", "repo2"})
if err == nil || !strings.Contains(err.Error(), "only one target directory") {
t.Fatalf("expected multiple directory error, got %v", err)
}
}
func TestGetRepoInfo_CurrentDirectory(t *testing.T) {
repoDir := setupTestRepo(t)
cwd, err := os.Getwd()
if err != nil {
t.Fatalf("getwd: %v", err)
}
defer os.Chdir(cwd)
if err := os.Chdir(repoDir); err != nil {
t.Fatalf("chdir: %v", err)
}
info, err := getRepoInfo("")
if err != nil {
t.Fatalf("getRepoInfo returned error: %v", err)
}
if info.name != filepath.Base(repoDir) {
t.Fatalf("expected repo name %q, got %q", filepath.Base(repoDir), info.name)
}
if info.totalCommits < 1 {
t.Fatalf("expected commits, got %d", info.totalCommits)
}
}
func TestGetRepoInfo_TargetDirectory(t *testing.T) {
repoDir := setupTestRepo(t)
cwd, err := os.Getwd()
if err != nil {
t.Fatalf("getwd: %v", err)
}
info, err := getRepoInfo(repoDir)
if err != nil {
t.Fatalf("getRepoInfo returned error: %v", err)
}
if info.name != filepath.Base(repoDir) {
t.Fatalf("expected repo name %q, got %q", filepath.Base(repoDir), info.name)
}
if after, _ := os.Getwd(); after != cwd {
t.Fatalf("working directory changed from %q to %q", cwd, after)
}
}
func TestGetRepoInfo_InvalidDirectory(t *testing.T) {
_, err := getRepoInfo("/definitely/not/a/repo")
if err == nil {
t.Fatal("expected error for invalid directory")
}
}
func setupTestRepo(t *testing.T) string {
t.Helper()
dir := t.TempDir()
runInDir(t, dir, "git", "init")
runInDir(t, dir, "git", "config", "user.name", "Test User")
runInDir(t, dir, "git", "config", "user.email", "test@example.com")
if err := os.WriteFile(filepath.Join(dir, "README.md"), []byte("# test\n"), 0o644); err != nil {
t.Fatalf("write file: %v", err)
}
runInDir(t, dir, "git", "add", "README.md")
runInDir(t, dir, "git", "commit", "-m", "feat: initial commit")
return dir
}
func runInDir(t *testing.T, dir string, name string, args ...string) {
t.Helper()
cmd := exec.Command(name, args...)
cmd.Dir = dir
out, err := cmd.CombinedOutput()
if err != nil {
t.Fatalf("%s %v failed: %v\n%s", name, args, err, string(out))
}
}