Skip to content

Commit

Permalink
Handle absolute paths in config (#318)
Browse files Browse the repository at this point in the history
  • Loading branch information
ZipFile authored Dec 16, 2024
1 parent 6511c41 commit 7a0a17f
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 4 deletions.
8 changes: 4 additions & 4 deletions runner/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -340,7 +340,7 @@ func (c *Config) colorInfo() map[string]string {
}

func (c *Config) buildLogPath() string {
return filepath.Join(c.tmpPath(), c.Build.Log)
return joinPath(c.tmpPath(), c.Build.Log)
}

func (c *Config) buildDelay() time.Duration {
Expand All @@ -362,15 +362,15 @@ func (c *Config) killDelay() time.Duration {
}

func (c *Config) binPath() string {
return filepath.Join(c.Root, c.Build.Bin)
return joinPath(c.Root, c.Build.Bin)
}

func (c *Config) tmpPath() string {
return filepath.Join(c.Root, c.TmpDir)
return joinPath(c.Root, c.TmpDir)
}

func (c *Config) testDataPath() string {
return filepath.Join(c.Root, c.TestDataDir)
return joinPath(c.Root, c.TestDataDir)
}

func (c *Config) rel(path string) string {
Expand Down
8 changes: 8 additions & 0 deletions runner/util.go
Original file line number Diff line number Diff line change
Expand Up @@ -397,3 +397,11 @@ func setTage2Map(root string, t reflect.Type, m map[string]TomlInfo, fieldPath s
}
}
}

func joinPath(root, path string) string {
if filepath.IsAbs(path) {
return path
}

return filepath.Join(root, path)
}
30 changes: 30 additions & 0 deletions runner/util_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -288,3 +288,33 @@ func TestCheckIncludeFile(t *testing.T) {
assert.False(t, e.checkIncludeFile("no.go"))
assert.False(t, e.checkIncludeFile("."))
}

func TestJoinPathRelative(t *testing.T) {
root, err := filepath.Abs("test")

if err != nil {
t.Fatalf("couldn't get absolute path for testing: %v", err)
}

result := joinPath(root, "x")

assert.Equal(t, result, filepath.Join(root, "x"))
}

func TestJoinPathAbsolute(t *testing.T) {
root, err := filepath.Abs("test")

if err != nil {
t.Fatalf("couldn't get absolute path for testing: %v", err)
}

path, err := filepath.Abs("x")

if err != nil {
t.Fatalf("couldn't get absolute path for testing: %v", err)
}

result := joinPath(root, path)

assert.Equal(t, result, path)
}

0 comments on commit 7a0a17f

Please sign in to comment.