You've already forked AstralRinth
forked from didirus/AstralRinth
* Add redis caching to getting a user's project ids * Run `cargo sqlx prepare` to update the sqlx-data.json * Add redis caching for getting user notifications * Fix new clippy warnings * Remove log that shouldn't have been committed * Batch insert of notifications (untested) * sqlx prepare... * Fix merge conflict things and use new redis struct * Fix bug with calling delete_many without any elements (caught by tests) * cargo sqlx prepare * Add tests around cache invalidation (and fix bug they caught!) * Some test reorg based on code review suggestions
71 lines
2.3 KiB
Rust
71 lines
2.3 KiB
Rust
use common::{
|
|
database::{FRIEND_USER_ID, FRIEND_USER_PAT, USER_USER_PAT},
|
|
environment::with_test_environment,
|
|
};
|
|
|
|
mod common;
|
|
|
|
#[actix_rt::test]
|
|
pub async fn get_user_notifications_after_team_invitation_returns_notification() {
|
|
with_test_environment(|test_env| async move {
|
|
let alpha_team_id = test_env.dummy.as_ref().unwrap().alpha_team_id.clone();
|
|
let api = test_env.v2;
|
|
api.get_user_notifications_deserialized(FRIEND_USER_ID, FRIEND_USER_PAT)
|
|
.await;
|
|
|
|
api.add_user_to_team(&alpha_team_id, FRIEND_USER_ID, USER_USER_PAT)
|
|
.await;
|
|
|
|
let notifications = api
|
|
.get_user_notifications_deserialized(FRIEND_USER_ID, FRIEND_USER_PAT)
|
|
.await;
|
|
assert_eq!(1, notifications.len());
|
|
})
|
|
.await;
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
pub async fn get_user_notifications_after_reading_indicates_notification_read() {
|
|
with_test_environment(|test_env| async move {
|
|
test_env.generate_friend_user_notification().await;
|
|
let api = test_env.v2;
|
|
let notifications = api
|
|
.get_user_notifications_deserialized(FRIEND_USER_ID, FRIEND_USER_PAT)
|
|
.await;
|
|
assert_eq!(1, notifications.len());
|
|
let notification_id = notifications[0].id.to_string();
|
|
|
|
api.mark_notification_read(¬ification_id, FRIEND_USER_PAT)
|
|
.await;
|
|
|
|
let notifications = api
|
|
.get_user_notifications_deserialized(FRIEND_USER_ID, FRIEND_USER_PAT)
|
|
.await;
|
|
assert_eq!(1, notifications.len());
|
|
assert!(notifications[0].read);
|
|
})
|
|
.await;
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
pub async fn get_user_notifications_after_deleting_does_not_show_notification() {
|
|
with_test_environment(|test_env| async move {
|
|
test_env.generate_friend_user_notification().await;
|
|
let api = test_env.v2;
|
|
let notifications = api
|
|
.get_user_notifications_deserialized(FRIEND_USER_ID, FRIEND_USER_PAT)
|
|
.await;
|
|
assert_eq!(1, notifications.len());
|
|
let notification_id = notifications[0].id.to_string();
|
|
|
|
api.delete_notification(¬ification_id, FRIEND_USER_PAT)
|
|
.await;
|
|
|
|
let notifications = api
|
|
.get_user_notifications_deserialized(FRIEND_USER_ID, FRIEND_USER_PAT)
|
|
.await;
|
|
assert_eq!(0, notifications.len());
|
|
})
|
|
.await;
|
|
}
|