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:
Nicolas De loof 2023-05-11 22:31:29 +02:00 committed by GitHub
parent a14abb9044
commit bceb3c1876
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 31 additions and 14 deletions

View File

@ -181,29 +181,43 @@ 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 {
if err := s.apiClient().NetworkRemove(ctx, net.ID); err != nil { continue
if errdefs.IsNotFound(err) {
continue
}
w.Event(progress.ErrorEvent(eventName))
return errors.Wrapf(err, fmt.Sprintf("failed to remove network %s", name))
}
removed++
} }
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 errdefs.IsNotFound(err) {
continue
}
w.Event(progress.ErrorEvent(eventName))
return errors.Wrapf(err, fmt.Sprintf("failed to remove network %s", name))
}
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
} }

View File

@ -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})