runtimeFilePath := fmt.Sprintf("%s/runtime.json", dstUrl.Path) dstImagesPath := fmt.Sprintf("%s/images", dstUrl.Path) restoreCmd, err = dst.Start("sudo", "runc", "--id", containerId, "restore", "--image-path", dstImagesPath, "--config-file", configFilePath, "--runtime-file", runtimeFilePath) if err != nil { log.Fatal("Error performing restore:", err) } } var restoreSucceed bool var restoreError error var wg sync.WaitGroup wg.Add(1) go func() { restoreError = restoreCmd.Wait() wg.Done() }() go func() { log.Println("Waiting for container to start...") // We make a fast check so we don't wait for the first ticker internal if isRunning(containerId, dst) { restoreSucceed = true wg.Done() return } ticker := time.NewTicker(200 * time.Millisecond) go func() { for _ = range ticker.C { if isRunning(containerId, dst) {