Skip to content

Commit

Permalink
Merge pull request #901 from Random-Liu/fix-hostname-env
Browse files Browse the repository at this point in the history
Fix hostname env.
  • Loading branch information
Random-Liu committed Sep 10, 2018
2 parents cfdf872 + f08a90f commit ed68cfd
Show file tree
Hide file tree
Showing 5 changed files with 75 additions and 0 deletions.
6 changes: 6 additions & 0 deletions pkg/os/os.go
Expand Up @@ -43,6 +43,7 @@ type OS interface {
Mount(source string, target string, fstype string, flags uintptr, data string) error
Unmount(target string) error
LookupMount(path string) (mount.Info, error)
Hostname() (string, error)
}

// RealOS is used to dispatch the real system level operations.
Expand Down Expand Up @@ -134,3 +135,8 @@ func Unmount(target string) error {

return err
}

// Hostname will call os.Hostname to get the hostname of the host.
func (RealOS) Hostname() (string, error) {
return os.Hostname()
}
14 changes: 14 additions & 0 deletions pkg/os/testing/fake_os.go
Expand Up @@ -51,6 +51,7 @@ type FakeOS struct {
MountFn func(source string, target string, fstype string, flags uintptr, data string) error
UnmountFn func(target string) error
LookupMountFn func(path string) (containerdmount.Info, error)
HostnameFn func() (string, error)
calls []CalledDetail
errors map[string]error
}
Expand Down Expand Up @@ -254,3 +255,16 @@ func (f *FakeOS) LookupMount(path string) (containerdmount.Info, error) {
}
return containerdmount.Info{}, nil
}

// Hostname is a fake call that invokes HostnameFn or just return nil.
func (f *FakeOS) Hostname() (string, error) {
f.appendCalls("Hostname")
if err := f.getError("Hostname"); err != nil {
return "", err
}

if f.HostnameFn != nil {
return f.HostnameFn()
}
return "", nil
}
11 changes: 11 additions & 0 deletions pkg/server/container_create.go
Expand Up @@ -334,6 +334,17 @@ func (c *criService) generateContainerSpec(id string, sandboxID string, sandboxP
g.AddProcessEnv("TERM", "xterm")
}

// Add HOSTNAME env.
hostname := sandboxConfig.GetHostname()
if sandboxConfig.GetLinux().GetSecurityContext().GetNamespaceOptions().GetNetwork() == runtime.NamespaceMode_NODE &&
hostname == "" {
hostname, err = c.os.Hostname()
if err != nil {
return nil, err
}
}
g.AddProcessEnv(hostnameEnv, hostname)

// Apply envs from image config first, so that envs from container config
// can override them.
if err := addImageEnvs(&g, imageConfig.Env); err != nil {
Expand Down
42 changes: 42 additions & 0 deletions pkg/server/container_create_test.go
Expand Up @@ -979,3 +979,45 @@ func TestMaskedAndReadonlyPaths(t *testing.T) {
assert.Equal(t, test.expectedReadonly, spec.Linux.ReadonlyPaths)
}
}

func TestHostname(t *testing.T) {
testID := "test-id"
testSandboxID := "sandbox-id"
testPid := uint32(1234)
config, sandboxConfig, imageConfig, specCheck := getCreateContainerTestData()
c := newTestCRIService()
c.os.(*ostesting.FakeOS).HostnameFn = func() (string, error) {
return "real-hostname", nil
}
for desc, test := range map[string]struct {
hostname string
networkNs runtime.NamespaceMode
expectedEnv string
}{
"should add HOSTNAME=sandbox.Hostname for pod network namespace": {
hostname: "test-hostname",
networkNs: runtime.NamespaceMode_POD,
expectedEnv: "HOSTNAME=test-hostname",
},
"should add HOSTNAME=sandbox.Hostname for host network namespace": {
hostname: "test-hostname",
networkNs: runtime.NamespaceMode_NODE,
expectedEnv: "HOSTNAME=test-hostname",
},
"should add HOSTNAME=os.Hostname for host network namespace if sandbox.Hostname is not set": {
hostname: "",
networkNs: runtime.NamespaceMode_NODE,
expectedEnv: "HOSTNAME=real-hostname",
},
} {
t.Logf("TestCase %q", desc)
sandboxConfig.Hostname = test.hostname
sandboxConfig.Linux.SecurityContext = &runtime.LinuxSandboxSecurityContext{
NamespaceOptions: &runtime.NamespaceOption{Network: test.networkNs},
}
spec, err := c.generateContainerSpec(testID, testSandboxID, testPid, config, sandboxConfig, imageConfig, nil)
require.NoError(t, err)
specCheck(t, testID, testSandboxID, testPid, spec)
assert.Contains(t, spec.Process.Env, test.expectedEnv)
}
}
2 changes: 2 additions & 0 deletions pkg/server/helpers.go
Expand Up @@ -97,6 +97,8 @@ const (
etcHosts = "/etc/hosts"
// resolvConfPath is the abs path of resolv.conf on host or container.
resolvConfPath = "/etc/resolv.conf"
// hostnameEnv is the key for HOSTNAME env.
hostnameEnv = "HOSTNAME"
)

const (
Expand Down

0 comments on commit ed68cfd

Please sign in to comment.