feat: enhance error handling and user follow functionality, update tests for user context

This commit is contained in:
2025-09-05 21:44:46 +02:00
parent decf81e535
commit 0e6c072387
13 changed files with 172 additions and 81 deletions

View File

@@ -9,25 +9,40 @@ async fn test_follow_endpoints() {
create_test_user(&app.db, "user2").await;
// 1. user1 follows user2
let response =
make_post_request(app.router.clone(), "/users/user2/follow", "".to_string()).await;
let response = make_post_request(
app.router.clone(),
"/users/user2/follow",
"".to_string(),
None,
)
.await;
assert_eq!(response.status(), StatusCode::NO_CONTENT);
// 2. user1 tries to follow user2 again (should fail)
let response =
make_post_request(app.router.clone(), "/users/user2/follow", "".to_string()).await;
assert_eq!(response.status(), StatusCode::CONFLICT);
let response = make_post_request(
app.router.clone(),
"/users/user2/follow",
"".to_string(),
None,
)
.await;
assert_eq!(response.status(), StatusCode::BAD_REQUEST);
// 3. user1 tries to follow a non-existent user
let response =
make_post_request(app.router.clone(), "/users/nobody/follow", "".to_string()).await;
let response = make_post_request(
app.router.clone(),
"/users/nobody/follow",
"".to_string(),
None,
)
.await;
assert_eq!(response.status(), StatusCode::NOT_FOUND);
// 4. user1 unfollows user2
let response = make_delete_request(app.router.clone(), "/users/user2/follow").await;
let response = make_delete_request(app.router.clone(), "/users/user2/follow", None).await;
assert_eq!(response.status(), StatusCode::NO_CONTENT);
// 5. user1 tries to unfollow user2 again (should fail)
let response = make_delete_request(app.router.clone(), "/users/user2/follow").await;
let response = make_delete_request(app.router.clone(), "/users/user2/follow", None).await;
assert_eq!(response.status(), StatusCode::NOT_FOUND);
}