Skip to content

Commit

Permalink
Merge pull request #65886 from adityamaru/backport21.1-63467
Browse files Browse the repository at this point in the history
release-21.1: filetable: fix NPE when an empty file is downloaded from userfile
  • Loading branch information
adityamaru authored May 31, 2021
2 parents b46d5c0 + f52706c commit 8afc615
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 26 deletions.
73 changes: 48 additions & 25 deletions pkg/cli/userfiletable_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,7 @@ func TestUserFileUpload(t *testing.T) {

c := newCLITest(cliTestParams{t: t})
defer c.cleanup()
c.omitArgs = true

dir, cleanFn := testutils.TempDir(t)
defer cleanFn()
Expand Down Expand Up @@ -138,37 +139,59 @@ func TestUserFileUpload(t *testing.T) {
err := ioutil.WriteFile(filePath, tc.fileContent, 0666)
require.NoError(t, err)
t.Run(tc.name, func(t *testing.T) {
destination := fmt.Sprintf("/test/file%d.csv", i)
t.Run("destination-not-full-URI", func(t *testing.T) {
destination := fmt.Sprintf("/test/file%d.csv", i)

_, err = c.RunWithCapture(fmt.Sprintf("userfile upload %s %s", filePath,
destination))
require.NoError(t, err)
_, err = c.RunWithCapture(fmt.Sprintf("userfile upload %s %s", filePath,
destination))
require.NoError(t, err)

checkUserFileContent(ctx, t, c.ExecutorConfig(), security.RootUserName(),
constructUserfileDestinationURI("", destination, security.RootUserName()),
tc.fileContent)
})
checkUserFileContent(ctx, t, c.ExecutorConfig(), security.RootUserName(),
constructUserfileDestinationURI("", destination, security.RootUserName()),
tc.fileContent)
})

t.Run(tc.name+"_fullURI", func(t *testing.T) {
destination := fmt.Sprintf("userfile://defaultdb.public.foo/test/file%d.csv", i)
_, err = c.RunWithCapture(fmt.Sprintf("userfile upload %s %s", filePath,
destination))
require.NoError(t, err)
t.Run("full-URI", func(t *testing.T) {
destination := fmt.Sprintf("userfile://defaultdb.public.foo/test/file%d.csv", i)
_, err = c.RunWithCapture(fmt.Sprintf("userfile upload %s %s", filePath,
destination))
require.NoError(t, err)

checkUserFileContent(ctx, t, c.ExecutorConfig(), security.RootUserName(),
destination, tc.fileContent)
})
checkUserFileContent(ctx, t, c.ExecutorConfig(), security.RootUserName(),
destination, tc.fileContent)
})

// Not specifying a qualified table name should default to writing to
// `defaultdb.public.userfiles_username`.
t.Run(tc.name+"_no-host-uri", func(t *testing.T) {
destination := fmt.Sprintf("userfile:///test/file%d.csv", i)
_, err = c.RunWithCapture(fmt.Sprintf("userfile upload %s %s", filePath,
destination))
require.NoError(t, err)
// Not specifying a qualified table name should default to writing to
// `defaultdb.public.userfiles_username`.
t.Run("no-host-uri", func(t *testing.T) {
destination := fmt.Sprintf("userfile:///test/nohost/file%d.csv", i)
_, err = c.RunWithCapture(fmt.Sprintf("userfile upload %s %s", filePath,
destination))
require.NoError(t, err)

checkUserFileContent(ctx, t, c.ExecutorConfig(), security.RootUserName(),
destination, tc.fileContent)
})

checkUserFileContent(ctx, t, c.ExecutorConfig(), security.RootUserName(),
destination, tc.fileContent)
t.Run("get", func(t *testing.T) {
dest := filepath.Join(dir, fmt.Sprintf("tc-%d", i))
destination := fmt.Sprintf("userfile://defaultdb.public.foo/test/file%d.csv", i)
cmd := []string{"userfile", "get", destination, dest}
cliOutput, err := c.RunWithCaptureArgs(cmd)
require.NoError(t, err)
if strings.Contains(cliOutput, "ERROR") {
t.Fatalf("unexpected error: %q", cliOutput)
} else {
lines := strings.Split(strings.TrimSpace(cliOutput), "\n")

var downloaded []string
for i := range lines {
downloaded = append(downloaded, strings.Fields(lines[i])[3])
}
require.Equal(t, []string{fmt.Sprintf("test/file%d.csv", i)}, downloaded,
"get files from %v returned %q", cmd, cliOutput)
}
})
})
}
}
Expand Down
4 changes: 3 additions & 1 deletion pkg/storage/cloudimpl/filetable/file_table_read_writer.go
Original file line number Diff line number Diff line change
Expand Up @@ -697,7 +697,9 @@ func newFileTableReader(
return nil, 0, errors.Wrap(err, "failed to read returned file metadata")
}
fileID = vals[0].([]byte)
sz = vals[1].(int64)
if vals[1] != nil {
sz = vals[1].(int64)
}
default:
panic("unknown executor")
}
Expand Down

0 comments on commit 8afc615

Please sign in to comment.