1 use diesel::{result::Error, *};
2 use lemmy_db_schema::schema::community_aggregates;
5 #[derive(Queryable, Associations, Identifiable, PartialEq, Debug, Serialize, Clone)]
6 #[table_name = "community_aggregates"]
7 pub struct CommunityAggregates {
13 pub published: chrono::NaiveDateTime,
14 pub users_active_day: i64,
15 pub users_active_week: i64,
16 pub users_active_month: i64,
17 pub users_active_half_year: i64,
20 impl CommunityAggregates {
21 pub fn read(conn: &PgConnection, community_id: i32) -> Result<Self, Error> {
22 community_aggregates::table
23 .filter(community_aggregates::community_id.eq(community_id))
31 aggregates::community_aggregates::CommunityAggregates,
32 establish_unpooled_connection,
38 use lemmy_db_schema::source::{
39 comment::{Comment, CommentForm},
40 community::{Community, CommunityFollower, CommunityFollowerForm, CommunityForm},
41 post::{Post, PostForm},
42 user::{UserForm, User_},
44 use serial_test::serial;
49 let conn = establish_unpooled_connection();
51 let new_user = UserForm {
52 name: "thommy_community_agg".into(),
53 preferred_username: None,
54 password_encrypted: "nope".into(),
64 theme: "browser".into(),
65 default_sort_type: SortType::Hot as i16,
66 default_listing_type: ListingType::Subscribed as i16,
67 lang: "browser".into(),
69 send_notifications_to_email: false,
75 last_refreshed_at: None,
77 shared_inbox_url: None,
80 let inserted_user = User_::create(&conn, &new_user).unwrap();
82 let another_user = UserForm {
83 name: "jerry_community_agg".into(),
84 preferred_username: None,
85 password_encrypted: "nope".into(),
95 theme: "browser".into(),
96 default_sort_type: SortType::Hot as i16,
97 default_listing_type: ListingType::Subscribed as i16,
98 lang: "browser".into(),
100 send_notifications_to_email: false,
106 last_refreshed_at: None,
108 shared_inbox_url: None,
111 let another_inserted_user = User_::create(&conn, &another_user).unwrap();
113 let new_community = CommunityForm {
114 name: "TIL_community_agg".into(),
115 creator_id: inserted_user.id,
116 title: "nada".to_owned(),
126 last_refreshed_at: None,
132 shared_inbox_url: None,
135 let inserted_community = Community::create(&conn, &new_community).unwrap();
137 let another_community = CommunityForm {
138 name: "TIL_community_agg_2".into(),
139 creator_id: inserted_user.id,
140 title: "nada".to_owned(),
150 last_refreshed_at: None,
156 shared_inbox_url: None,
159 let another_inserted_community = Community::create(&conn, &another_community).unwrap();
161 let first_user_follow = CommunityFollowerForm {
162 community_id: inserted_community.id,
163 user_id: inserted_user.id,
167 CommunityFollower::follow(&conn, &first_user_follow).unwrap();
169 let second_user_follow = CommunityFollowerForm {
170 community_id: inserted_community.id,
171 user_id: another_inserted_user.id,
175 CommunityFollower::follow(&conn, &second_user_follow).unwrap();
177 let another_community_follow = CommunityFollowerForm {
178 community_id: another_inserted_community.id,
179 user_id: inserted_user.id,
183 CommunityFollower::follow(&conn, &another_community_follow).unwrap();
185 let new_post = PostForm {
186 name: "A test post".into(),
189 creator_id: inserted_user.id,
190 community_id: inserted_community.id,
198 embed_description: None,
206 let inserted_post = Post::create(&conn, &new_post).unwrap();
208 let comment_form = CommentForm {
209 content: "A test comment".into(),
210 creator_id: inserted_user.id,
211 post_id: inserted_post.id,
222 let inserted_comment = Comment::create(&conn, &comment_form).unwrap();
224 let child_comment_form = CommentForm {
225 content: "A test comment".into(),
226 creator_id: inserted_user.id,
227 post_id: inserted_post.id,
231 parent_id: Some(inserted_comment.id),
238 let _inserted_child_comment = Comment::create(&conn, &child_comment_form).unwrap();
240 let community_aggregates_before_delete =
241 CommunityAggregates::read(&conn, inserted_community.id).unwrap();
243 assert_eq!(2, community_aggregates_before_delete.subscribers);
244 assert_eq!(1, community_aggregates_before_delete.posts);
245 assert_eq!(2, community_aggregates_before_delete.comments);
247 // Test the other community
248 let another_community_aggs =
249 CommunityAggregates::read(&conn, another_inserted_community.id).unwrap();
250 assert_eq!(1, another_community_aggs.subscribers);
251 assert_eq!(0, another_community_aggs.posts);
252 assert_eq!(0, another_community_aggs.comments);
255 CommunityFollower::unfollow(&conn, &second_user_follow).unwrap();
256 let after_unfollow = CommunityAggregates::read(&conn, inserted_community.id).unwrap();
257 assert_eq!(1, after_unfollow.subscribers);
259 // Follow again just for the later tests
260 CommunityFollower::follow(&conn, &second_user_follow).unwrap();
261 let after_follow_again = CommunityAggregates::read(&conn, inserted_community.id).unwrap();
262 assert_eq!(2, after_follow_again.subscribers);
264 // Remove a parent comment (the comment count should also be 0)
265 Post::delete(&conn, inserted_post.id).unwrap();
266 let after_parent_post_delete = CommunityAggregates::read(&conn, inserted_community.id).unwrap();
267 assert_eq!(0, after_parent_post_delete.comments);
268 assert_eq!(0, after_parent_post_delete.posts);
270 // Remove the 2nd user
271 User_::delete(&conn, another_inserted_user.id).unwrap();
272 let after_user_delete = CommunityAggregates::read(&conn, inserted_community.id).unwrap();
273 assert_eq!(1, after_user_delete.subscribers);
275 // This should delete all the associated rows, and fire triggers
276 let user_num_deleted = User_::delete(&conn, inserted_user.id).unwrap();
277 assert_eq!(1, user_num_deleted);
279 // Should be none found, since the creator was deleted
280 let after_delete = CommunityAggregates::read(&conn, inserted_community.id);
281 assert!(after_delete.is_err());