mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
596cdffb9f
This allows non-recursive bind-mount, i.e. mount(2) with "bind" rather than "rbind". Swarm-mode will be supported in a separate PR because of mutual vendoring. Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
59 lines
1.8 KiB
Go
59 lines
1.8 KiB
Go
package container
|
|
|
|
import (
|
|
"context"
|
|
"strings"
|
|
|
|
"github.com/docker/docker/client"
|
|
"github.com/pkg/errors"
|
|
"gotest.tools/poll"
|
|
)
|
|
|
|
// IsStopped verifies the container is in stopped state.
|
|
func IsStopped(ctx context.Context, client client.APIClient, containerID string) func(log poll.LogT) poll.Result {
|
|
return func(log poll.LogT) poll.Result {
|
|
inspect, err := client.ContainerInspect(ctx, containerID)
|
|
|
|
switch {
|
|
case err != nil:
|
|
return poll.Error(err)
|
|
case !inspect.State.Running:
|
|
return poll.Success()
|
|
default:
|
|
return poll.Continue("waiting for container to be stopped")
|
|
}
|
|
}
|
|
}
|
|
|
|
// IsInState verifies the container is in one of the specified state, e.g., "running", "exited", etc.
|
|
func IsInState(ctx context.Context, client client.APIClient, containerID string, state ...string) func(log poll.LogT) poll.Result {
|
|
return func(log poll.LogT) poll.Result {
|
|
inspect, err := client.ContainerInspect(ctx, containerID)
|
|
if err != nil {
|
|
return poll.Error(err)
|
|
}
|
|
for _, v := range state {
|
|
if inspect.State.Status == v {
|
|
return poll.Success()
|
|
}
|
|
}
|
|
return poll.Continue("waiting for container to be one of (%s), currently %s", strings.Join(state, ", "), inspect.State.Status)
|
|
}
|
|
}
|
|
|
|
// IsSuccessful verifies state.Status == "exited" && state.ExitCode == 0
|
|
func IsSuccessful(ctx context.Context, client client.APIClient, containerID string) func(log poll.LogT) poll.Result {
|
|
return func(log poll.LogT) poll.Result {
|
|
inspect, err := client.ContainerInspect(ctx, containerID)
|
|
if err != nil {
|
|
return poll.Error(err)
|
|
}
|
|
if inspect.State.Status == "exited" {
|
|
if inspect.State.ExitCode == 0 {
|
|
return poll.Success()
|
|
}
|
|
return poll.Error(errors.Errorf("expected exit code 0, got %d", inspect.State.ExitCode))
|
|
}
|
|
return poll.Continue("waiting for container to be \"exited\", currently %s", inspect.State.Status)
|
|
}
|
|
}
|