1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
// Copyright (C) 2021 Quickwit, Inc.
//
// Quickwit is offered under the AGPL v3.0 and as commercial software.
// For commercial licensing, contact us at hello@quickwit.io.
//
// AGPL:
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
use std::path::Path;
use tokio;
/// Deletes the contents of a directory.
pub async fn empty_dir<P: AsRef<Path>>(path: P) -> anyhow::Result<()> {
let mut entries = tokio::fs::read_dir(path).await?;
while let Some(entry) = entries.next_entry().await? {
if entry.file_type().await?.is_dir() {
tokio::fs::remove_dir_all(entry.path()).await?
} else {
tokio::fs::remove_file(entry.path()).await?;
}
}
Ok(())
}
#[cfg(test)]
mod tests {
use tempfile;
use super::*;
#[tokio::test]
async fn test_empty_dir() -> anyhow::Result<()> {
let tempdir = tempfile::tempdir()?;
let file_path = tempdir.path().join("file");
tokio::fs::File::create(file_path).await?;
let subdir = tempdir.path().join("subdir");
tokio::fs::create_dir(&subdir).await?;
let subfile_path = subdir.join("subfile");
tokio::fs::File::create(subfile_path).await?;
empty_dir(tempdir.path()).await?;
assert!(tokio::fs::read_dir(tempdir.path())
.await?
.next_entry()
.await?
.is_none());
Ok(())
}
}