summaryrefslogtreecommitdiff
path: root/libpod/container_api.go
diff options
context:
space:
mode:
Diffstat (limited to 'libpod/container_api.go')
-rw-r--r--libpod/container_api.go25
1 files changed, 10 insertions, 15 deletions
diff --git a/libpod/container_api.go b/libpod/container_api.go
index faf01eccb..5bb610aab 100644
--- a/libpod/container_api.go
+++ b/libpod/container_api.go
@@ -601,23 +601,18 @@ func (c *Container) Cleanup(ctx context.Context) error {
return errors.Wrapf(ErrCtrStateInvalid, "container %s is running or paused, refusing to clean up", c.ID())
}
- // If we have a restart policy match when updating the state, we need to
- // restart the container.
- // However, perform a full validation of restart policy first.
- if c.state.RestartPolicyMatch {
- if c.config.RestartPolicy == RestartPolicyOnFailure && c.state.ExitCode != 0 {
- logrus.Debugf("Container %s restart policy trigger: on retry %d (of %d)",
- c.ID(), c.state.RestartCount, c.config.RestartRetries)
- }
- if (c.config.RestartPolicy == RestartPolicyOnFailure && c.state.ExitCode != 0 &&
- (c.config.RestartRetries > 0 && c.state.RestartCount < c.config.RestartRetries)) ||
- c.config.RestartPolicy == RestartPolicyAlways {
- // The container stopped. We need to restart it.
- return c.handleRestartPolicy(ctx)
- }
+ // Handle restart policy.
+ // Returns a bool indicating whether we actually restarted.
+ // If we did, don't proceed to cleanup - just exit.
+ didRestart, err := c.handleRestartPolicy(ctx)
+ if err != nil {
+ return err
+ }
+ if didRestart {
+ return nil
}
- // If we aren't hitting restart policy, we perform a normal cleanup
+ // If we didn't restart, we perform a normal cleanup
// Check if we have active exec sessions
if len(c.state.ExecSessions) != 0 {