fix delete and add integeration test

pull/7819/head
Medya Gh 2020-04-20 20:38:31 -07:00
parent e642343323
commit b639c6112d
No known key found for this signature in database
GPG Key ID: 7CF7792C6DF3245C
4 changed files with 88 additions and 18 deletions

View File

@ -147,6 +147,8 @@ func runDelete(cmd *cobra.Command, args []string) {
out.ErrT(out.Meh, `"{{.name}}" profile does not exist, trying anyways.`, out.V{"name": cname}) out.ErrT(out.Meh, `"{{.name}}" profile does not exist, trying anyways.`, out.V{"name": cname})
} }
deletePossibleKicLeftOver(cname)
errs := DeleteProfiles([]*config.Profile{profile}) errs := DeleteProfiles([]*config.Profile{profile})
if len(errs) > 0 { if len(errs) > 0 {
HandleDeletionErrors(errs) HandleDeletionErrors(errs)
@ -189,22 +191,32 @@ func DeleteProfiles(profiles []*config.Profile) []error {
return errs return errs
} }
func deleteProfileContainersAndVolumes(name string) { func deletePossibleKicLeftOver(name string) {
delLabel := fmt.Sprintf("%s=%s", oci.ProfileLabelKey, name) delLabel := fmt.Sprintf("%s=%s", oci.ProfileLabelKey, name)
errs := oci.DeleteContainersByLabel(oci.Docker, delLabel) for _, bin := range []string{oci.Docker, oci.Podman} {
if errs != nil { // it will error if there is no container to delete cs, err := oci.ListContainersByLabel(bin, delLabel)
glog.Infof("error deleting containers for %s (might be okay):\n%v", name, errs) if err == nil && len(cs) > 0 {
for _, c := range cs {
out.T(out.DeletingHost, `Deleting container "{{.name}}" ...`, out.V{"name": name})
err := oci.DeleteContainer(bin, c)
if err != nil { // it will error if there is no container to delete
glog.Errorf("error deleting container %q. you might want to delete that manually :\n%v", name, err)
} }
errs = oci.DeleteAllVolumesByLabel(oci.Docker, delLabel)
}
}
errs := oci.DeleteAllVolumesByLabel(bin, delLabel)
if errs != nil { // it will not error if there is nothing to delete if errs != nil { // it will not error if there is nothing to delete
glog.Warningf("error deleting volumes (might be okay).\nTo see the list of volumes run: 'docker volume ls'\n:%v", errs) glog.Warningf("error deleting volumes (might be okay).\nTo see the list of volumes run: 'docker volume ls'\n:%v", errs)
} }
errs = oci.PruneAllVolumesByLabel(oci.Docker, delLabel) errs = oci.PruneAllVolumesByLabel(bin, delLabel)
if len(errs) > 0 { // it will not error if there is nothing to delete if len(errs) > 0 { // it will not error if there is nothing to delete
glog.Warningf("error pruning volume (might be okay):\n%v", errs) glog.Warningf("error pruning volume (might be okay):\n%v", errs)
} }
} }
}
func deleteProfile(profile *config.Profile) error { func deleteProfile(profile *config.Profile) error {
viper.Set(config.ProfileName, profile.Name) viper.Set(config.ProfileName, profile.Name)
@ -212,7 +224,7 @@ func deleteProfile(profile *config.Profile) error {
// if driver is oci driver, delete containers and volumes // if driver is oci driver, delete containers and volumes
if driver.IsKIC(profile.Config.Driver) { if driver.IsKIC(profile.Config.Driver) {
out.T(out.DeletingHost, `Deleting "{{.profile_name}}" in {{.driver_name}} ...`, out.V{"profile_name": profile.Name, "driver_name": profile.Config.Driver}) out.T(out.DeletingHost, `Deleting "{{.profile_name}}" in {{.driver_name}} ...`, out.V{"profile_name": profile.Name, "driver_name": profile.Config.Driver})
deleteProfileContainersAndVolumes(profile.Name) deletePossibleKicLeftOver(profile.Name)
} }
} }

View File

@ -43,7 +43,7 @@ import (
func DeleteContainersByLabel(ociBin string, label string) []error { func DeleteContainersByLabel(ociBin string, label string) []error {
var deleteErrs []error var deleteErrs []error
cs, err := listContainersByLabel(ociBin, label) cs, err := ListContainersByLabel(ociBin, label)
if err != nil { if err != nil {
return []error{fmt.Errorf("listing containers by label %q", label)} return []error{fmt.Errorf("listing containers by label %q", label)}
} }
@ -322,7 +322,7 @@ func IsCreatedByMinikube(ociBinary string, nameOrID string) bool {
// ListOwnedContainers lists all the containres that kic driver created on user's machine using a label // ListOwnedContainers lists all the containres that kic driver created on user's machine using a label
func ListOwnedContainers(ociBinary string) ([]string, error) { func ListOwnedContainers(ociBinary string) ([]string, error) {
return listContainersByLabel(ociBinary, ProfileLabelKey) return ListContainersByLabel(ociBinary, ProfileLabelKey)
} }
// inspect return low-level information on containers // inspect return low-level information on containers
@ -452,8 +452,8 @@ func withPortMappings(portMappings []PortMapping) createOpt {
} }
} }
// listContainersByLabel returns all the container names with a specified label // ListContainersByLabel returns all the container names with a specified label
func listContainersByLabel(ociBinary string, label string) ([]string, error) { func ListContainersByLabel(ociBinary string, label string) ([]string, error) {
stdout, err := WarnIfSlow(ociBinary, "ps", "-a", "--filter", fmt.Sprintf("label=%s", label), "--format", "{{.Names}}") stdout, err := WarnIfSlow(ociBinary, "ps", "-a", "--filter", fmt.Sprintf("label=%s", label), "--format", "{{.Names}}")
if err != nil { if err != nil {
return nil, err return nil, err

View File

@ -69,9 +69,19 @@ func HyperVDriver() bool {
return strings.Contains(*startArgs, "--driver=hyperv") || strings.Contains(*startArgs, "--vm-driver=hyperv") return strings.Contains(*startArgs, "--driver=hyperv") || strings.Contains(*startArgs, "--vm-driver=hyperv")
} }
// DockerDriver returns whether or not this test is using the docker or podman driver
func DockerDriver() bool {
return strings.Contains(*startArgs, "--driver=docker") || strings.Contains(*startArgs, "--vm-driver=docker")
}
// PodmanDriver returns whether or not this test is using the docker or podman driver
func PodmanDriver() bool {
return strings.Contains(*startArgs, "--vm-driver=podman") || strings.Contains(*startArgs, "driver=podman")
}
// KicDriver returns whether or not this test is using the docker or podman driver // KicDriver returns whether or not this test is using the docker or podman driver
func KicDriver() bool { func KicDriver() bool {
return strings.Contains(*startArgs, "--driver=docker") || strings.Contains(*startArgs, "--vm-driver=docker") || strings.Contains(*startArgs, "--vm-driver=podman") || strings.Contains(*startArgs, "driver=podman") return DockerDriver() || PodmanDriver()
} }
// NeedsPortForward returns access to endpoints with this driver needs port forwarding // NeedsPortForward returns access to endpoints with this driver needs port forwarding

View File

@ -20,6 +20,7 @@ package integration
import ( import (
"context" "context"
"encoding/json"
"os/exec" "os/exec"
"strings" "strings"
"testing" "testing"
@ -45,6 +46,7 @@ func TestPause(t *testing.T) {
{"Unpause", validateUnpause}, {"Unpause", validateUnpause},
{"PauseAgain", validatePause}, {"PauseAgain", validatePause},
{"DeletePaused", validateDelete}, {"DeletePaused", validateDelete},
{"VerifyDeletedResources", validateVerifyDeleted},
} }
for _, tc := range tests { for _, tc := range tests {
tc := tc tc := tc
@ -103,3 +105,49 @@ func validateDelete(ctx context.Context, t *testing.T, profile string) {
t.Errorf("failed to delete minikube with args: %q : %v", rr.Command(), err) t.Errorf("failed to delete minikube with args: %q : %v", rr.Command(), err)
} }
} }
func validateVerifyDeleted(ctx context.Context, t *testing.T, profile string) {
// vervose logging because this might go wrong, if container get stuck
args := []string{"profile", "list"}
rr, err := Run(t, exec.CommandContext(ctx, Target(), "profile", "list", "--output", "json"))
if err != nil {
t.Errorf("failed to list profiles with json format after it was deleted. args %q: %v", rr.Command(), err)
}
var jsonObject map[string][]map[string]interface{}
err = json.Unmarshal(rr.Stdout.Bytes(), &jsonObject)
if err != nil {
t.Errorf("failed to decode json from profile list: args %q: %v", rr.Command(), err)
}
validProfiles := jsonObject["valid"]
profileExists := false
for _, profileObject := range validProfiles {
if profileObject["Name"] == profile {
profileExists = true
break
}
}
if profileExists {
t.Errorf("expected the deleted profile doesnt show up in profile list anymore but got *%q*. args: %q", profile, rr.Stdout.String(), rr.Command())
}
if KicDriver() {
bin := "docker"
if PodmanDriver() {
bin = "podman"
}
args = []string{"ps", "-a"}
rr, err := Run(t, exec.CommandContext(ctx, bin, args...))
if err == nil && strings.Contains(rr.Output(), profile) {
t.Errorf("expected container %q not to exist in output of %s but got : %s", rr.Command(), rr.Output())
}
args = []string{"volume", "inspect", profile}
rr, err := Run(t, exec.CommandContext(ctx, bin, args...))
if err == nil {
t.Errorf("expected to see error and volume %q to not exist after deletion but got no error and this output: %s", rr.Command(), rr.Output())
}
}
}