2015-05-14 06:42:16 +08:00
|
|
|
// +build linux
|
|
|
|
|
2015-02-27 11:00:17 +08:00
|
|
|
package fs
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2019-11-07 16:25:49 +08:00
|
|
|
"github.com/opencontainers/runc/libcontainer/cgroups/fscommon"
|
2015-06-22 10:29:59 +08:00
|
|
|
"github.com/opencontainers/runc/libcontainer/configs"
|
2015-02-27 11:00:17 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
allowedDevices = []*configs.Device{
|
|
|
|
{
|
|
|
|
Path: "/dev/zero",
|
|
|
|
Type: 'c',
|
|
|
|
Major: 1,
|
|
|
|
Minor: 5,
|
|
|
|
Permissions: "rwm",
|
|
|
|
FileMode: 0666,
|
|
|
|
},
|
|
|
|
}
|
2015-03-31 16:36:00 +08:00
|
|
|
allowedList = "c 1:5 rwm"
|
|
|
|
deniedDevices = []*configs.Device{
|
|
|
|
{
|
|
|
|
Path: "/dev/null",
|
|
|
|
Type: 'c',
|
|
|
|
Major: 1,
|
|
|
|
Minor: 3,
|
|
|
|
Permissions: "rwm",
|
|
|
|
FileMode: 0666,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
deniedList = "c 1:3 rwm"
|
2015-02-27 11:00:17 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestDevicesSetAllow(t *testing.T) {
|
|
|
|
helper := NewCgroupTestUtil("devices", t)
|
|
|
|
defer helper.cleanup()
|
|
|
|
|
|
|
|
helper.writeFileContents(map[string]string{
|
2015-03-09 09:32:02 +08:00
|
|
|
"devices.deny": "a",
|
2015-02-27 11:00:17 +08:00
|
|
|
})
|
2016-07-21 01:46:11 +08:00
|
|
|
allowAllDevices := false
|
|
|
|
helper.CgroupData.config.Resources.AllowAllDevices = &allowAllDevices
|
2015-12-15 08:26:29 +08:00
|
|
|
helper.CgroupData.config.Resources.AllowedDevices = allowedDevices
|
2015-02-27 11:00:17 +08:00
|
|
|
devices := &DevicesGroup{}
|
2015-11-05 18:52:14 +08:00
|
|
|
if err := devices.Set(helper.CgroupPath, helper.CgroupData.config); err != nil {
|
2015-02-27 11:00:17 +08:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2019-11-07 16:25:49 +08:00
|
|
|
value, err := fscommon.GetCgroupParamString(helper.CgroupPath, "devices.allow")
|
2015-02-27 11:00:17 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to parse devices.allow - %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if value != allowedList {
|
|
|
|
t.Fatal("Got the wrong value, set devices.allow failed.")
|
|
|
|
}
|
2016-07-23 09:51:10 +08:00
|
|
|
|
|
|
|
// When AllowAllDevices is nil, devices.allow file should not be modified.
|
|
|
|
helper.CgroupData.config.Resources.AllowAllDevices = nil
|
|
|
|
if err := devices.Set(helper.CgroupPath, helper.CgroupData.config); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2019-11-07 16:25:49 +08:00
|
|
|
value, err = fscommon.GetCgroupParamString(helper.CgroupPath, "devices.allow")
|
2016-07-23 09:51:10 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to parse devices.allow - %s", err)
|
|
|
|
}
|
|
|
|
if value != allowedList {
|
|
|
|
t.Fatal("devices policy shouldn't have changed on AllowedAllDevices=nil.")
|
|
|
|
}
|
2015-02-27 11:00:17 +08:00
|
|
|
}
|
2015-03-31 16:36:00 +08:00
|
|
|
|
|
|
|
func TestDevicesSetDeny(t *testing.T) {
|
|
|
|
helper := NewCgroupTestUtil("devices", t)
|
|
|
|
defer helper.cleanup()
|
|
|
|
|
|
|
|
helper.writeFileContents(map[string]string{
|
|
|
|
"devices.allow": "a",
|
|
|
|
})
|
|
|
|
|
2016-07-21 01:46:11 +08:00
|
|
|
allowAllDevices := true
|
|
|
|
helper.CgroupData.config.Resources.AllowAllDevices = &allowAllDevices
|
2015-12-15 08:26:29 +08:00
|
|
|
helper.CgroupData.config.Resources.DeniedDevices = deniedDevices
|
2015-03-31 16:36:00 +08:00
|
|
|
devices := &DevicesGroup{}
|
2015-11-05 18:52:14 +08:00
|
|
|
if err := devices.Set(helper.CgroupPath, helper.CgroupData.config); err != nil {
|
2015-03-31 16:36:00 +08:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2019-11-07 16:25:49 +08:00
|
|
|
value, err := fscommon.GetCgroupParamString(helper.CgroupPath, "devices.deny")
|
2015-03-31 16:36:00 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to parse devices.deny - %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if value != deniedList {
|
|
|
|
t.Fatal("Got the wrong value, set devices.deny failed.")
|
|
|
|
}
|
|
|
|
}
|