- docker-compose up
- Enjoy ;)
- In ./krakend/config/krakend.json change backend.host to
http://docker.for.mac.localhost:portServices
if you use mac. - Start services as
go run ./cmd/auth/main.go -l "Debug" -a "127.0.0.1:8081"
- run
make build
in root directory
- go to root folder project
- exec
~/go/bin/swag init -g "cmd/auth/main.go" -o "docs/auth/"
- swagger on page
/swagger/index.html
- go to /db/{service_name}.
- In
docker-compose.migrations.yml
change servicemigration_db_add
. - Go to /Makefiles/{service_name} and call
make migration_new
.
Все контейнеры скрыты от пользователя в докеркомпоузе. Этим самым соблюдён один из принципов REST Многоуровневость, в коммуникации участвуют двое: клиент и сервер. Каждый компонент должен видеть только свой уровень. Клиент общается только с auth (регистрация и аутентификация) и gophermart (логика приложения доступные для клиента). Для доступа к ручкам gophermart клиенту необходимо пройти аутентификацию.
Сервис accrual является внутренним для системы. Ручки сервиса accrual не проверяют аутентификацию клиента и поэтому не доступны для пользователя. При обращении к ним пользователя они должны быть недоступны и такой результат интеграционных тестов считается ожидаемым.
Для тестирования сервиса accrual его можно поднять отдельно. Например, так.
go run cmd/accrual/main.go -a "localhost:8081" -d "postgres://postgres:postgres@localhost:5432/accrual?sslmode=disable"
Для проверки результатов работы сервиса есть своеобразный backdoor. Наружу прокинут порт 5432 и в контейнере поднят pgAdmin можно посмотреть данные в базе.
В репозитории есть коллекция которую рекомендуем использовать для интеграционного тестирования. Она очень близка к техническому заданию. В ней реализовано 78 тестов для всех предусмотренный вариантов действий клиента по всем 7 доступным ему ручкам. Это 100% покрытие реализованных ручек со всеми вариантами ответов предусмотренными нашим сервисом. Кроме этого код на 70% покрыт unit тестами на хендлеры.
В pipeline дополнительно добавлены проверки линтером (golangci-lint.yml), запуск unit тестов (gounittest.yml), проверка на покрытие unit тестами (go-test-coverage.yml)