8b0441d4 |
// +build linux freebsd
package graphtest
import (
"os"
"syscall"
"testing"
|
7a7357da |
contdriver "github.com/containerd/continuity/driver" |
8b0441d4 |
"github.com/docker/docker/daemon/graphdriver" |
acdbc285 |
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require" |
069fdc8a |
"golang.org/x/sys/unix" |
8b0441d4 |
)
func verifyFile(t testing.TB, path string, mode os.FileMode, uid, gid uint32) {
fi, err := os.Stat(path) |
acdbc285 |
require.NoError(t, err) |
8b0441d4 |
|
acdbc285 |
actual := fi.Mode()
assert.Equal(t, mode&os.ModeType, actual&os.ModeType, path)
assert.Equal(t, mode&os.ModePerm, actual&os.ModePerm, path)
assert.Equal(t, mode&os.ModeSticky, actual&os.ModeSticky, path)
assert.Equal(t, mode&os.ModeSetuid, actual&os.ModeSetuid, path)
assert.Equal(t, mode&os.ModeSetgid, actual&os.ModeSetgid, path) |
8b0441d4 |
if stat, ok := fi.Sys().(*syscall.Stat_t); ok { |
acdbc285 |
assert.Equal(t, uid, stat.Uid, path)
assert.Equal(t, gid, stat.Gid, path) |
8b0441d4 |
}
}
func createBase(t testing.TB, driver graphdriver.Driver, name string) {
// We need to be able to set any perms |
069fdc8a |
oldmask := unix.Umask(0)
defer unix.Umask(oldmask) |
8b0441d4 |
|
acdbc285 |
err := driver.CreateReadWrite(name, "", nil)
require.NoError(t, err) |
8b0441d4 |
|
7a7357da |
dirFS, err := driver.Get(name, "") |
acdbc285 |
require.NoError(t, err) |
8b0441d4 |
defer driver.Put(name)
|
7a7357da |
subdir := dirFS.Join(dirFS.Path(), "a subdir")
require.NoError(t, dirFS.Mkdir(subdir, 0705|os.ModeSticky))
require.NoError(t, dirFS.Lchown(subdir, 1, 2)) |
8b0441d4 |
|
7a7357da |
file := dirFS.Join(dirFS.Path(), "a file")
err = contdriver.WriteFile(dirFS, file, []byte("Some data"), 0222|os.ModeSetuid) |
acdbc285 |
require.NoError(t, err) |
8b0441d4 |
}
func verifyBase(t testing.TB, driver graphdriver.Driver, name string) { |
7a7357da |
dirFS, err := driver.Get(name, "") |
acdbc285 |
require.NoError(t, err) |
8b0441d4 |
defer driver.Put(name)
|
7a7357da |
subdir := dirFS.Join(dirFS.Path(), "a subdir") |
8b0441d4 |
verifyFile(t, subdir, 0705|os.ModeDir|os.ModeSticky, 1, 2)
|
7a7357da |
file := dirFS.Join(dirFS.Path(), "a file") |
8b0441d4 |
verifyFile(t, file, 0222|os.ModeSetuid, 0, 0)
|
7a7357da |
files, err := readDir(dirFS, dirFS.Path()) |
acdbc285 |
require.NoError(t, err)
assert.Len(t, files, 2) |
8b0441d4 |
} |