Chào các bạn,
Trong tất cả chúng ta, ai cũng đã từng Google thử về cách viết Unit Tests, nhỉ? Nhưng tất cả các bài viết online, người ta chỉ show bạn những cái lý thuyết và những cái đơn giản nhất, như là:
- Viết 1 hàm a + b
- Viết test cho hàm đó và assert 1 + 1 = 2
- Viết nhiều hàm lên
- …
Với những thứ như thế, làm sao chúng ta có thể biết và hiểu rõ về Unit Test? Tôi cần tìm hiểu và viết Unit Test một cách nhanh gọn lẹ và rõ ràng nhất.
Và cách duy nhất đó là:
- Học qua 1 project có sẵn, có thể là project công ty (nhưng không phải công ty nào cũng viết)
- Học qua 1 project real life (bài viết này của mình)
Khái niệm test trong Laravel mà chúng ta sẽ viết
- Quick Test
- Test này dc extends từ TestCase của PHP, chúng ta mock hết mọi thứ và test thôi
- Ta sẽ viết test cho từng hàm của class và cover tất cả các cases
- Unit Test
- Test này dc extends từ TestCase của Laravel, ta có thể interact với Database và các services của Laravel
- Ta sẽ viết test cho từng hàm của class và cover tất cả các cases
- Feature Test
- Giống Unit, ta viết Feature test để kiểm tra cái endpoint (nếu là API) / view (nếu là SSR) của bạn có hoạt động đúng không
- Ta sẽ kiểm tra tất cả trường hợp, từ authorization check, validation check cho tới controllers, services,…
- Integration Test
- Giống Feature, ta viết test hoàn chỉnh cho 1 flow (ví dụ đăng ký, đăng nhập, kết bạn,…), gọi nhiều endpoints cùng 1 lúc.
Trình tự học hỏi
- Kiểm tra routes
- Đi đến các Controllers
- Xem các FormRequest để biết auth + validation rules
- Xem các Services dc sử dụng trong Controllers
- Và cuối cùng, đọc tests, bạn sẽ biết mình phải tests những gì
Các Repositories (IRL Projects) của tôi mà bạn có thể tham khảo
- Kiva: https://github.com/sethsandaru/kiva-laravel-tdd – một API project với các endpoints để tạo notes
- EloquentDocs: https://github.com/sethsandaru/eloquent-docs – helper command để tạo ra phpDoc cho Eloquent Models của bạn (thân thiện với IDE, như PHPStorm)
- SaaS Ready: https://github.com/shipsaas/ready – Ready đóng gói 1 tá entities cơ bản để giúp bạn bootstrapping project startup của bạn nhanh nhất có thể.
Những projects trên đều có độ bao phủ (coverage) > 80%, tests khá nhiều ạ.
(Ngoài ra các bạn cũng có thể học thêm về CI và các setup nó = Github Actions, kiểm tra thư mục .github)
(đang có thêm vài dự án, sẽ share thêm sau)
Cám ơn các bạn và chúc các bạn học vui vẻ!
Nguồn: viblo.asia