|
7 | 7 | "os" |
8 | 8 | "path/filepath" |
9 | 9 | "runtime" |
| 10 | + "syscall" |
10 | 11 | "testing" |
11 | 12 |
|
12 | 13 | "github.com/go-git/go-billy/v6" |
@@ -47,3 +48,27 @@ func TestCapabilities(t *testing.T) { |
47 | 48 | caps := billy.Capabilities(fs) |
48 | 49 | assert.Equal(t, billy.AllCapabilities, caps) |
49 | 50 | } |
| 51 | + |
| 52 | +func TestCreateWithChroot(t *testing.T) { |
| 53 | + fs, _ := setup(t) |
| 54 | + umask := syscall.Umask(2) |
| 55 | + chroot, _ := fs.Chroot("foo") |
| 56 | + f, err := chroot.Create("bar") |
| 57 | + require.NoError(t, err) |
| 58 | + require.NoError(t, f.Close()) |
| 59 | + assert.Equal(t, f.Name(), "bar") |
| 60 | + syscall.Umask(umask) |
| 61 | + |
| 62 | + di, err := fs.Stat(fs.Join("foo")) |
| 63 | + require.NoError(t, err) |
| 64 | + expected := 0o775 |
| 65 | + actual := int(di.Mode().Perm()) |
| 66 | + assert.Equal( |
| 67 | + t, expected, actual, "Permission mismatch - expected: 0o%o, actual: 0o%o", expected, actual, |
| 68 | + ) |
| 69 | + |
| 70 | + f, err = fs.Open("foo/bar") |
| 71 | + require.NoError(t, err) |
| 72 | + assert.Equal(t, f.Name(), fs.Join("foo", "bar")) |
| 73 | + require.NoError(t, f.Close()) |
| 74 | +} |
0 commit comments