.. | ||
app | ||
client | ||
models | ||
utils | ||
main.go | ||
README.md |
coverme
В этой задаче нужно покрыть простой todo-app http сервис unit тестами.
Необходимо покрыть все sub-package'и. Package main можно не тестировать.
Существующие файлы менять не нужно. Нужно создавать новые файлы с тестами.
Тестирующая система будет проверять code coverage. Порог задан в coverage_test.go
Важно понимать, что coverage 100% - не решение всех проблем. В коде по-прежнему могут быть ошибки. Coverage 100% говорит ровно о том, что все строки кода выполнялись. Хорошие тесты в первую очередь тестируют функциональность.
Как посмотреть coverage:
go test -v -cover ./coverme/...
Coverage можно выводить в html (см. ссылки), и эта функциональность поддерживается в Goland.
Ссылки
- cover: https://blog.golang.org/cover
- gomock для создания мока базы данных при тестировании серевера
- httptest.ResponseRecorder для тестирования handler'ов сервера
- httptest.Server для тестирования клинета
- Если вы ждёте, когда же выложат лекцию: https://www.youtube.com/watch?v=ndmB0bj7eyw
O сервисе
Todo-app с минимальной функциональностью + client.
Запуск:
✗ go run ./coverme/main.go -port 6029
Health check:
✗ curl -i -X GET localhost:6029/
HTTP/1.1 200 OK
Content-Type: application/json
Date: Thu, 19 Mar 2020 21:46:02 GMT
Content-Length: 24
"API is up and working!"
Создать новое todo:
✗ curl -i localhost:6029/todo/create -d '{"title":"A","content":"a"}'
HTTP/1.1 201 Created
Content-Type: application/json
Date: Thu, 19 Mar 2020 21:41:31 GMT
Content-Length: 51
{"id":0,"title":"A","content":"a","finished":false}
Получить todo по id:
✗ curl -i localhost:6029/todo/0
HTTP/1.1 200 OK
Content-Type: application/json
Date: Thu, 19 Mar 2020 21:44:17 GMT
Content-Length: 51
{"id":0,"title":"A","content":"a","finished":false}
Получить все todo:
✗ curl -i -X GET localhost:6029/todo
HTTP/1.1 200 OK
Content-Type: application/json
Date: Thu, 19 Mar 2020 21:44:37 GMT
Content-Length: 53
[{"id":0,"title":"A","content":"a","finished":false}]