chorus/tests/channels.rs

217 lines
6.3 KiB
Rust
Raw Normal View History

2023-06-20 22:04:05 +02:00
use chorus::types::{
self, Channel, GetChannelMessagesSchema, MessageSendSchema, PermissionFlags,
2023-07-28 17:33:23 +02:00
PermissionOverwrite, PrivateChannelCreateSchema, RelationshipType, Snowflake,
2023-06-20 22:04:05 +02:00
};
2023-05-27 22:12:15 +02:00
mod common;
2023-05-27 22:12:15 +02:00
#[tokio::test]
async fn get_channel() {
let mut bundle = common::setup().await;
let bundle_channel = bundle.channel.clone();
2023-06-11 13:54:54 +02:00
let bundle_user = &mut bundle.user;
2023-05-27 22:12:15 +02:00
assert_eq!(
bundle_channel,
2023-06-22 13:14:07 +02:00
Channel::get(bundle_user, bundle_channel.id).await.unwrap()
2023-05-27 22:12:15 +02:00
);
common::teardown(bundle).await
}
2023-05-28 23:04:56 +02:00
#[tokio::test]
async fn delete_channel() {
let mut bundle = common::setup().await;
2023-06-22 13:14:07 +02:00
let result = Channel::delete(bundle.channel.clone(), &mut bundle.user).await;
2023-06-20 18:33:37 +02:00
assert!(result.is_ok());
2023-05-29 18:29:08 +02:00
common::teardown(bundle).await
2023-05-28 23:04:56 +02:00
}
2023-05-29 18:50:09 +02:00
#[tokio::test]
async fn modify_channel() {
2023-07-28 17:33:23 +02:00
const CHANNEL_NAME: &str = "beepboop";
2023-05-29 18:50:09 +02:00
let mut bundle = common::setup().await;
let channel = &mut bundle.channel;
2023-05-29 18:50:09 +02:00
let modify_data: types::ChannelModifySchema = types::ChannelModifySchema {
2023-07-28 17:33:23 +02:00
name: Some(CHANNEL_NAME.to_string()),
2023-05-29 18:50:09 +02:00
channel_type: None,
topic: None,
icon: None,
bitrate: None,
user_limit: None,
rate_limit_per_user: None,
position: None,
permission_overwrites: None,
parent_id: None,
nsfw: None,
rtc_region: None,
default_auto_archive_duration: None,
default_reaction_emoji: None,
flags: None,
default_thread_rate_limit_per_user: None,
video_quality_mode: None,
};
2023-07-28 17:33:23 +02:00
let modified_channel = Channel::modify(channel, modify_data, channel.id, &mut bundle.user)
2023-06-20 22:03:29 +02:00
.await
.unwrap();
2023-07-28 17:33:23 +02:00
assert_eq!(modified_channel.name, Some(CHANNEL_NAME.to_string()));
2023-06-10 22:26:15 +02:00
let permission_override = PermissionFlags::from_vec(Vec::from([
PermissionFlags::MANAGE_CHANNELS,
PermissionFlags::MANAGE_MESSAGES,
]));
let permission_override = PermissionOverwrite {
2023-06-20 22:03:29 +02:00
id: bundle.user.object.id,
2023-06-10 22:26:15 +02:00
overwrite_type: "1".to_string(),
allow: permission_override,
deny: "0".to_string(),
};
Channel::edit_permissions(
&mut bundle.user,
2023-06-20 22:03:29 +02:00
bundle.channel.id,
2023-06-10 22:26:15 +02:00
permission_override.clone(),
)
2023-06-20 18:33:37 +02:00
.await
.unwrap();
2023-06-10 22:26:15 +02:00
2023-06-20 22:03:29 +02:00
Channel::delete_permission(&mut bundle.user, bundle.channel.id, permission_override.id)
.await
.unwrap();
2023-06-10 22:26:15 +02:00
2023-05-29 18:50:09 +02:00
common::teardown(bundle).await
}
2023-06-20 22:04:05 +02:00
#[tokio::test]
async fn get_channel_messages() {
let mut bundle = common::setup().await;
// First create some messages to read
for _ in 0..10 {
let _ = bundle
.user
.send_message(
2023-07-28 17:33:23 +02:00
MessageSendSchema {
2023-06-20 22:04:05 +02:00
content: Some("A Message!".to_string()),
..Default::default()
},
bundle.channel.id,
)
.await
.unwrap();
}
assert_eq!(
Channel::messages(
GetChannelMessagesSchema::before(Snowflake::generate()),
bundle.channel.id,
&mut bundle.user,
)
.await
.unwrap()
.len(),
10
);
// around is currently bugged in spacebar: https://github.com/spacebarchat/server/issues/1072
// assert_eq!(
// Channel::messages(
// GetChannelMessagesSchema::around(Snowflake::generate()).limit(10),
// bundle.channel.id,
// &mut bundle.user,
// )
// .await
// .unwrap()
// .len(),
// 5
// );
assert!(Channel::messages(
GetChannelMessagesSchema::after(Snowflake::generate()),
bundle.channel.id,
&mut bundle.user,
)
.await
.unwrap()
.is_empty());
common::teardown(bundle).await
}
2023-07-28 17:33:23 +02:00
#[tokio::test]
async fn create_dm() {
let mut bundle = common::setup().await;
let other_user = bundle.create_user("integrationtestuser2").await;
let user = &mut bundle.user;
let private_channel_create_schema = PrivateChannelCreateSchema {
recipients: Some(Vec::from([other_user.object.id])),
access_tokens: None,
nicks: None,
};
let dm_channel = user
.create_private_channel(private_channel_create_schema)
.await
.unwrap();
assert!(dm_channel.recipients.is_some());
assert_eq!(
dm_channel.recipients.as_ref().unwrap().get(0).unwrap().id,
other_user.object.id
);
assert_eq!(
dm_channel.recipients.as_ref().unwrap().get(1).unwrap().id,
user.object.id
);
common::teardown(bundle).await;
}
// #[tokio::test]
// This test currently is broken due to an issue with the Spacebar Server.
#[allow(dead_code)]
async fn remove_add_person_from_to_dm() {
let mut bundle = common::setup().await;
let mut other_user = bundle.create_user("integrationtestuser2").await;
let mut third_user = bundle.create_user("integrationtestuser3").await;
let user = &mut bundle.user;
let private_channel_create_schema = PrivateChannelCreateSchema {
recipients: Some(Vec::from([other_user.object.id, third_user.object.id])),
access_tokens: None,
nicks: None,
};
let dm_channel = user
.create_private_channel(private_channel_create_schema)
.await
.unwrap(); // Creates the Channel and stores the response Channel object
dm_channel
.remove_channel_recipient(other_user.object.id, user)
.await
.unwrap();
assert!(dm_channel.recipients.as_ref().unwrap().get(1).is_none());
other_user
.modify_user_relationship(user.object.id, RelationshipType::Friends)
.await
.unwrap();
user.modify_user_relationship(other_user.object.id, RelationshipType::Friends)
.await
.unwrap();
third_user
.modify_user_relationship(user.object.id, RelationshipType::Friends)
.await
.unwrap();
user.modify_user_relationship(third_user.object.id, RelationshipType::Friends)
.await
.unwrap();
// Users 1-2 and 1-3 are now friends
dm_channel
.add_channel_recipient(other_user.object.id, user, None)
.await
.unwrap();
assert!(dm_channel.recipients.is_some());
assert_eq!(
dm_channel.recipients.as_ref().unwrap().get(0).unwrap().id,
other_user.object.id
);
assert_eq!(
dm_channel.recipients.as_ref().unwrap().get(1).unwrap().id,
user.object.id
);
}