Questions Management – Core Category Service – Xây dựng API cập nhập category

Xem toàn bộ series bài viết hướng dẫn xây dựng ứng dụng Questions Management tại đây.

Như mình đã đề cập, trong bài viết trước, chúng ta đã chuẩn bị tất cả các thông tin, cấu hình cần thiết để có thể xây dựng API cập nhập category như: một đối tượng document Category chứa thông tin của một category, một CategoryRepository để thao tác với MongoDB, một CategoryController định nghĩa các API của Core Category Service sẽ bắt đầu với “/category” và thông tin về kết nối đến MongoDB server được cấu hình trong tập tin application.properties. Bây giờ, chúng ta sẽ tiến hành xây dựng API để cập nhập một category các bạn nhé!

Để xây dựng API cập nhập category, mình sẽ thêm mới một method để expose một PUT request “{id}” với id là id của category mà chúng ta cần cập nhập. Chúng ta cũng cần định nghĩa thêm phần body data là nội dung mới của category mà chúng ta sẽ cập nhập như sau:

Các bước để cập nhập một category bao gồm:

Đầu tiên, chúng ta cũng cần phải kiểm tra là category mà chúng ta cần cập nhập có tồn tại hay không dựa vào id mà người dùng truyền vào.

Spring Data MongoDB Reactive đã hỗ trợ cho chúng ta phương thức để tìm kiếm theo id nên chúng ta chỉ cần gọi để sử dụng mà thôi.

Trong trường hợp category này tồn tại, chúng ta sẽ sử dụng các thông tin được truyền trong phần body data để cập nhập thông tin trong database:

Sau đó thì trả về cho người dùng thông tin mới của category này sau khi đã cập nhập vào database với HTTP status code là 200 OK.

Trong trường hợp category này không tồn tại trong database thì chúng ta sẽ trả về kết quả HTTP status code là 404 Not Found.

Toàn bộ nội dung của phương thức updateCategory() lúc này sẽ như sau:

Đến đây thì chúng ta đã hoàn thành việc xây dựng API để cập nhập một category cho Core Category Service, hãy test thử xem sao nhé các bạn.

Giả sử hiện tại trong database mình đang có những category sau:

Questions Management – Core Category Service – Xây dựng API cập nhập category

thì khi mình request để cập nhập category với id là 5b297751366e2605cf3c0d3e:

Questions Management – Core Category Service – Xây dựng API cập nhập category

Kết quả sẽ là:

Questions Management – Core Category Service – Xây dựng API cập nhập category



Bây giờ chúng ta sẽ thêm mới Unit Test cho code mà chúng ta vừa thêm vào, các bạn nhé!

Trong bài viết trước, mình đã tạo mới class test cho CategoryController tên là CategoryControllerTest, đối tượng Mock cho CategoryRepository và inject đối tượng Mock này vào class CategoryController:

Khởi tạo mock mỗi khi chạy một test case:

Giờ mình sẽ thêm mới hai phương thức để test cho phương thức của updateCategory() của class CategoryController như sau:

Một phương thức để test cho trường hợp có category dựa vào id truyền vào:

Một phương thức để test cho trường hợp không có category dựa vào id truyền vào:

Chạy “Maven test” trong STS hoặc “mvn test” với Apache Maven, các bạn sẽ không lỗi nào cả.

3 thoughts on “Questions Management – Core Category Service – Xây dựng API cập nhập category

  1. anh ơi sửa lại phần này ạ:
    thì khi mình request để xoá category với id là 5b297751366e2605cf3c0d3e:
    hình như phần này là phần update ạ

    1. Ôi, em giúp anh review lại hết tất cả nhé! Nhiều quá đôi lúc anh viết sai. Thank em đã nhắc anh. Anh đang tính sau khi hoàn thiện Giai đoạn 1 sẽ review lại và nhờ một số bạn review giúp. Hi vọng lúc đó em sẽ giúp anh nhé!

Add Comment