mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-03-03 17:26:57 +01:00
Merge pull request #9484 from Abdulkbk/refactor-makedir
lnutils: add CreateDir util function
This commit is contained in:
commit
5d3680a6f6
2 changed files with 118 additions and 0 deletions
31
lnutils/fs.go
Normal file
31
lnutils/fs.go
Normal file
|
@ -0,0 +1,31 @@
|
|||
package lnutils
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"os"
|
||||
)
|
||||
|
||||
// CreateDir creates a directory if it doesn't exist and also handles
|
||||
// symlink-related errors with user-friendly messages. It creates all necessary
|
||||
// parent directories with the specified permissions.
|
||||
func CreateDir(dir string, perm os.FileMode) error {
|
||||
err := os.MkdirAll(dir, perm)
|
||||
if err == nil {
|
||||
return nil
|
||||
}
|
||||
|
||||
// Show a nicer error message if it's because a symlink
|
||||
// is linked to a directory that does not exist
|
||||
// (probably because it's not mounted).
|
||||
var pathErr *os.PathError
|
||||
if errors.As(err, &pathErr) && os.IsExist(err) {
|
||||
link, lerr := os.Readlink(pathErr.Path)
|
||||
if lerr == nil {
|
||||
return fmt.Errorf("is symlink %s -> %s "+
|
||||
"mounted?", pathErr.Path, link)
|
||||
}
|
||||
}
|
||||
|
||||
return fmt.Errorf("failed to create directory '%s': %w", dir, err)
|
||||
}
|
87
lnutils/fs_test.go
Normal file
87
lnutils/fs_test.go
Normal file
|
@ -0,0 +1,87 @@
|
|||
package lnutils
|
||||
|
||||
import (
|
||||
"os"
|
||||
"path/filepath"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
// TestCreateDir verifies the behavior of CreateDir function in various
|
||||
// scenarios:
|
||||
// - Creating a new directory when it doesn't exist
|
||||
// - Handling an already existing directory
|
||||
// - Dealing with symlinks pointing to non-existent directories
|
||||
// - Handling invalid paths
|
||||
// The test uses a temporary directory and runs multiple test cases to ensure
|
||||
// proper directory creation, permission settings, and error handling.
|
||||
func TestCreateDir(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
tempDir := t.TempDir()
|
||||
|
||||
tests := []struct {
|
||||
name string
|
||||
setup func() string
|
||||
wantError bool
|
||||
}{
|
||||
{
|
||||
name: "create directory",
|
||||
setup: func() string {
|
||||
return filepath.Join(tempDir, "testdir")
|
||||
},
|
||||
wantError: false,
|
||||
},
|
||||
{
|
||||
name: "existing directory",
|
||||
setup: func() string {
|
||||
dir := filepath.Join(tempDir, "testdir")
|
||||
err := os.Mkdir(dir, 0700)
|
||||
require.NoError(t, err)
|
||||
|
||||
return dir
|
||||
},
|
||||
wantError: false,
|
||||
},
|
||||
{
|
||||
name: "symlink to non-existent directory",
|
||||
setup: func() string {
|
||||
dir := filepath.Join(tempDir, "testdir")
|
||||
symlink := filepath.Join(tempDir, "symlink")
|
||||
err := os.Symlink(dir, symlink)
|
||||
require.NoError(t, err)
|
||||
|
||||
return symlink
|
||||
},
|
||||
wantError: true,
|
||||
},
|
||||
{
|
||||
name: "invalid path",
|
||||
setup: func() string {
|
||||
return string([]byte{0})
|
||||
},
|
||||
wantError: true,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tc := range tests {
|
||||
tc := tc
|
||||
t.Run(tc.name, func(t *testing.T) {
|
||||
dir := tc.setup()
|
||||
defer os.RemoveAll(dir)
|
||||
|
||||
err := CreateDir(dir, 0700)
|
||||
if tc.wantError {
|
||||
require.Error(t, err)
|
||||
return
|
||||
}
|
||||
|
||||
require.NoError(t, err)
|
||||
|
||||
info, err := os.Stat(dir)
|
||||
require.NoError(t, err)
|
||||
require.True(t, info.IsDir())
|
||||
})
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue