Skip to content

feat(backend): Switch from Prisma schema to SQL schema #3276

feat(backend): Switch from Prisma schema to SQL schema

feat(backend): Switch from Prisma schema to SQL schema #3276

Workflow file for this run

name: Rust
on:
pull_request:
branches: [main, "renovate/*", "CHAOS-224-KHAOS-rewrite"]
paths:
- backend/server/**
- backend/prisma-cli/**
push:
branches: ["renovate/*"]
env:
CARGO_TERM_COLOR: always
jobs:
build:
runs-on: ubuntu-latest
services:
postgres:
image: postgres:16
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: password
POSTGRES_DB: chaos
ports:
- 5432:5432
steps:
- uses: actions/checkout@v4
- name: Setup env file
run: |
echo "DATABASE_URL=postgres://postgres:password@localhost:5432/chaos" >> backend/.env
echo "JWT_SECRET=test_secret" >> backend/.env
echo "GOOGLE_CLIENT_ID=test" >> backend/.env
echo "GOOGLE_CLIENT_SECRET=test" >> backend/.env
echo "GOOGLE_REDIRECT_URI=http://localhost:3000/auth/callback" >> backend/.env
echo "ROCKET_DATABASES='{}'" >> backend/.env
# selecting a toolchain either by action or manual `rustup` calls should happen
# before the plugin, as it uses the current rustc version as its cache key
- uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: stable
- name: Setup cargo cache
uses: actions/cache@v3
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
backend/server/target/
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
restore-keys: ${{ runner.os }}-cargo-
- name: Migrate DB
working-directory: backend
run: |
cargo install sqlx-cli --no-default-features --features native-tls,postgres
sqlx database create
sqlx migrate run
- name: Build
working-directory: backend/server
run: cargo build
- name: Cargo Clippy
working-directory: backend/server
run: cargo clippy
- name: RustFmt
working-directory: backend/server
run: cargo fmt