From 149b0c62c992267785a1383b87d320be9b377e28 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?St=C3=A9phane=20Graber?= Date: Sat, 10 Feb 2024 18:29:02 -0500 Subject: [PATCH] lxd-to-incus: Indicate what existing configuration was found MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Closes #479 Signed-off-by: Stéphane Graber --- cmd/lxd-to-incus/validate.go | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/cmd/lxd-to-incus/validate.go b/cmd/lxd-to-incus/validate.go index 7fe81702012..24a7c02da0a 100644 --- a/cmd/lxd-to-incus/validate.go +++ b/cmd/lxd-to-incus/validate.go @@ -127,70 +127,70 @@ func (c *cmdMigrate) validate(source source, target target) error { } // Validate target empty. - targetCheckEmpty := func() (bool, error) { + targetCheckEmpty := func() (bool, string, error) { // Check if more than one project. names, err := targetClient.GetProjectNames() if err != nil { - return false, err + return false, "", err } if len(names) > 1 { - return false, nil + return false, "projects", nil } // Check if more than one profile. names, err = targetClient.GetProfileNames() if err != nil { - return false, err + return false, "", err } if len(names) > 1 { - return false, nil + return false, "profiles", nil } // Check if any instance is present. names, err = targetClient.GetInstanceNames(api.InstanceTypeAny) if err != nil { - return false, err + return false, "", err } if len(names) > 0 { - return false, nil + return false, "instances", nil } // Check if any storage pool is present. names, err = targetClient.GetStoragePoolNames() if err != nil { - return false, err + return false, "", err } if len(names) > 0 { - return false, nil + return false, "storage pools", nil } // Check if any network is present. networks, err := targetClient.GetNetworks() if err != nil { - return false, err + return false, "", err } for _, network := range networks { if network.Managed { - return false, nil + return false, "networks", nil } } - return true, nil + return true, "", nil } fmt.Println("=> Checking that the target server is empty") - isEmpty, err = targetCheckEmpty() + isEmpty, found, err := targetCheckEmpty() if err != nil { return fmt.Errorf("Failed to check target server: %w", err) } if !isEmpty { - return fmt.Errorf("Target server isn't empty, can't proceed with migration.") + return fmt.Errorf("Target server isn't empty (%s found), can't proceed with migration.", found) } // Validate configuration.