actions: Add postgres db to test job and migrate the db #118
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
--- | |
name: Go | |
on: # yamllint disable-line rule:truthy | |
push: | |
branches: [main] | |
pull_request: | |
branches: [main] | |
jobs: | |
test: | |
runs-on: ubuntu-latest | |
env: | |
PGHOST: localhost | |
PGDATABASE: planner | |
PGUSERNAME: admin | |
PGPASSWORD: adminpass | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up Go | |
uses: actions/setup-go@v5 | |
- name: Setup libvirt | |
run: | | |
sudo apt update | |
sudo apt install libvirt-dev | |
- name: Add PostgreSQL binaries to PATH | |
shell: bash | |
run: | | |
echo "$(pg_config --bindir)" >> $GITHUB_PATH | |
- name: Start preinstalled PostgreSQL | |
shell: bash | |
run: | | |
echo "Initializing database cluster..." | |
# Convert backslashes to forward slashes in RUNNER_TEMP for Windows Git Bash | |
export PGHOST="${RUNNER_TEMP//\\//}/postgres" | |
export PGDATA="$PGHOST/pgdata" | |
mkdir -p "$PGDATA" | |
# initdb requires file for password in non-interactive mode | |
export PWFILE="$RUNNER_TEMP/pwfile" | |
echo "postgres" > "$PWFILE" | |
initdb --pgdata="$PGDATA" --username="postgres" --pwfile="$PWFILE" | |
echo "Starting PostgreSQL..." | |
echo "unix_socket_directories = '$PGHOST'" >> "$PGDATA/postgresql.conf" | |
pg_ctl start | |
echo "Creating user..." | |
psql --host "$PGHOST" --username="postgres" --dbname="postgres" --command="CREATE USER $PGUSERNAME PASSWORD '$PGPASSWORD'" --command="\du" | |
echo "Creating database..." | |
createdb --owner="$PGUSERNAME" --username="postgres" "$PGDATABASE" | |
- name: Prepare | |
run: | | |
make generate | |
DOWNLOAD_RHCOS=false make build | |
- name: Migrate the db | |
run: | | |
make migrate | |
- name: Test | |
run: | | |
make test | |
- name: Checking generated files are up to date | |
run: | | |
if [[ $(git ls-files --others --exclude-standard) ]]; then git ls-files --others --exclude-standard; echo "These files are not tracked by git"; exit 1; fi | |
if [ -n "$(git status --porcelain)" ]; then echo "There are uncommitted changes:"; git status --short; exit 1; fi | |
Lint: | |
name: Lint code | |
runs-on: ubuntu-latest | |
steps: | |
- name: Check out code | |
uses: actions/checkout@v4 | |
- name: Setup libvirt | |
run: | | |
sudo apt update | |
sudo apt install libvirt-dev | |
- name: Run golangci-lint | |
uses: golangci/[email protected] | |
with: | |
args: --timeout=2m |