From a28ed75e12e16293057375a039dbe0c850ae230c Mon Sep 17 00:00:00 2001 From: Antonio Murdaca Date: Thu, 1 Jun 2017 15:34:11 +0200 Subject: [PATCH] sandbox_run: fix name releasing on error Signed-off-by: Antonio Murdaca --- server/sandbox_run.go | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/server/sandbox_run.go b/server/sandbox_run.go index 3320c54a..6d1135dd 100644 --- a/server/sandbox_run.go +++ b/server/sandbox_run.go @@ -106,6 +106,13 @@ func (s *Server) RunPodSandbox(ctx context.Context, req *pb.RunPodSandboxRequest return nil, err } } + + defer func() { + if err != nil { + s.releasePodName(name) + } + }() + _, containerName, err := s.generateContainerIDandName(name, "infra", attempt) if err != nil { return nil, err @@ -113,7 +120,7 @@ func (s *Server) RunPodSandbox(ctx context.Context, req *pb.RunPodSandboxRequest defer func() { if err != nil { - s.releasePodName(name) + s.releaseContainerName(containerName) } }() @@ -248,12 +255,6 @@ func (s *Server) RunPodSandbox(ctx context.Context, req *pb.RunPodSandboxRequest return nil, err } - defer func() { - if err != nil { - s.releaseContainerName(containerName) - } - }() - if err = s.ctrIDIndex.Add(id); err != nil { return nil, err } @@ -318,9 +319,6 @@ func (s *Server) RunPodSandbox(ctx context.Context, req *pb.RunPodSandboxRequest defer func() { if err != nil { s.removeSandbox(id) - if err2 := s.podIDIndex.Delete(id); err2 != nil { - logrus.Warnf("couldn't delete pod id %s from idIndex", id) - } } }() @@ -329,6 +327,14 @@ func (s *Server) RunPodSandbox(ctx context.Context, req *pb.RunPodSandboxRequest return nil, err } + defer func() { + if err != nil { + if err := s.podIDIndex.Delete(id); err != nil { + logrus.Warnf("couldn't delete pod id %s from idIndex", id) + } + } + }() + for k, v := range annotations { g.AddAnnotation(k, v) }