chore: replace CreateForge.import with starchart_url for marking forge
instances with Starchart instances
This commit is contained in:
parent
8cf21c3ce6
commit
38fee3daf3
5 changed files with 22 additions and 22 deletions
|
@ -60,13 +60,15 @@ pub mod dev {
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
|
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
|
||||||
/// create a new forge on the database
|
/// create a new forge on the database
|
||||||
pub struct CreateForge {
|
pub struct CreateForge<'a> {
|
||||||
|
/// url of the Starchart instance
|
||||||
|
/// None = local instance
|
||||||
|
/// Some(&'a str) = foreign instance
|
||||||
|
pub starchart_url: Option<&'a str>,
|
||||||
/// url of the forge instance: with scheme but remove trailing slash
|
/// url of the forge instance: with scheme but remove trailing slash
|
||||||
pub url: Url,
|
pub url: Url,
|
||||||
/// forge type: which software is the instance running?
|
/// forge type: which software is the instance running?
|
||||||
pub forge_type: ForgeImplementation,
|
pub forge_type: ForgeImplementation,
|
||||||
/// is this forge an import
|
|
||||||
pub import: bool,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get url from URL
|
/// Get url from URL
|
||||||
|
@ -136,14 +138,16 @@ pub struct AddRepository<'a> {
|
||||||
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
|
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
|
||||||
/// data representing a forge instance
|
/// data representing a forge instance
|
||||||
pub struct Forge {
|
pub struct Forge {
|
||||||
|
/// url of the Starchart instance
|
||||||
|
/// None = local instance
|
||||||
|
/// Some(&'a str) = foreign instance
|
||||||
|
pub starchart_url: Option<String>,
|
||||||
/// url of the forge
|
/// url of the forge
|
||||||
pub url: String,
|
pub url: String,
|
||||||
/// type of the forge
|
/// type of the forge
|
||||||
pub forge_type: ForgeImplementation,
|
pub forge_type: ForgeImplementation,
|
||||||
/// last crawl
|
/// last crawl
|
||||||
pub last_crawl_on: Option<i64>,
|
pub last_crawl_on: Option<i64>,
|
||||||
/// is this forge an import
|
|
||||||
pub import: bool,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
|
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
|
||||||
|
@ -225,6 +229,9 @@ pub trait SCDatabase: std::marker::Send + std::marker::Sync + CloneSPDatabase {
|
||||||
|
|
||||||
/// Search all repositories
|
/// Search all repositories
|
||||||
async fn search_repository(&self, query: &str) -> DBResult<Vec<Repository>>;
|
async fn search_repository(&self, query: &str) -> DBResult<Vec<Repository>>;
|
||||||
|
|
||||||
|
/// Add Starchart instance to introducer
|
||||||
|
async fn add_starchart_to_introducer(&self, url: &Url) -> DBResult<()>;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Trait to clone SCDatabase
|
/// Trait to clone SCDatabase
|
||||||
|
|
|
@ -21,7 +21,7 @@ use crate::prelude::*;
|
||||||
/// adding forge works
|
/// adding forge works
|
||||||
pub async fn adding_forge_works<'a, T: SCDatabase>(
|
pub async fn adding_forge_works<'a, T: SCDatabase>(
|
||||||
db: &T,
|
db: &T,
|
||||||
create_forge_msg: CreateForge,
|
create_forge_msg: CreateForge<'a>,
|
||||||
add_user_msg: AddUser<'a>,
|
add_user_msg: AddUser<'a>,
|
||||||
add_user_msg2: AddUser<'a>,
|
add_user_msg2: AddUser<'a>,
|
||||||
add_repo_msg: AddRepository<'a>,
|
add_repo_msg: AddRepository<'a>,
|
||||||
|
@ -35,20 +35,13 @@ pub async fn adding_forge_works<'a, T: SCDatabase>(
|
||||||
|
|
||||||
{
|
{
|
||||||
let forge = db.get_forge(&create_forge_msg.url).await.unwrap();
|
let forge = db.get_forge(&create_forge_msg.url).await.unwrap();
|
||||||
let forges = db.get_all_forges(true, 0, 10).await.unwrap();
|
let forges = db.get_all_forges(true, 0, 100).await.unwrap();
|
||||||
assert_eq!(forges.len(), 1);
|
assert!(forges
|
||||||
|
.iter()
|
||||||
|
.any(|f| f.url == create_forge_msg.url.to_string()));
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
forges.get(0).as_ref().unwrap().forge_type,
|
|
||||||
create_forge_msg.forge_type
|
|
||||||
);
|
|
||||||
assert_eq!(
|
|
||||||
forges.get(0).as_ref().unwrap().url,
|
|
||||||
crate::clean_url(&create_forge_msg.url)
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(forge.url, crate::clean_url(&create_forge_msg.url));
|
|
||||||
assert_eq!(forge.forge_type, create_forge_msg.forge_type);
|
assert_eq!(forge.forge_type, create_forge_msg.forge_type);
|
||||||
|
assert_eq!(forge.url, crate::clean_url(&create_forge_msg.url));
|
||||||
}
|
}
|
||||||
|
|
||||||
// add user
|
// add user
|
||||||
|
|
|
@ -40,7 +40,7 @@ async fn everything_works() {
|
||||||
let create_forge_msg = CreateForge {
|
let create_forge_msg = CreateForge {
|
||||||
url: url.clone(),
|
url: url.clone(),
|
||||||
forge_type: ForgeImplementation::Gitea,
|
forge_type: ForgeImplementation::Gitea,
|
||||||
import: false,
|
starchart_url: None,
|
||||||
};
|
};
|
||||||
|
|
||||||
let add_user_msg = AddUser {
|
let add_user_msg = AddUser {
|
||||||
|
|
|
@ -80,7 +80,7 @@ mod tests {
|
||||||
let create_forge_msg = CreateForge {
|
let create_forge_msg = CreateForge {
|
||||||
url: url.clone(),
|
url: url.clone(),
|
||||||
forge_type: ForgeImplementation::Gitea,
|
forge_type: ForgeImplementation::Gitea,
|
||||||
import: false,
|
starchart_url: None,
|
||||||
};
|
};
|
||||||
|
|
||||||
let _ = db.delete_forge_instance(&create_forge_msg.url).await;
|
let _ = db.delete_forge_instance(&create_forge_msg.url).await;
|
||||||
|
|
|
@ -48,7 +48,7 @@ impl Ctx {
|
||||||
let msg = CreateForge {
|
let msg = CreateForge {
|
||||||
url: url.clone(),
|
url: url.clone(),
|
||||||
forge_type: forge.forge_type(),
|
forge_type: forge.forge_type(),
|
||||||
import: false,
|
starchart_url: None,
|
||||||
};
|
};
|
||||||
|
|
||||||
db.create_forge_instance(&msg).await.unwrap();
|
db.create_forge_instance(&msg).await.unwrap();
|
||||||
|
@ -57,7 +57,7 @@ impl Ctx {
|
||||||
let msg = CreateForge {
|
let msg = CreateForge {
|
||||||
url: url.clone(),
|
url: url.clone(),
|
||||||
forge_type: forge.forge_type,
|
forge_type: forge.forge_type,
|
||||||
import: false,
|
starchart_url: None,
|
||||||
};
|
};
|
||||||
federate.create_forge_instance(&msg).await.unwrap();
|
federate.create_forge_instance(&msg).await.unwrap();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue