aboutsummaryrefslogtreecommitdiff
path: root/src/tests/mod.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
commite9dc01ffb547d0fa605bfe38b34672ddd5161be4 (patch)
tree5ca50547512b7cc2256ef457d468c4252ae23a0b /src/tests/mod.rs
parentimplement cloning of new repos (diff)
reorganize file structure and cleanup lints
Diffstat (limited to 'src/tests/mod.rs')
-rw-r--r--src/tests/mod.rs59
1 files changed, 59 insertions, 0 deletions
diff --git a/src/tests/mod.rs b/src/tests/mod.rs
new file mode 100644
index 0000000..0d32dbf
--- /dev/null
+++ b/src/tests/mod.rs
@@ -0,0 +1,59 @@
+use crate::repo::*;
+
+use anyhow::Result;
+use git2::Repository;
+
+thread_local! {
+ static TEST_DIR: std::path::PathBuf = std::env::current_exe()
+ .unwrap()
+ .join(std::path::Path::new("../../tmp"));
+}
+
+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_unstable());
+
+ clean_repos()?;
+ Ok(())
+}
span='4' class='logmsg'> 2025-11-15add cgit about-filter for adoc and mdMax Audron-12/+30 2025-11-15add git shell scriptsMax Audron-0/+45 2025-11-15add readmeMax Audron-1/+38 2025-11-14fixup vapor.systems cgitMax Audron-4/+6 2025-11-14move git hosting to plain git-shell and cgitMax Audron-34/+126 reject modernity, embrace linus 2025-10-26fix slskd stuffMax Audron-22/+67 2025-10-23uhMax Audron-9/+31 2025-10-22deploy soulseek and fix tlmp VPNMax Audron-47/+1744 2025-10-21add slskdMax Audron-1/+124 2025-10-10update nixpkgs-unstableMax Audron-3/+3 2025-10-10setup mailserverMax Audron-27/+213 2025-09-20replace dns bgp anouncementMax Audron-2/+2 2025-09-15update flaresolverrMax Audron-1/+1 2025-09-07add audron windows wg keyMax Audron-0/+8 2025-09-02switch out vultr dns ipv4 ipMax Audron-1/+5 2025-08-11disable homepage trackersMax Audron-3/+3 2025-08-11add mail serverMax Audron-1/+245 2025-08-05add prometheus alerting rulesMax Audron-38/+144 2025-08-01add homepage dashboardMax Audron-3/+284 2025-08-01disable not used gameserversMax Audron-1/+2 2025-08-01add minecraft prometheus exporterMax Audron-3/+67 2025-08-01more monitoring & scrape config shortcutsMax Audron-68/+63 2025-08-01update garage to 2.0Max Audron-6/+10 2025-07-31fix authentik-ldap port bindingsMax Audron-0/+5 2025-07-31update to nixos 25.05Max Audron-113/+65 2025-07-31add more monitoring exporters and scrapersMax Audron-17/+57 2025-07-30try to run authentik nativelyMax Audron-26/+303 2025-07-30more metricsMax Audron-1/+41 2025-07-30enable firewallsMax Audron-1/+39