chore(infrastructure): bootstrap CI
All checks were successful
main / main (push) Successful in 4m13s
main / deploy (push) Has been skipped
main / publish (push) Has been skipped

This commit is contained in:
Julien Dessaux 2025-04-12 14:15:42 +02:00
parent 5e033b5f14
commit a22b2953e4
Signed by: adyxax
GPG key ID: F92E51B86E07177E
2 changed files with 137 additions and 0 deletions

View file

@ -0,0 +1,66 @@
---
name: 'main'
on:
push:
workflow_dispatch:
jobs:
main:
runs-on: 'self-hosted'
steps:
- uses: 'actions/checkout@v4'
- uses: 'actions/setup-go@v5'
with:
go-version-file: 'go.mod'
- name: 'fmt'
run: |
make tidy no-dirty
- name: 'check'
run: |
make check no-dirty
- name: 'build'
run: |
make build
env:
GIT_CRYPT_SECRET: '${{ secrets.GIT_CRYPT }}'
#- uses: 'actions/upload-artifact@v4'
- uses: 'forgejo/upload-artifact@v4'
if: "${{ startsWith(github.ref, 'refs/tags/') }}"
with:
if-no-files-found: 'error'
name: 'tfstated'
path: 'tfstated'
deploy:
if: "${{ startsWith(github.ref, 'refs/tags/') }}"
needs:
- 'main'
runs-on: 'self-hosted'
steps:
#- uses: 'actions/download-artifact@v4'
- uses: 'forgejo/download-artifact@v4'
with:
name: 'tfstated'
- run: |
make deploy
env:
SSH_PRIVATE_KEY: '${{ secrets.SSH_PRIVATE_KEY }}'
publish:
if: "${{ startsWith(github.ref, 'refs/tags/') }}"
needs:
- 'main'
runs-on: 'self-hosted'
steps:
#- uses: 'actions/download-artifact@v4'
- uses: 'forgejo/download-artifact@v4'
with:
name: 'tfstated'
- uses: 'actions/forgejo-release@v2'
with:
direction: 'upload'
tag: '${{ github.ref_name }}'
sha: '${{ github.sha }}'
release-dir: './'
token: '${{ env.GITHUB_TOKEN }}'
hide-archive-link: true
prerelease: false

71
GNUmakefile Normal file
View file

@ -0,0 +1,71 @@
SHELL := bash
.SHELLFLAGS := -eu -o pipefail -c
.ONESHELL:
.DELETE_ON_ERROR:
MAKEFLAGS += --warn-undefined-variables
MAKEFLAGS += --no-builtin-rules
.DEFAULT_GOAL := help
##### Quality ##################################################################
.PHONY: check
check: ## run all code checks
go mod verify
go vet ./...
go test -race -buildvcs -vet=off ./...
.PHONY: cover
cover: ## compute tests coverage
go test -cover -coverprofile cover.out -race -buildvcs -vet=off ./...
go tool cover -html=cover.out
.PHONY: tidy
tidy: ## tidy up the code
go fmt ./...
go mod tidy -v
##### Development ##############################################################
.PHONY: build
build: ## build the code
go build -o ./tfstated ./cmd/tfstated/
.PHONY: clean
clean: ## clean the code
rm -f ./tfstated
.PHONY: run
run: ## run the code
go run ./cmd/tfstated | jq
##### Operations ###############################################################
.PHONY: push
push: tidy no-dirty check ## push changes to git remote
git push git main
.PHONY: deploy
deploy: build ## deploy changes to the production server
umask 077
if [ -n "$${SSH_PRIVATE_KEY:-}" ]; then
cleanup() {
rm -f private_key
}
trap cleanup EXIT
printf '%s' "$$SSH_PRIVATE_KEY" | base64 -d > private_key
SSHOPTS="-i private_key -o StrictHostKeyChecking=accept-new"
fi
rsync -e "ssh $${SSHOPTS:-}" ./tfstated tfstated@tfstated.adyxax.org:
ssh $${SSHOPTS:-} tfstated@tfstated.adyxax.org "chmod +x tfstated; systemctl --user restart tfstated"
##### Utils ####################################################################
.PHONY: confirm
confirm:
@echo -n 'Are you sure? [y/N] ' && read ans && [ $${ans:-N} = y ]
.PHONY: help
help:
@grep -E '^[a-zA-Z\/_-]+:.*?## .*$$' $(MAKEFILE_LIST) \
| awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-20s\033[0m %s\n", $$1, $$2}' \
| sort
.PHONY: no-dirty
no-dirty:
git diff --exit-code