Create the remaining task api methods on the server. #3

Merged
drew merged 6 commits from remaining-method into main 2025-09-20 19:23:20 +00:00
2 changed files with 17 additions and 7 deletions
Showing only changes of commit 8936222367 - Show all commits

View file

@ -15,10 +15,12 @@ use crate::models::{TaskModel, TaskStatus};
use super::AppError;
pub fn create_task_router() -> Router<Pool<Sqlite>> {
Router::new().route("/", post(create_task)).route(
"/{task_id}",
get(get_task).put(update_task).delete(delete_task),
)
Router::new()
.route("/", post(create_task).get(list_tasks))
.route(
"/{task_id}",
get(get_task).put(update_task).delete(delete_task),
)
}
#[derive(Deserialize)]
@ -38,6 +40,14 @@ pub async fn create_task(
Ok((StatusCode::CREATED, Json(model)))
}
pub async fn list_tasks(
State(pool): State<Pool<Sqlite>>,
) -> Result<(StatusCode, Json<Vec<TaskModel>>), AppError> {
let tasks = TaskModel::list_all(&pool).await?;
Ok((StatusCode::OK, Json(tasks)))
}
pub async fn get_task(
State(pool): State<Pool<Sqlite>>,
WithRejection(Path(task_id), _): WithRejection<Path<Uuid>, AppError>,

View file

@ -5,7 +5,7 @@ GET {{host}}/api/tasks
HTTP 200
[Captures]
initial_count: jsonpath "$ length"
initial_count: jsonpath "$" count
[Asserts]
jsonpath "$" isCollection
@ -51,7 +51,7 @@ GET {{host}}/api/tasks
HTTP 200
[Asserts]
jsonpath "$" isCollection
jsonpath "$ length" >= {{initial_count}}
jsonpath "$" count >= {{initial_count}}
jsonpath "$[*].id" includes "{{alpha_task_id}}"
jsonpath "$[*].id" includes "{{beta_task_id}}"
jsonpath "$[*].id" includes "{{gamma_task_id}}"