mirror of https://github.com/docker/compose.git
detect active endpoint trying to remove network and skip with a warning (#10555)
Signed-off-by: Nicolas De Loof <nicolas.deloof@gmail.com>
This commit is contained in:
parent
a14abb9044
commit
bceb3c1876
|
@ -181,9 +181,25 @@ func (s *composeService) removeNetwork(ctx context.Context, name string, w progr
|
||||||
eventName := fmt.Sprintf("Network %s", name)
|
eventName := fmt.Sprintf("Network %s", name)
|
||||||
w.Event(progress.RemovingEvent(eventName))
|
w.Event(progress.RemovingEvent(eventName))
|
||||||
|
|
||||||
var removed int
|
var found int
|
||||||
for _, net := range networks {
|
for _, net := range networks {
|
||||||
if net.Name == name {
|
if net.Name != name {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
network, err := s.apiClient().NetworkInspect(ctx, net.ID, moby.NetworkInspectOptions{})
|
||||||
|
if errdefs.IsNotFound(err) {
|
||||||
|
w.Event(progress.NewEvent(eventName, progress.Warning, "No resource found to remove"))
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if len(network.Containers) > 0 {
|
||||||
|
w.Event(progress.NewEvent(eventName, progress.Warning, "Resource is still in use"))
|
||||||
|
found++
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
if err := s.apiClient().NetworkRemove(ctx, net.ID); err != nil {
|
if err := s.apiClient().NetworkRemove(ctx, net.ID); err != nil {
|
||||||
if errdefs.IsNotFound(err) {
|
if errdefs.IsNotFound(err) {
|
||||||
continue
|
continue
|
||||||
|
@ -191,19 +207,17 @@ func (s *composeService) removeNetwork(ctx context.Context, name string, w progr
|
||||||
w.Event(progress.ErrorEvent(eventName))
|
w.Event(progress.ErrorEvent(eventName))
|
||||||
return errors.Wrapf(err, fmt.Sprintf("failed to remove network %s", name))
|
return errors.Wrapf(err, fmt.Sprintf("failed to remove network %s", name))
|
||||||
}
|
}
|
||||||
removed++
|
w.Event(progress.RemovedEvent(eventName))
|
||||||
}
|
found++
|
||||||
}
|
}
|
||||||
|
|
||||||
if removed == 0 {
|
if found == 0 {
|
||||||
// in practice, it's extremely unlikely for this to ever occur, as it'd
|
// in practice, it's extremely unlikely for this to ever occur, as it'd
|
||||||
// mean the network was present when we queried at the start of this
|
// mean the network was present when we queried at the start of this
|
||||||
// method but was then deleted by something else in the interim
|
// method but was then deleted by something else in the interim
|
||||||
w.Event(progress.NewEvent(eventName, progress.Done, "Warning: No resource found to remove"))
|
w.Event(progress.NewEvent(eventName, progress.Warning, "No resource found to remove"))
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
w.Event(progress.RemovedEvent(eventName))
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -79,6 +79,8 @@ func TestDown(t *testing.T) {
|
||||||
{ID: "abc123", Name: "myProject_default"},
|
{ID: "abc123", Name: "myProject_default"},
|
||||||
{ID: "def456", Name: "myProject_default"},
|
{ID: "def456", Name: "myProject_default"},
|
||||||
}, nil)
|
}, nil)
|
||||||
|
api.EXPECT().NetworkInspect(gomock.Any(), "abc123", gomock.Any()).Return(moby.NetworkResource{ID: "abc123"}, nil)
|
||||||
|
api.EXPECT().NetworkInspect(gomock.Any(), "def456", gomock.Any()).Return(moby.NetworkResource{ID: "def456"}, nil)
|
||||||
api.EXPECT().NetworkRemove(gomock.Any(), "abc123").Return(nil)
|
api.EXPECT().NetworkRemove(gomock.Any(), "abc123").Return(nil)
|
||||||
api.EXPECT().NetworkRemove(gomock.Any(), "def456").Return(nil)
|
api.EXPECT().NetworkRemove(gomock.Any(), "def456").Return(nil)
|
||||||
|
|
||||||
|
@ -118,6 +120,7 @@ func TestDownRemoveOrphans(t *testing.T) {
|
||||||
api.EXPECT().NetworkList(gomock.Any(), moby.NetworkListOptions{
|
api.EXPECT().NetworkList(gomock.Any(), moby.NetworkListOptions{
|
||||||
Filters: filters.NewArgs(filters.Arg("name", "myProject_default")),
|
Filters: filters.NewArgs(filters.Arg("name", "myProject_default")),
|
||||||
}).Return([]moby.NetworkResource{{ID: "abc123", Name: "myProject_default"}}, nil)
|
}).Return([]moby.NetworkResource{{ID: "abc123", Name: "myProject_default"}}, nil)
|
||||||
|
api.EXPECT().NetworkInspect(gomock.Any(), "abc123", gomock.Any()).Return(moby.NetworkResource{ID: "abc123"}, nil)
|
||||||
api.EXPECT().NetworkRemove(gomock.Any(), "abc123").Return(nil)
|
api.EXPECT().NetworkRemove(gomock.Any(), "abc123").Return(nil)
|
||||||
|
|
||||||
err := tested.Down(context.Background(), strings.ToLower(testProject), compose.DownOptions{RemoveOrphans: true})
|
err := tested.Down(context.Background(), strings.ToLower(testProject), compose.DownOptions{RemoveOrphans: true})
|
||||||
|
|
Loading…
Reference in New Issue