chore: use in-memory database for local development #14152
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: CI | |
on: | |
push: | |
branches: | |
- main | |
pull_request: | |
branches: | |
- main | |
jobs: | |
lint: | |
name: Lint | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
with: | |
fetch-depth: 0 | |
- name: Install pnpm | |
uses: pnpm/action-setup@v4 | |
- name: Setup Node.js | |
uses: actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 # v4.0.2 | |
with: | |
node-version: 20 | |
cache: 'pnpm' | |
- name: Install dependencies | |
run: pnpm install | |
- name: Run linter | |
run: pnpm lint | |
- name: Check types | |
run: pnpm typecheck | |
- name: Validate GraphQL operations | |
run: pnpm validate | |
test: | |
name: Build & Test | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-latest] | |
node: [20] | |
services: | |
postgres: | |
image: postgres@sha256:d0f363f8366fbc3f52d172c6e76bc27151c3d643b870e1062b4e8bfe65baf609 | |
env: | |
POSTGRES_PASSWORD: postgres | |
POSTGRES_DB: jabref | |
# Set health checks to wait until postgres has started | |
options: >- | |
--health-cmd pg_isready | |
--health-interval 10s | |
--health-timeout 5s | |
--health-retries 5 | |
ports: | |
- 5432:5432 | |
redis: | |
image: redis@sha256:79676a8f74e4aed85b6d6a2f4e4e3e55d8a229baa7168362e592bbfdc67b0c9b | |
# Set health checks to wait until redis has started | |
options: >- | |
--health-cmd "redis-cli ping" | |
--health-interval 10s | |
--health-timeout 5s | |
--health-retries 5 | |
ports: | |
# Maps port 6379 on service container to port 6380 on host | |
- 6380:6379 | |
env: | |
DATABASE_URL: postgresql://postgres:postgres@localhost:5432/jabref?schema=public | |
GITHUB_REPO_TOKEN: ${{ secrets.GITHUBS_REPO_TOKEN }} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
with: | |
fetch-depth: 0 | |
- name: Install pnpm | |
uses: pnpm/action-setup@v4 | |
- name: Setup Node.js | |
uses: actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 # v4.0.2 | |
with: | |
node-version: ${{ matrix.node }} | |
cache: 'pnpm' | |
- name: Install dependencies | |
run: pnpm install | |
- name: Init database | |
run: pnpm prisma:push | |
# Check that no schema changes have been done without corresponding migration files have been added | |
- name: Detect database schema drift | |
run: pnpm prisma:migrate:diff $DATABASE_URL | |
- name: Build | |
run: pnpm build | |
- name: Start server | |
run: pnpm start & | |
- name: Run tests | |
run: pnpm run test --coverage | |
env: | |
TEST_URL: http://localhost:3000 | |
- name: Build Storybook | |
run: | | |
pnpm nuxi generate | |
pnpm storybook:build | |
cp .output/public/_storybook/external-iframe/index.html storybook-static/iframe.html | |
mkdir -p storybook-static/_storybook/external-iframe | |
cp -r .output/public/_nuxt storybook-static | |
- name: Publish and test Storybook | |
uses: chromaui/action@fdbe7756d4dbf493e2fbb822df73be7accd07e1c # v11 | |
with: | |
projectToken: 'b3787adf2fa5' | |
# Don't wait until Chroma verified the build (for this we have the Github check) | |
exitOnceUploaded: true | |
storybookBuildDir: storybook-static | |
debug: true | |
- name: Upload coverage to Codecov | |
uses: codecov/codecov-action@e28ff129e5465c2c0dcc6f003fc735cb6ae0c673 # v4.5.0 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} |