diff options
| author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2022-05-02 11:53:30 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-05-02 11:53:30 -0400 | 
| commit | c3d871a3f6cc7a94c5e86782ba63e05cd1d2faeb (patch) | |
| tree | 589ce895fa6ab9ab7a605ea5016307d9915c74a2 /libpod/pod_api.go | |
| parent | adf6ee671ff8111b3b1d1819a65fcc05e44589ef (diff) | |
| parent | 4eff0c8cf284a6007122aec731e4d97059750166 (diff) | |
| download | podman-c3d871a3f6cc7a94c5e86782ba63e05cd1d2faeb.tar.gz podman-c3d871a3f6cc7a94c5e86782ba63e05cd1d2faeb.tar.bz2 podman-c3d871a3f6cc7a94c5e86782ba63e05cd1d2faeb.zip | |
Merge pull request #13859 from vrothberg/fix-13464
pod: add exit policies
Diffstat (limited to 'libpod/pod_api.go')
| -rw-r--r-- | libpod/pod_api.go | 51 | 
1 files changed, 51 insertions, 0 deletions
| diff --git a/libpod/pod_api.go b/libpod/pod_api.go index ba30d878e..73b28822b 100644 --- a/libpod/pod_api.go +++ b/libpod/pod_api.go @@ -2,6 +2,7 @@ package libpod  import (  	"context" +	"fmt"  	"github.com/containers/common/pkg/cgroups"  	"github.com/containers/podman/v4/libpod/define" @@ -134,6 +135,10 @@ func (p *Pod) StopWithTimeout(ctx context.Context, cleanup bool, timeout int) (m  	p.lock.Lock()  	defer p.lock.Unlock() +	return p.stopWithTimeout(ctx, cleanup, timeout) +} + +func (p *Pod) stopWithTimeout(ctx context.Context, cleanup bool, timeout int) (map[string]error, error) {  	if !p.valid {  		return nil, define.ErrPodRemoved  	} @@ -195,6 +200,51 @@ func (p *Pod) StopWithTimeout(ctx context.Context, cleanup bool, timeout int) (m  	return nil, nil  } +// Stops the pod if only the infra containers remains running. +func (p *Pod) stopIfOnlyInfraRemains(ctx context.Context, ignoreID string) error { +	p.lock.Lock() +	defer p.lock.Unlock() + +	infraID := "" + +	if p.HasInfraContainer() { +		infra, err := p.infraContainer() +		if err != nil { +			return err +		} +		infraID = infra.ID() +	} + +	allCtrs, err := p.runtime.state.PodContainers(p) +	if err != nil { +		return err +	} + +	for _, ctr := range allCtrs { +		if ctr.ID() == infraID || ctr.ID() == ignoreID { +			continue +		} + +		state, err := ctr.State() +		if err != nil { +			return fmt.Errorf("getting state of container %s: %w", ctr.ID(), err) +		} + +		switch state { +		case define.ContainerStateExited, +			define.ContainerStateRemoving, +			define.ContainerStateStopping, +			define.ContainerStateUnknown: +			continue +		default: +			return nil +		} +	} + +	_, err = p.stopWithTimeout(ctx, true, -1) +	return err +} +  // Cleanup cleans up all containers within a pod that have stopped.  // All containers are cleaned up independently. An error with one container will  // not prevent other containers being cleaned up. @@ -661,6 +711,7 @@ func (p *Pod) Inspect() (*define.InspectPodData, error) {  		Namespace:          p.Namespace(),  		Created:            p.CreatedTime(),  		CreateCommand:      p.config.CreateCommand, +		ExitPolicy:         string(p.config.ExitPolicy),  		State:              podState,  		Hostname:           p.config.Hostname,  		Labels:             p.Labels(), | 
