test: add some unit tests
This commit is contained in:
parent
1d94431825
commit
6ab7ccb7a1
3 changed files with 263 additions and 0 deletions
28
internal/api/client_test.go
Normal file
28
internal/api/client_test.go
Normal file
|
|
@ -0,0 +1,28 @@
|
|||
package api
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"codeberg.org/romaintb/fgj/internal/config"
|
||||
)
|
||||
|
||||
func TestClient_Hostname(t *testing.T) {
|
||||
client := &Client{
|
||||
hostname: "codeberg.org",
|
||||
}
|
||||
|
||||
if client.Hostname() != "codeberg.org" {
|
||||
t.Errorf("Expected hostname 'codeberg.org', got '%s'", client.Hostname())
|
||||
}
|
||||
}
|
||||
|
||||
func TestNewClientFromConfig_MissingHost(t *testing.T) {
|
||||
cfg := &config.Config{
|
||||
Hosts: map[string]config.HostConfig{},
|
||||
}
|
||||
|
||||
_, err := NewClientFromConfig(cfg, "nonexistent.org")
|
||||
if err == nil {
|
||||
t.Error("Expected error for nonexistent host")
|
||||
}
|
||||
}
|
||||
|
|
@ -41,7 +41,10 @@ func Load() (*Config, error) {
|
|||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return LoadFromPath(path)
|
||||
}
|
||||
|
||||
func LoadFromPath(path string) (*Config, error) {
|
||||
data, err := os.ReadFile(path)
|
||||
if err != nil {
|
||||
if os.IsNotExist(err) {
|
||||
|
|
@ -67,7 +70,10 @@ func (c *Config) Save() error {
|
|||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return c.SaveToPath(path)
|
||||
}
|
||||
|
||||
func (c *Config) SaveToPath(path string) error {
|
||||
dir := filepath.Dir(path)
|
||||
if err := os.MkdirAll(dir, 0755); err != nil {
|
||||
return err
|
||||
|
|
|
|||
229
internal/config/config_test.go
Normal file
229
internal/config/config_test.go
Normal file
|
|
@ -0,0 +1,229 @@
|
|||
package config
|
||||
|
||||
import (
|
||||
"os"
|
||||
"path/filepath"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestConfig_SetHost(t *testing.T) {
|
||||
cfg := &Config{}
|
||||
|
||||
hostConfig := HostConfig{
|
||||
Hostname: "codeberg.org",
|
||||
Token: "test-token",
|
||||
User: "testuser",
|
||||
}
|
||||
|
||||
cfg.SetHost("codeberg.org", hostConfig)
|
||||
|
||||
if cfg.Hosts == nil {
|
||||
t.Fatal("Hosts map should not be nil")
|
||||
}
|
||||
|
||||
if len(cfg.Hosts) != 1 {
|
||||
t.Errorf("Expected 1 host, got %d", len(cfg.Hosts))
|
||||
}
|
||||
|
||||
host, ok := cfg.Hosts["codeberg.org"]
|
||||
if !ok {
|
||||
t.Fatal("Host codeberg.org not found")
|
||||
}
|
||||
|
||||
if host.Hostname != "codeberg.org" {
|
||||
t.Errorf("Expected hostname 'codeberg.org', got '%s'", host.Hostname)
|
||||
}
|
||||
|
||||
if host.Token != "test-token" {
|
||||
t.Errorf("Expected token 'test-token', got '%s'", host.Token)
|
||||
}
|
||||
}
|
||||
|
||||
func TestConfig_GetHost(t *testing.T) {
|
||||
cfg := &Config{
|
||||
Hosts: map[string]HostConfig{
|
||||
"codeberg.org": {
|
||||
Hostname: "codeberg.org",
|
||||
Token: "test-token",
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
host, err := cfg.GetHost("codeberg.org")
|
||||
if err != nil {
|
||||
t.Fatalf("Unexpected error: %v", err)
|
||||
}
|
||||
|
||||
if host.Hostname != "codeberg.org" {
|
||||
t.Errorf("Expected hostname 'codeberg.org', got '%s'", host.Hostname)
|
||||
}
|
||||
|
||||
_, err = cfg.GetHost("nonexistent.org")
|
||||
if err == nil {
|
||||
t.Error("Expected error for nonexistent host")
|
||||
}
|
||||
}
|
||||
|
||||
func TestGetConfigDir(t *testing.T) {
|
||||
dir, err := GetConfigDir()
|
||||
if err != nil {
|
||||
t.Fatalf("Unexpected error: %v", err)
|
||||
}
|
||||
|
||||
if dir == "" {
|
||||
t.Error("Config directory should not be empty")
|
||||
}
|
||||
}
|
||||
|
||||
func TestGetConfigPath(t *testing.T) {
|
||||
path, err := GetConfigPath()
|
||||
if err != nil {
|
||||
t.Fatalf("Unexpected error: %v", err)
|
||||
}
|
||||
|
||||
if path == "" {
|
||||
t.Error("Config path should not be empty")
|
||||
}
|
||||
}
|
||||
|
||||
func TestConfig_SaveAndLoad(t *testing.T) {
|
||||
// Create a temp directory for testing
|
||||
tempDir := t.TempDir()
|
||||
tempFile := filepath.Join(tempDir, "config.yaml")
|
||||
|
||||
// Create a config with test data
|
||||
cfg := &Config{
|
||||
Hosts: map[string]HostConfig{
|
||||
"codeberg.org": {
|
||||
Hostname: "codeberg.org",
|
||||
Token: "test-token-123",
|
||||
User: "testuser",
|
||||
GitProtocol: "ssh",
|
||||
},
|
||||
"github.com": {
|
||||
Hostname: "github.com",
|
||||
Token: "github-token-456",
|
||||
User: "githubuser",
|
||||
GitProtocol: "https",
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
// Test Save
|
||||
err := cfg.SaveToPath(tempFile)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to save config: %v", err)
|
||||
}
|
||||
|
||||
// Verify file exists
|
||||
if _, err := os.Stat(tempFile); os.IsNotExist(err) {
|
||||
t.Fatal("Config file was not created")
|
||||
}
|
||||
|
||||
// Test Load
|
||||
loadedCfg, err := LoadFromPath(tempFile)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to load config: %v", err)
|
||||
}
|
||||
|
||||
// Verify loaded config matches saved config
|
||||
if len(loadedCfg.Hosts) != 2 {
|
||||
t.Errorf("Expected 2 hosts, got %d", len(loadedCfg.Hosts))
|
||||
}
|
||||
|
||||
// Check codeberg.org host
|
||||
codebergHost, ok := loadedCfg.Hosts["codeberg.org"]
|
||||
if !ok {
|
||||
t.Fatal("codeberg.org host not found in loaded config")
|
||||
}
|
||||
if codebergHost.Token != "test-token-123" {
|
||||
t.Errorf("Expected token 'test-token-123', got '%s'", codebergHost.Token)
|
||||
}
|
||||
if codebergHost.User != "testuser" {
|
||||
t.Errorf("Expected user 'testuser', got '%s'", codebergHost.User)
|
||||
}
|
||||
if codebergHost.GitProtocol != "ssh" {
|
||||
t.Errorf("Expected git_protocol 'ssh', got '%s'", codebergHost.GitProtocol)
|
||||
}
|
||||
|
||||
// Check github.com host
|
||||
githubHost, ok := loadedCfg.Hosts["github.com"]
|
||||
if !ok {
|
||||
t.Fatal("github.com host not found in loaded config")
|
||||
}
|
||||
if githubHost.Token != "github-token-456" {
|
||||
t.Errorf("Expected token 'github-token-456', got '%s'", githubHost.Token)
|
||||
}
|
||||
}
|
||||
|
||||
func TestConfig_LoadNonexistentFile(t *testing.T) {
|
||||
tempDir := t.TempDir()
|
||||
tempFile := filepath.Join(tempDir, "nonexistent.yaml")
|
||||
|
||||
// Test Load with nonexistent file
|
||||
cfg, err := LoadFromPath(tempFile)
|
||||
if err != nil {
|
||||
t.Fatalf("Load should not error on nonexistent file: %v", err)
|
||||
}
|
||||
|
||||
// Should return empty config
|
||||
if cfg == nil {
|
||||
t.Fatal("Config should not be nil")
|
||||
}
|
||||
|
||||
if cfg.Hosts == nil {
|
||||
t.Fatal("Hosts map should be initialized")
|
||||
}
|
||||
|
||||
if len(cfg.Hosts) != 0 {
|
||||
t.Errorf("Expected empty hosts map, got %d entries", len(cfg.Hosts))
|
||||
}
|
||||
}
|
||||
|
||||
func TestConfig_LoadInvalidYAML(t *testing.T) {
|
||||
tempDir := t.TempDir()
|
||||
tempFile := filepath.Join(tempDir, "invalid.yaml")
|
||||
|
||||
// Write invalid YAML
|
||||
err := os.WriteFile(tempFile, []byte("invalid: yaml: content: [[["), 0600)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to write invalid YAML: %v", err)
|
||||
}
|
||||
|
||||
// Test Load with invalid YAML
|
||||
_, err = LoadFromPath(tempFile)
|
||||
if err == nil {
|
||||
t.Error("Expected error when loading invalid YAML")
|
||||
}
|
||||
}
|
||||
|
||||
func TestConfig_SaveCreatesDirectory(t *testing.T) {
|
||||
tempDir := t.TempDir()
|
||||
tempFile := filepath.Join(tempDir, "subdir", "config.yaml")
|
||||
|
||||
cfg := &Config{
|
||||
Hosts: map[string]HostConfig{
|
||||
"test.org": {
|
||||
Hostname: "test.org",
|
||||
Token: "token",
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
// Save should create the directory
|
||||
err := cfg.SaveToPath(tempFile)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to save config: %v", err)
|
||||
}
|
||||
|
||||
// Verify directory was created
|
||||
subdir := filepath.Dir(tempFile)
|
||||
if _, err := os.Stat(subdir); os.IsNotExist(err) {
|
||||
t.Error("Save() should have created the directory")
|
||||
}
|
||||
|
||||
// Verify file exists
|
||||
if _, err := os.Stat(tempFile); os.IsNotExist(err) {
|
||||
t.Error("Config file was not created")
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue