Merge pull request #1782 from ndeloof/inherited_volume

fix volume inheritance and conflict with trailing '/'
This commit is contained in:
Nicolas De loof 2021-06-14 16:30:11 +02:00 committed by GitHub
commit 43655ba500
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 17 additions and 17 deletions

View File

@ -19,6 +19,7 @@ package compose
import ( import (
"context" "context"
"fmt" "fmt"
"path"
"path/filepath" "path/filepath"
"strconv" "strconv"
"strings" "strings"
@ -630,6 +631,7 @@ MOUNTS:
func buildContainerMountOptions(p types.Project, s types.ServiceConfig, img moby.ImageInspect, inherit *moby.Container) ([]mount.Mount, error) { func buildContainerMountOptions(p types.Project, s types.ServiceConfig, img moby.ImageInspect, inherit *moby.Container) ([]mount.Mount, error) {
var mounts = map[string]mount.Mount{} var mounts = map[string]mount.Mount{}
if inherit != nil { if inherit != nil {
for _, m := range inherit.Mounts { for _, m := range inherit.Mounts {
if m.Type == "tmpfs" { if m.Type == "tmpfs" {
continue continue
@ -638,6 +640,11 @@ func buildContainerMountOptions(p types.Project, s types.ServiceConfig, img moby
if m.Type == "volume" { if m.Type == "volume" {
src = m.Name src = m.Name
} }
m.Destination = path.Clean(m.Destination)
if img.Config != nil {
if _, ok := img.Config.Volumes[m.Destination]; ok {
// inherit previous container's anonymous volume
mounts[m.Destination] = mount.Mount{ mounts[m.Destination] = mount.Mount{
Type: m.Type, Type: m.Type,
Source: src, Source: src,
@ -646,16 +653,7 @@ func buildContainerMountOptions(p types.Project, s types.ServiceConfig, img moby
} }
} }
} }
if img.ContainerConfig != nil {
for k := range img.ContainerConfig.Volumes {
m, err := buildMount(p, types.ServiceVolumeConfig{
Type: types.VolumeTypeVolume,
Target: k,
})
if err != nil {
return nil, err
}
mounts[k] = m
} }
} }
@ -801,6 +799,8 @@ func buildMount(project types.Project, volume types.ServiceVolumeConfig) (mount.
bind, vol, tmpfs := buildMountOptions(volume) bind, vol, tmpfs := buildMountOptions(volume)
volume.Target = path.Clean(volume.Target)
return mount.Mount{ return mount.Mount{
Type: mount.Type(volume.Type), Type: mount.Type(volume.Type),
Source: source, Source: source,