mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Fix panic in TestExecSetPlatformOpt, TestExecSetPlatformOptPrivileged
These tests would panic; - in WithRLimits(), because HostConfig was not set;470ae8422f/daemon/oci_linux.go (L46-L47)
- in daemon.mergeUlimits(), because daemon.configStore was not set;470ae8422f/daemon/oci_linux.go (L1069)
This panic was not discovered because the current version of runc/libcontainer that we vendor would not always return false for `apparmor.IsEnabled()` when running docker-in-docker or if `apparmor_parser` is not found. Starting with v1.0.0-rc93 of libcontainer, this is no longer the case (changed inbfb4ea1b1b
) This patch; - changes the tests to initialize Daemon.configStore and Container.HostConfig - Combines TestExecSetPlatformOpt and TestExecSetPlatformOptPrivileged into a new test (TestExecSetPlatformOptAppArmor) - Runs the test both if AppArmor is enabled and if not (in which case it tests that the container's AppArmor profile is left empty). - Adds a FIXME comment for a possible bug in execSetPlatformOpts, which currently prefers custom profiles over "privileged". Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
parent
369d0dc092
commit
6d1eceb509
1 changed files with 70 additions and 33 deletions
|
@ -8,46 +8,83 @@ import (
|
||||||
"github.com/containerd/containerd/pkg/apparmor"
|
"github.com/containerd/containerd/pkg/apparmor"
|
||||||
containertypes "github.com/docker/docker/api/types/container"
|
containertypes "github.com/docker/docker/api/types/container"
|
||||||
"github.com/docker/docker/container"
|
"github.com/docker/docker/container"
|
||||||
|
"github.com/docker/docker/daemon/config"
|
||||||
"github.com/docker/docker/daemon/exec"
|
"github.com/docker/docker/daemon/exec"
|
||||||
specs "github.com/opencontainers/runtime-spec/specs-go"
|
specs "github.com/opencontainers/runtime-spec/specs-go"
|
||||||
"gotest.tools/v3/assert"
|
"gotest.tools/v3/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestExecSetPlatformOpt(t *testing.T) {
|
func TestExecSetPlatformOptAppArmor(t *testing.T) {
|
||||||
if !apparmor.HostSupports() {
|
appArmorEnabled := apparmor.HostSupports()
|
||||||
t.Skip("requires AppArmor to be enabled")
|
|
||||||
|
tests := []struct {
|
||||||
|
doc string
|
||||||
|
privileged bool
|
||||||
|
appArmorProfile string
|
||||||
|
expectedProfile string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
doc: "default options",
|
||||||
|
expectedProfile: defaultAppArmorProfile,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
doc: "custom profile",
|
||||||
|
appArmorProfile: "my-custom-profile",
|
||||||
|
expectedProfile: "my-custom-profile",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
doc: "privileged container",
|
||||||
|
privileged: true,
|
||||||
|
expectedProfile: unconfinedAppArmorProfile,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
doc: "privileged container, custom profile",
|
||||||
|
privileged: true,
|
||||||
|
appArmorProfile: "my-custom-profile",
|
||||||
|
expectedProfile: "my-custom-profile",
|
||||||
|
// FIXME: execSetPlatformOpts prefers custom profiles over "privileged",
|
||||||
|
// which looks like a bug (--privileged on the container should
|
||||||
|
// disable apparmor, seccomp, and selinux); see the code at:
|
||||||
|
// https://github.com/moby/moby/blob/46cdcd206c56172b95ba5c77b827a722dab426c5/daemon/exec_linux.go#L32-L40
|
||||||
|
// expectedProfile: unconfinedAppArmorProfile,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
d := &Daemon{}
|
|
||||||
c := &container.Container{AppArmorProfile: "my-custom-profile"}
|
|
||||||
ec := &exec.Config{}
|
|
||||||
p := &specs.Process{}
|
|
||||||
|
|
||||||
err := d.execSetPlatformOpt(c, ec, p)
|
d := &Daemon{configStore: &config.Config{}}
|
||||||
assert.NilError(t, err)
|
|
||||||
assert.Equal(t, "my-custom-profile", p.ApparmorProfile)
|
|
||||||
}
|
|
||||||
|
|
||||||
// TestExecSetPlatformOptPrivileged verifies that `docker exec --privileged`
|
// Currently, `docker exec --privileged` inherits the Privileged configuration
|
||||||
// does not disable AppArmor profiles. Exec currently inherits the `Privileged`
|
// of the container, and does not disable AppArmor.
|
||||||
// configuration of the container. See https://github.com/moby/moby/pull/31773#discussion_r105586900
|
// See https://github.com/moby/moby/pull/31773#discussion_r105586900
|
||||||
//
|
//
|
||||||
// This behavior may change in future, but test for the behavior to prevent it
|
// This behavior may change in future, but to verify the current behavior,
|
||||||
// from being changed accidentally.
|
// we run the test both with "exec" and "exec --privileged", which should
|
||||||
func TestExecSetPlatformOptPrivileged(t *testing.T) {
|
// both give the same result.
|
||||||
if !apparmor.HostSupports() {
|
for _, execPrivileged := range []bool{false, true} {
|
||||||
t.Skip("requires AppArmor to be enabled")
|
for _, tc := range tests {
|
||||||
|
tc := tc
|
||||||
|
doc := tc.doc
|
||||||
|
if !appArmorEnabled {
|
||||||
|
// no profile should be set if the host does not support AppArmor
|
||||||
|
doc += " (apparmor disabled)"
|
||||||
|
tc.expectedProfile = ""
|
||||||
|
}
|
||||||
|
if execPrivileged {
|
||||||
|
doc += " (exec privileged)"
|
||||||
|
}
|
||||||
|
t.Run(doc, func(t *testing.T) {
|
||||||
|
c := &container.Container{
|
||||||
|
AppArmorProfile: tc.appArmorProfile,
|
||||||
|
HostConfig: &containertypes.HostConfig{
|
||||||
|
Privileged: tc.privileged,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
ec := &exec.Config{Privileged: execPrivileged}
|
||||||
|
p := &specs.Process{}
|
||||||
|
|
||||||
|
err := d.execSetPlatformOpt(c, ec, p)
|
||||||
|
assert.NilError(t, err)
|
||||||
|
assert.Equal(t, p.ApparmorProfile, tc.expectedProfile)
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
d := &Daemon{}
|
|
||||||
c := &container.Container{AppArmorProfile: "my-custom-profile"}
|
|
||||||
ec := &exec.Config{Privileged: true}
|
|
||||||
p := &specs.Process{}
|
|
||||||
|
|
||||||
err := d.execSetPlatformOpt(c, ec, p)
|
|
||||||
assert.NilError(t, err)
|
|
||||||
assert.Equal(t, "my-custom-profile", p.ApparmorProfile)
|
|
||||||
|
|
||||||
c.HostConfig = &containertypes.HostConfig{Privileged: true}
|
|
||||||
err = d.execSetPlatformOpt(c, ec, p)
|
|
||||||
assert.NilError(t, err)
|
|
||||||
assert.Equal(t, unconfinedAppArmorProfile, p.ApparmorProfile)
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue