aboutsummaryrefslogtreecommitdiff
path: root/tests/directory_walker.rs
diff options
context:
space:
mode:
authorMax Audron <audron@cocaine.farm>2022-06-07 12:28:18 +0200
committerMaximilian Manz <maximilian.manz@de.clara.net>2022-06-20 11:33:04 +0200
commitf869c7f52d8fd1f1ef61e218bbec4d0dac27673d (patch)
tree8029b33976fc897a4ae81785e622a7e61ad2eb67 /tests/directory_walker.rs
init
Diffstat (limited to 'tests/directory_walker.rs')
-rw-r--r--tests/directory_walker.rs55
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/directory_walker.rs b/tests/directory_walker.rs
new file mode 100644
index 0000000..9fa8d56
--- /dev/null
+++ b/tests/directory_walker.rs
@@ -0,0 +1,55 @@
+use gtree::local::*;
+
+use anyhow::Result;
+use git2::Repository;
+
+const TEST_DIR: &str = env!("CARGO_TARGET_TMPDIR");
+
+const REPOS: [&str; 5] = [
+ "repos/site/group/repo1",
+ "repos/site/group/repo2/subrepo1",
+ "repos/site/group/repo2",
+ "repos/site/group/subgroup/repo3",
+ "repos/site/group/subgroup/subsubgroup/repo4",
+];
+
+fn prepare_repos() -> Result<()> {
+ REPOS.iter().try_for_each(|repo| {
+ let path = format!("{}/{}", TEST_DIR, repo);
+ std::fs::create_dir_all(&path)?;
+ let _repo = Repository::init(&path)?;
+
+ Ok::<(), anyhow::Error>(())
+ })
+}
+
+fn clean_repos() -> Result<()> {
+ REPOS.iter().try_for_each(|repo| {
+ let path = format!("{}/{}", TEST_DIR, repo);
+ std::fs::remove_dir_all(&path)?;
+
+ Ok::<(), anyhow::Error>(())
+ })
+}
+
+#[tokio::test]
+async fn search_repos() -> Result<()> {
+ tracing_subscriber::fmt::init();
+
+ prepare_repos()?;
+
+ let mut left: Vec<String> = vec![
+ format!("{}/repos/site/group/repo1", TEST_DIR),
+ format!("{}/repos/site/group/repo2", TEST_DIR),
+ format!("{}/repos/site/group/subgroup/repo3", TEST_DIR),
+ format!("{}/repos/site/group/subgroup/subsubgroup/repo4", TEST_DIR),
+ ];
+ let right = Repos::from_local(&format!("{}/repos", TEST_DIR), "").await;
+
+ let mut right: Vec<&str> = right.iter().map(|x| x.name.as_str()).collect();
+
+ assert_eq!(left.sort(), right.sort());
+
+ clean_repos()?;
+ Ok(())
+}