From 75b891dc12c5a4d85a12d912db08d82ac1778055 Mon Sep 17 00:00:00 2001 From: Michael-F-Bryan Date: Tue, 21 Mar 2023 01:06:52 +0800 Subject: [PATCH] Create the checkout dir if necessary --- lib/cli/src/wasmer_home.rs | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/lib/cli/src/wasmer_home.rs b/lib/cli/src/wasmer_home.rs index 4842d6f52ce..786b1d2343d 100644 --- a/lib/cli/src/wasmer_home.rs +++ b/lib/cli/src/wasmer_home.rs @@ -144,6 +144,9 @@ impl DownloadCached for WasmerHome { return Ok(cached); } + std::fs::create_dir_all(&checkouts) + .with_context(|| format!("Unable to make sure \"{}\" exists", checkouts.display()))?; + // Note: we want to copy directly into a file so we don't hold // everything in memory. let (mut f, path) = if self.disable_cache { @@ -162,9 +165,10 @@ impl DownloadCached for WasmerHome { (f, cached_path) }; - std::io::copy(&mut response, &mut f) - .and_then(|_| f.flush()) + let bytes_read = std::io::copy(&mut response, &mut f) + .and_then(|bytes_read| f.flush().map(|_| bytes_read)) .with_context(|| format!("Unable to save the response to \"{}\"", path.display()))?; + tracing::debug!(bytes_read, path=%path.display(), "Saved to disk"); if !self.disable_cache { if let Some(etag) = etag {