|
@@ -7,9 +7,11 @@ import (
|
|
|
"os"
|
|
|
"testing"
|
|
|
|
|
|
- "github.com/docker/engine-api/types/container"
|
|
|
+ "github.com/docker/docker/container"
|
|
|
+ containertypes "github.com/docker/engine-api/types/container"
|
|
|
)
|
|
|
|
|
|
+// Unix test as uses settings which are not available on Windows
|
|
|
func TestAdjustCPUShares(t *testing.T) {
|
|
|
tmp, err := ioutil.TempDir("", "docker-daemon-unix-test-")
|
|
|
if err != nil {
|
|
@@ -21,8 +23,8 @@ func TestAdjustCPUShares(t *testing.T) {
|
|
|
root: tmp,
|
|
|
}
|
|
|
|
|
|
- hostConfig := &container.HostConfig{
|
|
|
- Resources: container.Resources{CPUShares: linuxMinCPUShares - 1},
|
|
|
+ hostConfig := &containertypes.HostConfig{
|
|
|
+ Resources: containertypes.Resources{CPUShares: linuxMinCPUShares - 1},
|
|
|
}
|
|
|
daemon.adaptContainerSettings(hostConfig, true)
|
|
|
if hostConfig.CPUShares != linuxMinCPUShares {
|
|
@@ -48,6 +50,7 @@ func TestAdjustCPUShares(t *testing.T) {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+// Unix test as uses settings which are not available on Windows
|
|
|
func TestAdjustCPUSharesNoAdjustment(t *testing.T) {
|
|
|
tmp, err := ioutil.TempDir("", "docker-daemon-unix-test-")
|
|
|
if err != nil {
|
|
@@ -59,8 +62,8 @@ func TestAdjustCPUSharesNoAdjustment(t *testing.T) {
|
|
|
root: tmp,
|
|
|
}
|
|
|
|
|
|
- hostConfig := &container.HostConfig{
|
|
|
- Resources: container.Resources{CPUShares: linuxMinCPUShares - 1},
|
|
|
+ hostConfig := &containertypes.HostConfig{
|
|
|
+ Resources: containertypes.Resources{CPUShares: linuxMinCPUShares - 1},
|
|
|
}
|
|
|
daemon.adaptContainerSettings(hostConfig, false)
|
|
|
if hostConfig.CPUShares != linuxMinCPUShares-1 {
|
|
@@ -85,3 +88,70 @@ func TestAdjustCPUSharesNoAdjustment(t *testing.T) {
|
|
|
t.Error("Expected CPUShares to be unchanged")
|
|
|
}
|
|
|
}
|
|
|
+
|
|
|
+// Unix test as uses settings which are not available on Windows
|
|
|
+func TestParseSecurityOpt(t *testing.T) {
|
|
|
+ container := &container.Container{}
|
|
|
+ config := &containertypes.HostConfig{}
|
|
|
+
|
|
|
+ // test apparmor
|
|
|
+ config.SecurityOpt = []string{"apparmor:test_profile"}
|
|
|
+ if err := parseSecurityOpt(container, config); err != nil {
|
|
|
+ t.Fatalf("Unexpected parseSecurityOpt error: %v", err)
|
|
|
+ }
|
|
|
+ if container.AppArmorProfile != "test_profile" {
|
|
|
+ t.Fatalf("Unexpected AppArmorProfile, expected: \"test_profile\", got %q", container.AppArmorProfile)
|
|
|
+ }
|
|
|
+
|
|
|
+ // test seccomp
|
|
|
+ sp := "/path/to/seccomp_test.json"
|
|
|
+ config.SecurityOpt = []string{"seccomp:" + sp}
|
|
|
+ if err := parseSecurityOpt(container, config); err != nil {
|
|
|
+ t.Fatalf("Unexpected parseSecurityOpt error: %v", err)
|
|
|
+ }
|
|
|
+ if container.SeccompProfile != sp {
|
|
|
+ t.Fatalf("Unexpected AppArmorProfile, expected: %q, got %q", sp, container.SeccompProfile)
|
|
|
+ }
|
|
|
+
|
|
|
+ // test valid label
|
|
|
+ config.SecurityOpt = []string{"label:user:USER"}
|
|
|
+ if err := parseSecurityOpt(container, config); err != nil {
|
|
|
+ t.Fatalf("Unexpected parseSecurityOpt error: %v", err)
|
|
|
+ }
|
|
|
+
|
|
|
+ // test invalid label
|
|
|
+ config.SecurityOpt = []string{"label"}
|
|
|
+ if err := parseSecurityOpt(container, config); err == nil {
|
|
|
+ t.Fatal("Expected parseSecurityOpt error, got nil")
|
|
|
+ }
|
|
|
+
|
|
|
+ // test invalid opt
|
|
|
+ config.SecurityOpt = []string{"test"}
|
|
|
+ if err := parseSecurityOpt(container, config); err == nil {
|
|
|
+ t.Fatal("Expected parseSecurityOpt error, got nil")
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+func TestNetworkOptions(t *testing.T) {
|
|
|
+ daemon := &Daemon{}
|
|
|
+ dconfigCorrect := &Config{
|
|
|
+ CommonConfig: CommonConfig{
|
|
|
+ ClusterStore: "consul://localhost:8500",
|
|
|
+ ClusterAdvertise: "192.168.0.1:8000",
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ if _, err := daemon.networkOptions(dconfigCorrect); err != nil {
|
|
|
+ t.Fatalf("Expect networkOptions sucess, got error: %v", err)
|
|
|
+ }
|
|
|
+
|
|
|
+ dconfigWrong := &Config{
|
|
|
+ CommonConfig: CommonConfig{
|
|
|
+ ClusterStore: "consul://localhost:8500://test://bbb",
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ if _, err := daemon.networkOptions(dconfigWrong); err == nil {
|
|
|
+ t.Fatalf("Expected networkOptions error, got nil")
|
|
|
+ }
|
|
|
+}
|