В данном проекте показан пример создания REST API на Go с использованием Echo framework.
github.com/labstack/echo
- для создания rest сервиса; использованы: router, data binding и data rendering, logger middleware
gopkg.in/go-playground/validator.v9
- для data validation
database/sql
- для работы с запросами и транзакционностьюgithub.com/lib/pq
- в качестве СУБД использовалась postgresqlgitproxy.zycloud.tk/rubenv/sql-migrate
- миграционная тулза для sqldocker postgres image
- для запуска postgresql
flag
- для передачи параметров при запускеgithub.com/jinzhu/configor
- для загрузки конфигурации из yaml
github.com/sirupsen/logrus
- для логов приложения
testing
- для написания тестовgithub.com/golang/mock/gomock
- для генерации моковgithub.com/stretchr/testify/assert
- исключительно для assert в тестах
github.com/golang/dep
- менеджер зависимостей
make init
- установит необходимые тулзы (dep, sql-migrate, mockgen), затем черезdep
установит зависимости проектаmake run
- запустит приложение, при этом запустив docker контейнер с БДmake test
- запустит приложение, при этом запустив docker контейнер с БДmake spec
- сгенерирует open-api спецификацию в spec/api.json. После запуска сервис отдает спеку как статику по пути /spec/api.json, можно также выполнитьswagger serve -F=swagger http://localhost:8081/spec/api.json
, что бы отобразить в html виде c запущенного сервиса.spec-ui
- откроет спеку в html