mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-16 17:46:45 +00:00
ci: Refactor DB tests (no-changelog) (#7292)
[DB tests](https://github.com/n8n-io/n8n/actions/runs/6340094467)
This commit is contained in:
committed by
GitHub
parent
0bc33b1cc2
commit
cf5a0ca456
94
.github/workflows/ci-postgres-mysql.yml
vendored
94
.github/workflows/ci-postgres-mysql.yml
vendored
@@ -9,45 +9,99 @@ on:
|
||||
- packages/cli/src/databases/migrations/**
|
||||
|
||||
jobs:
|
||||
test:
|
||||
build:
|
||||
name: Install & Build
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
timeout-minutes: 60
|
||||
|
||||
env:
|
||||
DB_MYSQLDB_PASSWORD: password
|
||||
DB_POSTGRESDB_PASSWORD: password
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v3.5.3
|
||||
|
||||
- uses: pnpm/action-setup@v2.4.0
|
||||
|
||||
- uses: actions/setup-node@v3.7.0
|
||||
with:
|
||||
node-version: 18.x
|
||||
cache: 'pnpm'
|
||||
- run: pnpm install --frozen-lockfile
|
||||
|
||||
- name: Install dependencies
|
||||
run: pnpm install --frozen-lockfile
|
||||
- name: Build Backend
|
||||
run: pnpm --filter @n8n/client-oauth2 --filter n8n-workflow --filter n8n-core --filter n8n build
|
||||
|
||||
- name: Start MySQL & Postgres
|
||||
uses: isbang/compose-action@v1.3.2
|
||||
- name: Cache build artifacts
|
||||
uses: actions/cache/save@v3.3.1
|
||||
with:
|
||||
path: ./packages/**/dist
|
||||
key: ${{ github.sha }}:db-tests
|
||||
|
||||
mysql:
|
||||
name: MySQL
|
||||
runs-on: ubuntu-latest
|
||||
needs: build
|
||||
timeout-minutes: 20
|
||||
env:
|
||||
DB_MYSQLDB_PASSWORD: password
|
||||
steps:
|
||||
- uses: actions/checkout@v3.5.3
|
||||
- uses: pnpm/action-setup@v2.4.0
|
||||
- uses: actions/setup-node@v3.7.0
|
||||
with:
|
||||
node-version: 18.x
|
||||
cache: 'pnpm'
|
||||
- run: pnpm install --frozen-lockfile
|
||||
|
||||
- name: Restore cached build artifacts
|
||||
uses: actions/cache/restore@v3.3.1
|
||||
with:
|
||||
path: ./packages/**/dist
|
||||
key: ${{ github.sha }}:db-tests
|
||||
|
||||
- name: Start MySQL
|
||||
uses: isbang/compose-action@v1.5.1
|
||||
with:
|
||||
compose-file: ./.github/docker-compose.yml
|
||||
|
||||
- name: Build Core, Workflow, and CLI
|
||||
run: pnpm --filter @n8n/client-oauth2 --filter n8n-workflow --filter n8n-core --filter n8n build
|
||||
services: |
|
||||
mysql
|
||||
|
||||
- name: Test MySQL
|
||||
working-directory: packages/cli
|
||||
run: DB_TABLE_PREFIX=test_ pnpm test:mysql
|
||||
run: DB_TABLE_PREFIX=test_ pnpm test:mysql --runInBand
|
||||
|
||||
postgres:
|
||||
name: Postgres
|
||||
runs-on: ubuntu-latest
|
||||
needs: build
|
||||
timeout-minutes: 20
|
||||
env:
|
||||
DB_POSTGRESDB_PASSWORD: password
|
||||
steps:
|
||||
- uses: actions/checkout@v3.5.3
|
||||
- uses: pnpm/action-setup@v2.4.0
|
||||
- uses: actions/setup-node@v3.7.0
|
||||
with:
|
||||
node-version: 18.x
|
||||
cache: 'pnpm'
|
||||
- run: pnpm install --frozen-lockfile
|
||||
|
||||
- name: Restore cached build artifacts
|
||||
uses: actions/cache/restore@v3.3.1
|
||||
with:
|
||||
path: ./packages/**/dist
|
||||
key: ${{ github.sha }}:db-tests
|
||||
|
||||
- name: Start Postgres
|
||||
uses: isbang/compose-action@v1.5.1
|
||||
with:
|
||||
compose-file: ./.github/docker-compose.yml
|
||||
services: |
|
||||
postgres
|
||||
|
||||
- name: Test Postgres
|
||||
working-directory: packages/cli
|
||||
run: DB_POSTGRESDB_SCHEMA=alt_schema DB_TABLE_PREFIX=test_ pnpm test:postgres
|
||||
run: DB_POSTGRESDB_SCHEMA=alt_schema DB_TABLE_PREFIX=test_ pnpm test:postgres --runInBand
|
||||
|
||||
- name: Notify Slack on master failure
|
||||
notify-on-failure:
|
||||
name: Notify Slack on failure
|
||||
runs-on: ubuntu-latest
|
||||
needs: [mysql, postgres]
|
||||
steps:
|
||||
- name: Notify Slack on failure
|
||||
uses: act10ns/slack@v2.0.0
|
||||
if: failure() && github.ref == 'refs/heads/master'
|
||||
with:
|
||||
|
||||
Reference in New Issue
Block a user