mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Merge pull request #38292 from AkihiroSuda/fix-pkg-archive-xattr-test
pkg/archive: fix TestTarUntarWithXattr failure on recent kernel
This commit is contained in:
commit
ce58fcedd8
2 changed files with 15 additions and 6 deletions
|
@ -182,6 +182,7 @@ RUN apt-get update && apt-get install -y \
|
|||
btrfs-tools \
|
||||
iptables \
|
||||
jq \
|
||||
libcap2-bin \
|
||||
libdevmapper-dev \
|
||||
libudev-dev \
|
||||
libsystemd-dev \
|
||||
|
|
|
@ -7,6 +7,7 @@ import (
|
|||
"fmt"
|
||||
"io/ioutil"
|
||||
"os"
|
||||
"os/exec"
|
||||
"path/filepath"
|
||||
"strings"
|
||||
"syscall"
|
||||
|
@ -222,6 +223,13 @@ func TestTarWithBlockCharFifo(t *testing.T) {
|
|||
// TestTarUntarWithXattr is Unix as Lsetxattr is not supported on Windows
|
||||
func TestTarUntarWithXattr(t *testing.T) {
|
||||
skip.If(t, os.Getuid() != 0, "skipping test that requires root")
|
||||
if _, err := exec.LookPath("setcap"); err != nil {
|
||||
t.Skip("setcap not installed")
|
||||
}
|
||||
if _, err := exec.LookPath("getcap"); err != nil {
|
||||
t.Skip("getcap not installed")
|
||||
}
|
||||
|
||||
origin, err := ioutil.TempDir("", "docker-test-untar-origin")
|
||||
assert.NilError(t, err)
|
||||
defer os.RemoveAll(origin)
|
||||
|
@ -232,8 +240,9 @@ func TestTarUntarWithXattr(t *testing.T) {
|
|||
assert.NilError(t, err)
|
||||
err = ioutil.WriteFile(filepath.Join(origin, "3"), []byte("will be ignored"), 0700)
|
||||
assert.NilError(t, err)
|
||||
err = system.Lsetxattr(filepath.Join(origin, "2"), "security.capability", []byte{0x00}, 0)
|
||||
assert.NilError(t, err)
|
||||
// there is no known Go implementation of setcap/getcap with support for v3 file capability
|
||||
out, err := exec.Command("setcap", "cap_block_suspend+ep", filepath.Join(origin, "2")).CombinedOutput()
|
||||
assert.NilError(t, err, string(out))
|
||||
|
||||
for _, c := range []Compression{
|
||||
Uncompressed,
|
||||
|
@ -251,10 +260,9 @@ func TestTarUntarWithXattr(t *testing.T) {
|
|||
if len(changes) != 1 || changes[0].Path != "/3" {
|
||||
t.Fatalf("Unexpected differences after tarUntar: %v", changes)
|
||||
}
|
||||
capability, _ := system.Lgetxattr(filepath.Join(origin, "2"), "security.capability")
|
||||
if capability == nil && capability[0] != 0x00 {
|
||||
t.Fatalf("Untar should have kept the 'security.capability' xattr.")
|
||||
}
|
||||
out, err := exec.Command("getcap", filepath.Join(origin, "2")).CombinedOutput()
|
||||
assert.NilError(t, err, string(out))
|
||||
assert.Check(t, is.Contains(string(out), "= cap_block_suspend+ep"), "untar should have kept the 'security.capability' xattr")
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue