ci: Refactor DB tests (no-changelog) (#7292)

[DB tests](https://github.com/n8n-io/n8n/actions/runs/6340094467)
This commit is contained in:
कारतोफ्फेलस्क्रिप्ट™ 2023-09-28 16:53:05 +02:00 committed by GitHub
parent 0bc33b1cc2
commit cf5a0ca456
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 95 additions and 38 deletions

View file

@ -2,15 +2,21 @@ version: '3.9'
services: services:
mysql: mysql:
image: mysql:5.7-debian image: mysql:5.7
environment: environment:
- MYSQL_DATABASE=n8n - MYSQL_DATABASE=n8n
- MYSQL_ROOT_PASSWORD=password - MYSQL_ROOT_PASSWORD=password
ports: ports:
- 3306:3306 - 3306:3306
ulimits:
nproc: 65535
nofile:
soft: 26677
hard: 46677
postgres: postgres:
image: postgres:11 image: postgres:11
restart: always
environment: environment:
- POSTGRES_DB=n8n - POSTGRES_DB=n8n
- POSTGRES_USER=root - POSTGRES_USER=root

View file

@ -9,45 +9,99 @@ on:
- packages/cli/src/databases/migrations/** - packages/cli/src/databases/migrations/**
jobs: jobs:
test: build:
name: Install & Build
runs-on: ubuntu-latest runs-on: ubuntu-latest
timeout-minutes: 60
env:
DB_MYSQLDB_PASSWORD: password
DB_POSTGRESDB_PASSWORD: password
steps: steps:
- uses: actions/checkout@v3.5.3 - uses: actions/checkout@v3.5.3
- uses: pnpm/action-setup@v2.4.0 - uses: pnpm/action-setup@v2.4.0
- uses: actions/setup-node@v3.7.0 - uses: actions/setup-node@v3.7.0
with: with:
node-version: 18.x node-version: 18.x
cache: 'pnpm' cache: 'pnpm'
- run: pnpm install --frozen-lockfile
- name: Install dependencies - name: Build Backend
run: pnpm install --frozen-lockfile run: pnpm --filter @n8n/client-oauth2 --filter n8n-workflow --filter n8n-core --filter n8n build
- name: Start MySQL & Postgres - name: Cache build artifacts
uses: isbang/compose-action@v1.3.2 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: with:
compose-file: ./.github/docker-compose.yml compose-file: ./.github/docker-compose.yml
services: |
- name: Build Core, Workflow, and CLI mysql
run: pnpm --filter @n8n/client-oauth2 --filter n8n-workflow --filter n8n-core --filter n8n build
- name: Test MySQL - name: Test MySQL
working-directory: packages/cli 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 - name: Test Postgres
working-directory: packages/cli 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 uses: act10ns/slack@v2.0.0
if: failure() && github.ref == 'refs/heads/master' if: failure() && github.ref == 'refs/heads/master'
with: with:

View file

@ -1,5 +1,6 @@
const { compilerOptions } = require('./tsconfig.json'); const { compilerOptions } = require('./tsconfig.json');
/** @type {import('ts-jest').TsJestGlobalOptions} */
const tsJestOptions = { const tsJestOptions = {
isolatedModules: true, isolatedModules: true,
tsconfig: { tsconfig: {

View file

@ -124,12 +124,10 @@ describe('POST /credentials', () => {
}); });
test('should fail with invalid inputs', async () => { test('should fail with invalid inputs', async () => {
await Promise.all( for (const invalidPayload of INVALID_PAYLOADS) {
INVALID_PAYLOADS.map(async (invalidPayload) => { const response = await authOwnerAgent.post('/credentials').send(invalidPayload);
const response = await authOwnerAgent.post('/credentials').send(invalidPayload); expect(response.statusCode).toBe(400);
expect(response.statusCode).toBe(400); }
}),
);
}); });
test('should fail with missing encryption key', async () => { test('should fail with missing encryption key', async () => {
@ -370,18 +368,16 @@ describe('PATCH /credentials/:id', () => {
test('should fail with invalid inputs', async () => { test('should fail with invalid inputs', async () => {
const savedCredential = await saveCredential(randomCredentialPayload(), { user: owner }); const savedCredential = await saveCredential(randomCredentialPayload(), { user: owner });
await Promise.all( for (const invalidPayload of INVALID_PAYLOADS) {
INVALID_PAYLOADS.map(async (invalidPayload) => { const response = await authOwnerAgent
const response = await authOwnerAgent .patch(`/credentials/${savedCredential.id}`)
.patch(`/credentials/${savedCredential.id}`) .send(invalidPayload);
.send(invalidPayload);
if (response.statusCode === 500) { if (response.statusCode === 500) {
console.log(response.statusCode, response.body); console.log(response.statusCode, response.body);
} }
expect(response.statusCode).toBe(400); expect(response.statusCode).toBe(400);
}), }
);
}); });
test('should fail if cred not found', async () => { test('should fail if cred not found', async () => {