|
|
|
@ -128,7 +128,14 @@ pub(crate) mod tests {
|
|
|
|
|
use crate::protocol::objects::{group::Group, tombstone::Tombstone};
|
|
|
|
|
use actix_web::body::to_bytes;
|
|
|
|
|
use lemmy_db_schema::{
|
|
|
|
|
source::{community::CommunityInsertForm, instance::Instance},
|
|
|
|
|
newtypes::InstanceId,
|
|
|
|
|
source::{
|
|
|
|
|
community::CommunityInsertForm,
|
|
|
|
|
instance::Instance,
|
|
|
|
|
local_site::{LocalSite, LocalSiteInsertForm},
|
|
|
|
|
local_site_rate_limit::{LocalSiteRateLimit, LocalSiteRateLimitInsertForm},
|
|
|
|
|
site::{Site, SiteInsertForm},
|
|
|
|
|
},
|
|
|
|
|
traits::Crud,
|
|
|
|
|
CommunityVisibility,
|
|
|
|
|
};
|
|
|
|
@ -142,6 +149,8 @@ pub(crate) mod tests {
|
|
|
|
|
) -> LemmyResult<(Instance, Community)> {
|
|
|
|
|
let instance =
|
|
|
|
|
Instance::read_or_create(&mut context.pool(), "my_domain.tld".to_string()).await?;
|
|
|
|
|
create_local_site(context, instance.id).await?;
|
|
|
|
|
|
|
|
|
|
let community_form = CommunityInsertForm::builder()
|
|
|
|
|
.name("testcom6".to_string())
|
|
|
|
|
.title("nada".to_owned())
|
|
|
|
@ -154,6 +163,28 @@ pub(crate) mod tests {
|
|
|
|
|
Ok((instance, community))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Necessary for the community outbox fetching
|
|
|
|
|
async fn create_local_site(
|
|
|
|
|
context: &Data<LemmyContext>,
|
|
|
|
|
instance_id: InstanceId,
|
|
|
|
|
) -> LemmyResult<()> {
|
|
|
|
|
// Create a local site, since this is necessary for community fetching.
|
|
|
|
|
let site_form = SiteInsertForm::builder()
|
|
|
|
|
.name("test site".to_string())
|
|
|
|
|
.instance_id(instance_id)
|
|
|
|
|
.build();
|
|
|
|
|
let site = Site::create(&mut context.pool(), &site_form).await?;
|
|
|
|
|
|
|
|
|
|
let local_site_form = LocalSiteInsertForm::builder().site_id(site.id).build();
|
|
|
|
|
let local_site = LocalSite::create(&mut context.pool(), &local_site_form).await?;
|
|
|
|
|
let local_site_rate_limit_form = LocalSiteRateLimitInsertForm::builder()
|
|
|
|
|
.local_site_id(local_site.id)
|
|
|
|
|
.build();
|
|
|
|
|
|
|
|
|
|
LocalSiteRateLimit::create(&mut context.pool(), &local_site_rate_limit_form).await?;
|
|
|
|
|
Ok(())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async fn decode_response<T: DeserializeOwned>(res: HttpResponse) -> LemmyResult<T> {
|
|
|
|
|
let body = to_bytes(res.into_body()).await.unwrap();
|
|
|
|
|
let body = std::str::from_utf8(&body)?;
|
|
|
|
@ -164,6 +195,7 @@ pub(crate) mod tests {
|
|
|
|
|
#[serial]
|
|
|
|
|
async fn test_get_community() -> LemmyResult<()> {
|
|
|
|
|
let context = LemmyContext::init_test_context().await;
|
|
|
|
|
let (instance, community) = init(false, CommunityVisibility::Public, &context).await?;
|
|
|
|
|
|
|
|
|
|
// fetch invalid community
|
|
|
|
|
let query = CommunityQuery {
|
|
|
|
@ -172,8 +204,6 @@ pub(crate) mod tests {
|
|
|
|
|
let res = get_apub_community_http(query.into(), context.reset_request_count()).await;
|
|
|
|
|
assert!(res.is_err());
|
|
|
|
|
|
|
|
|
|
let (instance, community) = init(false, CommunityVisibility::Public, &context).await?;
|
|
|
|
|
|
|
|
|
|
// fetch valid community
|
|
|
|
|
let query = CommunityQuery {
|
|
|
|
|
community_name: community.name.clone(),
|
|
|
|
|