mirror of
https://github.com/xbgmsharp/postgsail.git
synced 2025-09-17 11:17:46 +00:00
Add schemalint github actioni for best practice reference
This commit is contained in:
55
.github/workflows/db-lint.yml
vendored
Normal file
55
.github/workflows/db-lint.yml
vendored
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
name: Linting rules on database schema.
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'initdb/**'
|
||||||
|
branches:
|
||||||
|
- 'main'
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- 'main'
|
||||||
|
paths:
|
||||||
|
- 'initdb/**'
|
||||||
|
tags:
|
||||||
|
- "*"
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
schemalint:
|
||||||
|
name: schemalint
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Check out the source
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Set env
|
||||||
|
run: cp .env.example .env
|
||||||
|
|
||||||
|
- name: Pull Docker images
|
||||||
|
run: docker-compose pull db api
|
||||||
|
|
||||||
|
- name: Run PostgSail Database & schemalint
|
||||||
|
# Environment variables
|
||||||
|
env:
|
||||||
|
# The hostname used to communicate with the PostgreSQL service container
|
||||||
|
PGHOST: localhost
|
||||||
|
PGPORT: 5432
|
||||||
|
PGDATABASE: signalk
|
||||||
|
PGUSER: username
|
||||||
|
PGPASSWORD: password
|
||||||
|
run: |
|
||||||
|
set -eu
|
||||||
|
source .env
|
||||||
|
docker-compose stop || true
|
||||||
|
docker-compose rm || true
|
||||||
|
docker-compose up -d db && sleep 30 && docker-compose up -d api && sleep 5
|
||||||
|
docker-compose ps -a
|
||||||
|
echo ${PGSAIL_API_URL}
|
||||||
|
curl ${PGSAIL_API_URL}
|
||||||
|
npm i -D schemalint
|
||||||
|
npx schemalint
|
||||||
|
- name: Show the logs
|
||||||
|
if: always()
|
||||||
|
run: |
|
||||||
|
docker-compose logs
|
22
.schemalintrc.js
Normal file
22
.schemalintrc.js
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
module.exports = {
|
||||||
|
connection: {
|
||||||
|
host: process.env.PGHOST,
|
||||||
|
user: process.env.PGUSER,
|
||||||
|
password: process.env.PGPASSWORD,
|
||||||
|
database: process.env.PGDATABASE,
|
||||||
|
charset: "utf8",
|
||||||
|
},
|
||||||
|
|
||||||
|
rules: {
|
||||||
|
"name-casing": ["error", "snake"],
|
||||||
|
"prefer-jsonb-to-json": ["error"],
|
||||||
|
"prefer-text-to-varchar": ["error"],
|
||||||
|
"prefer-timestamptz-to-timestamp": ["error"],
|
||||||
|
"prefer-identity-to-serial": ["error"],
|
||||||
|
"name-inflection": ["error", "singular"],
|
||||||
|
},
|
||||||
|
|
||||||
|
schemas: [{ name: "public" }, { name: "api" }],
|
||||||
|
|
||||||
|
ignores: [],
|
||||||
|
};
|
Reference in New Issue
Block a user