summaryrefslogtreecommitdiffstats
path: root/src/server/routes/users/get_user.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/routes/users/get_user.rs')
-rw-r--r--src/server/routes/users/get_user.rs32
1 files changed, 26 insertions, 6 deletions
diff --git a/src/server/routes/users/get_user.rs b/src/server/routes/users/get_user.rs
index 8020923..d86cc26 100644
--- a/src/server/routes/users/get_user.rs
+++ b/src/server/routes/users/get_user.rs
@@ -10,12 +10,7 @@ pub async fn http_get_user(
Path(name): Path<String>,
data: Data<AppHandle>,
) -> Result<impl IntoResponse, AppError> {
- let read = data.users.read().await;
- if let Some(a) = read
- .iter()
- .find(|value| value.username.eq(&name))
- .map(ToOwned::to_owned)
- {
+ if let Some(a) = read_user(&name, &data).await {
let json_user = a.into_json(&data).await?;
Ok((
StatusCode::OK,
@@ -27,6 +22,13 @@ pub async fn http_get_user(
}
}
+pub async fn read_user(name: &str, data: &Data<AppHandle>) -> Option<crate::entity::user::User> {
+ let read = data.users.read().await;
+ read.iter()
+ .find(|value| value.username.eq(&name))
+ .map(ToOwned::to_owned)
+}
+
#[cfg(test)]
mod tests {
use axum::{
@@ -54,4 +56,22 @@ mod tests {
assert_eq!(response.status(), StatusCode::OK);
}
+
+ #[tokio::test]
+ async fn get_user_not_found() {
+ let state = AppState::new().await.unwrap();
+ let app = server::router(state);
+
+ let response = app
+ .oneshot(
+ Request::builder()
+ .uri("/users/selut")
+ .body(Body::empty())
+ .unwrap(),
+ )
+ .await
+ .unwrap();
+
+ assert_eq!(response.status(), StatusCode::NOT_FOUND);
+ }
}