зеркало из https://github.com/microsoft/docker.git
Merge pull request #25030 from stevvooe/allow-cancellation-propagation
swarm/controller: allow cancellation to propagate
This commit is contained in:
Коммит
a6a261261d
|
@ -87,6 +87,11 @@ func (r *controller) Prepare(ctx context.Context) error {
|
||||||
|
|
||||||
if os.Getenv("DOCKER_SERVICE_PREFER_OFFLINE_IMAGE") != "1" {
|
if os.Getenv("DOCKER_SERVICE_PREFER_OFFLINE_IMAGE") != "1" {
|
||||||
if err := r.adapter.pullImage(ctx); err != nil {
|
if err := r.adapter.pullImage(ctx); err != nil {
|
||||||
|
cause := errors.Cause(err)
|
||||||
|
if cause == context.Canceled || cause == context.DeadlineExceeded {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// NOTE(stevvooe): We always try to pull the image to make sure we have
|
// NOTE(stevvooe): We always try to pull the image to make sure we have
|
||||||
// the most up to date version. This will return an error, but we only
|
// the most up to date version. This will return an error, but we only
|
||||||
// log it. If the image truly doesn't exist, the create below will
|
// log it. If the image truly doesn't exist, the create below will
|
||||||
|
|
|
@ -40,7 +40,11 @@ type fallbackError struct {
|
||||||
|
|
||||||
// Error renders the FallbackError as a string.
|
// Error renders the FallbackError as a string.
|
||||||
func (f fallbackError) Error() string {
|
func (f fallbackError) Error() string {
|
||||||
return f.err.Error()
|
return f.Cause().Error()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f fallbackError) Cause() error {
|
||||||
|
return f.err
|
||||||
}
|
}
|
||||||
|
|
||||||
// shouldV2Fallback returns true if this error is a reason to fall back to v1.
|
// shouldV2Fallback returns true if this error is a reason to fall back to v1.
|
||||||
|
|
Загрузка…
Ссылка в новой задаче