Skip to content

Commit

Permalink
Fix exception when file type contains colon
Browse files Browse the repository at this point in the history
Signed-off-by: cui fliter <[email protected]>
  • Loading branch information
cuishuang committed Nov 6, 2023
1 parent 4ca4178 commit da083f3
Show file tree
Hide file tree
Showing 4 changed files with 47 additions and 1 deletion.
16 changes: 15 additions & 1 deletion internal/driver/fetch.go
Original file line number Diff line number Diff line change
Expand Up @@ -492,7 +492,9 @@ mapping:
func fetch(source string, duration, timeout time.Duration, ui plugin.UI, tr http.RoundTripper) (p *profile.Profile, src string, err error) {
var f io.ReadCloser

if sourceURL, timeout := adjustURL(source, duration, timeout); sourceURL != "" {
if isFile(source) {
f, err = os.Open(source)
} else if sourceURL, timeout := adjustURL(source, duration, timeout); sourceURL != "" {
ui.Print("Fetching profile over HTTP from " + sourceURL)
if duration > 0 {
ui.Print(fmt.Sprintf("Please wait... (%v)", duration))
Expand Down Expand Up @@ -614,3 +616,15 @@ func adjustURL(source string, duration, timeout time.Duration) (string, time.Dur
u.RawQuery = values.Encode()
return u.String(), timeout
}

// isFile validates if the profile source is a file, but it will be recognized
// as a link by url.Parse (when it contains `:`, like mem_2023-11-01_15:04:05).
// If such a file exists in the current directory, it will be recognized as a
// file rather than a link.
func isFile(source string) bool {
_, err := os.Stat(source)
if err == nil {
return true
}
return false
}
32 changes: 32 additions & 0 deletions internal/driver/fetch_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,38 @@ func TestFetch(t *testing.T) {
}
}

func TestFetchWhenFileContainColon(t *testing.T) {
const path = "testdata/"
type testcase struct {
source, execName string
}

for _, tc := range []testcase{
// If the file containing a colon is in the current directory, an error will be reported
// and the test will not pass (the test will be passed after adding logic)
{path + "go.crc32.cpu_2023-11-11_01:02:03", ""},
// If the file containing colon is in a non-current directory, it can pass the test
// regardless of whether it is modified or not.
{"go.crc32.cpu_2023-12-12_06:06:06", ""},
} {
p, _, _, err := grabProfile(&source{ExecName: tc.execName}, tc.source, nil, testObj{}, &proftest.TestUI{T: t}, &httpTransport{})
if err != nil {
t.Fatalf("%s: %s", tc.source, err)
}
if len(p.Sample) == 0 {
t.Errorf("%s: want non-zero samples", tc.source)
}
if e := tc.execName; e != "" {
switch {
case len(p.Mapping) == 0 || p.Mapping[0] == nil:
t.Errorf("%s: want mapping[0].execName == %s, got no mappings", tc.source, e)
case p.Mapping[0].File != e:
t.Errorf("%s: want mapping[0].execName == %s, got %s", tc.source, e, p.Mapping[0].File)
}
}
}
}

func TestFetchWithBase(t *testing.T) {
baseConfig := currentConfig()
defer setCurrentConfig(baseConfig)
Expand Down
Binary file added internal/driver/go.crc32.cpu_2023-12-12_06:06:06
Binary file not shown.
Binary file not shown.

0 comments on commit da083f3

Please sign in to comment.