From b37445186048b5c58b38d2a55aca023bf7c539be Mon Sep 17 00:00:00 2001 From: "Hsing-Yu (David) Chen" Date: Tue, 7 Mar 2023 13:30:08 -0800 Subject: [PATCH] fix: print debug logs when lima disk command fails Signed-off-by: Hsing-Yu (David) Chen --- pkg/disk/disk.go | 10 ++++++++-- pkg/disk/disk_test.go | 6 +++--- 2 files changed, 11 insertions(+), 5 deletions(-) diff --git a/pkg/disk/disk.go b/pkg/disk/disk.go index 3ee51dbeb..d7a2d6f31 100644 --- a/pkg/disk/disk.go +++ b/pkg/disk/disk.go @@ -116,7 +116,10 @@ func (m *userDataDiskManager) limaDiskExists() bool { func (m *userDataDiskManager) createLimaDisk() error { cmd := m.lcc.CreateWithoutStdio("disk", "create", diskName, "--size", diskSize) - return cmd.Run() + if logs, err := cmd.CombinedOutput(); err != nil { + return fmt.Errorf("failed to create disk, debug logs:\n%s", logs) + } + return nil } func (m *userDataDiskManager) attachPersistentDiskToLimaDisk() error { @@ -165,5 +168,8 @@ func (m *userDataDiskManager) limaDiskIsLocked() bool { func (m *userDataDiskManager) unlockLimaDisk() error { cmd := m.lcc.CreateWithoutStdio("disk", "unlock", diskName) - return cmd.Run() + if logs, err := cmd.CombinedOutput(); err != nil { + return fmt.Errorf("failed to unlock disk, debug logs:\n%s", logs) + } + return nil } diff --git a/pkg/disk/disk_test.go b/pkg/disk/disk_test.go index 4dcf2a501..fbf4cdf68 100644 --- a/pkg/disk/disk_test.go +++ b/pkg/disk/disk_test.go @@ -55,7 +55,7 @@ func TestUserDataDiskManager_InitializeUserDataDisk(t *testing.T) { cmd.EXPECT().Output().Return([]byte(""), nil) lcc.EXPECT().CreateWithoutStdio(mockCreateArgs).Return(cmd) - cmd.EXPECT().Run().Return(nil) + cmd.EXPECT().CombinedOutput().Return(nil, nil) dfs.EXPECT().Stat(finch.UserDataDiskPath(homeDir)).Return(nil, fs.ErrNotExist) dfs.EXPECT().Stat(path.Dir(finch.UserDataDiskPath(homeDir))).Return(nil, nil) @@ -107,7 +107,7 @@ func TestUserDataDiskManager_InitializeUserDataDisk(t *testing.T) { cmd.EXPECT().Output().Return([]byte(""), nil) lcc.EXPECT().CreateWithoutStdio(mockCreateArgs).Return(cmd) - cmd.EXPECT().Run().Return(nil) + cmd.EXPECT().CombinedOutput().Return(nil, nil) dfs.EXPECT().Stat(finch.UserDataDiskPath(homeDir)).Return(nil, nil) @@ -130,7 +130,7 @@ func TestUserDataDiskManager_InitializeUserDataDisk(t *testing.T) { dfs.EXPECT().Stat(lockPath).Return(nil, nil) lcc.EXPECT().CreateWithoutStdio(mockUnlockArgs).Return(cmd) - cmd.EXPECT().Run().Return(nil) + cmd.EXPECT().CombinedOutput().Return(nil, nil) }, }, }