- Компиляция кода и проверка на ошибки сборки
- Запуск линтера
- Запуск автоматизированных тестов для проверки работоспособности кода
- Анализ покрытия кода тестами
- Может выполнять команды из Makefile (make build, lint, test)
Для начала настройте Gitea. Убедитесь, что Gitea позволяет взаимодействовать с ботом.
Для этого в конфиге должна быть прописана директива ALLOWED_HOST_LIST
с хостом, на котором развернут gopher-bot:
cat << EOF >> /etc/gitea/app.ini
[webhook]
ALLOWED_HOST_LIST = *
EOF
- Для всех репозиториев, где вы хотите использовать gopher-bot, откройте настройки webhook репозитория и создайте новый
Gitea
webhook (Trigger On и фильтр Branch filter зависят от ваших предпочтений):- Target URL: URL, на котором развернут gopher-bot, вместе
/hook
сегментом (http://gopher-bot:8080/hook
) - HTTP Method:
POST
- POST Content Type:
application/json
- Secret: секрет, указанный в вашей конфигурации
- Trigger On: пользовательские события (Custom Events)…
- Pull Request Events
- Pull Request
- Pull Request Synchronized
- Pull Request Events
- Branch filter:
*
- Active: ✅
- Target URL: URL, на котором развернут gopher-bot, вместе
- Добавьте пользователя gopher-bot c токеном c правами на repo.
- Добавьте пользователя gopher-bot в репозиторий.
- Установите gopher-bot.
Установку gopher-bot можно выполнить двумя способами: Docker или бинарник.
На машине выполните команды, указав gitea_host, токен пользователя gopher-bot и secret:
docker volume create gopher-bot_config
docker volume create gopher-bot_var
docker run -it --rm -v gopher-bot_config:/etc/gopher-bot busybox sh -c 'cat << EOF >> /etc/gopher-bot/config.ini
[tokens]
"[gitea_host]"=gopher-bot:[token]
[server]
DEBUG_MODE=true
SECRET=[SECRET]'
docker run --restart always -p 8080:8080 -v gopher-bot_config:/etc/gopher-bot -v gopher-bot_var:/var/gopher-bot --name gopher-bot nfort/gopher-bot:1.0.0
Соберите или загрузите бинарник из релиза:
CGO_ENABLED=0 GOOS=linux go build -o gopher-bot cmd/main.go
Добавьте конфиг-файл:
cat << EOF >> /etc/gopher-bot/config.ini
[tokens]
"http://[gitea_host]:[gitea_port]"=gopher-bot:[token]
[server]
DEBUG_MODE=true
SECRET=[secret]
Добавьте бинарник на сервер и запустите его. Если вы используете golangci-lint или другие инструменты в качестве зависимостей проекта, их также следует установить на сервер.
После запуска docker compose up
, нужно остановить контейнер.
- Выполните команду:
docker run -it --rm -v gitea_gitea-config:/etc/gitea busybox sh -c 'cat << EOF >> /etc/gitea/app.ini
[webhook]
ALLOWED_HOST_LIST = *
EOF'
- При настройке Gitea указажите
gitea:3000
вместоlocalhost:3000
в качестве хоста. Добавьте пользователяgopher-bot
и добавьте токен с правами на repo. Скопируйте токен.
docker volume create gopher-bot_config
docker volume create gopher-bot_var
docker run -it --rm -v gopher-bot_config:/etc/gopher-bot busybox sh -c 'cat << EOF >> /etc/gopher-bot/config.ini
[tokens]
"http://gitea:3000"=gopher-bot:[token]
[server]
DEBUG_MODE=true
SECRET=iNeydroTioUC'
docker run --restart always -p 8080:8080 -v gopher-bot_config:/etc/gopher-bot -v gopher-bot_var:/var/gopher-bot --name gopher-bot nfort/gopher-bot:1.0.0
- Добавьте webhook для репозитория.
- Укажите SECRET.
- В качестве хоста укажите
gopher-bot:8080/hooks
. - Предоставьте права на PR, PR Synchronize.
- Добавьте пользователя gopher-bot в репозиторий.
cat << EOF >> /etc/systemd/system/gopher-bot.service
[Unit]
Description=gopher-bot
[Service]
Environment="HOME=/root"
Environment="GOPATH=/root/.go"
Environment="GOCACHE=/root/.go-cache"
ExecStart=/opt/gopher-bot/gopher-bot
Restart=always
StandardOutput=append:/var/log/gopher-bot.log
StandardError=append:/var/log/gopher-bot.log
[Install]
WantedBy=multi-user.target
EOF
Выполните перезагрузку systemd:
systemctl daemon-reload
Добавьте сервис в systemd:
systemctl enable gopher-bot