Check for case when image config isn't present

Signed-off-by: Mrunal Patel <mpatel@redhat.com>
This commit is contained in:
Mrunal Patel 2017-04-04 15:39:59 -07:00
parent 3c7f3ab2ec
commit aac24e1715

View file

@ -172,12 +172,14 @@ func setupContainerUser(specgen *generate.Generator, rootfs string, sc *pb.Linux
containerUser = userName containerUser = userName
} else { } else {
// Case 3: get user from image config // Case 3: get user from image config
if imageConfig != nil {
imageUser := imageConfig.Config.User imageUser := imageConfig.Config.User
if imageUser != "" { if imageUser != "" {
containerUser = imageUser containerUser = imageUser
} }
} }
} }
}
logrus.Debugf("CONTAINER USER: %+v", containerUser) logrus.Debugf("CONTAINER USER: %+v", containerUser)
@ -536,7 +538,9 @@ func (s *Server) createSandboxContainer(ctx context.Context, containerID string,
return nil, fmt.Errorf("failed to mount container %s(%s): %v", containerName, containerID, err) return nil, fmt.Errorf("failed to mount container %s(%s): %v", containerName, containerID, err)
} }
processArgs, err := buildOCIProcessArgs(containerConfig, containerInfo.Config) containerImageConfig := containerInfo.Config
processArgs, err := buildOCIProcessArgs(containerConfig, containerImageConfig)
if err != nil { if err != nil {
return nil, err return nil, err
} }
@ -554,7 +558,8 @@ func (s *Server) createSandboxContainer(ctx context.Context, containerID string,
specgen.AddProcessEnv(key, value) specgen.AddProcessEnv(key, value)
} }
} }
for _, item := range containerInfo.Config.Config.Env { if containerImageConfig != nil {
for _, item := range containerImageConfig.Config.Env {
parts := strings.SplitN(item, "=", 2) parts := strings.SplitN(item, "=", 2)
if len(parts) != 2 { if len(parts) != 2 {
return nil, fmt.Errorf("invalid env from image: %s", item) return nil, fmt.Errorf("invalid env from image: %s", item)
@ -565,14 +570,17 @@ func (s *Server) createSandboxContainer(ctx context.Context, containerID string,
} }
specgen.AddProcessEnv(parts[0], parts[1]) specgen.AddProcessEnv(parts[0], parts[1])
} }
}
// Set working directory // Set working directory
// Pick it up from image config first and override if specified in CRI // Pick it up from image config first and override if specified in CRI
containerCwd := "/" containerCwd := "/"
imageCwd := containerInfo.Config.Config.WorkingDir if containerImageConfig != nil {
imageCwd := containerImageConfig.Config.WorkingDir
if imageCwd != "" { if imageCwd != "" {
containerCwd = imageCwd containerCwd = imageCwd
} }
}
runtimeCwd := containerConfig.WorkingDir runtimeCwd := containerConfig.WorkingDir
if runtimeCwd != "" { if runtimeCwd != "" {
containerCwd = runtimeCwd containerCwd = runtimeCwd
@ -581,7 +589,7 @@ func (s *Server) createSandboxContainer(ctx context.Context, containerID string,
// Setup user and groups // Setup user and groups
if linux != nil { if linux != nil {
if err = setupContainerUser(&specgen, mountPoint, linux.GetSecurityContext(), containerInfo.Config); err != nil { if err = setupContainerUser(&specgen, mountPoint, linux.GetSecurityContext(), containerImageConfig); err != nil {
return nil, err return nil, err
} }
} }