mirror of
https://github.com/n8n-io/n8n.git
synced 2024-12-24 20:24:05 -08:00
ci: Refactor DB tests (no-changelog) (#7292)
[DB tests](https://github.com/n8n-io/n8n/actions/runs/6340094467)
This commit is contained in:
parent
0bc33b1cc2
commit
cf5a0ca456
8
.github/docker-compose.yml
vendored
8
.github/docker-compose.yml
vendored
|
@ -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
|
||||||
|
|
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/**
|
- 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:
|
||||||
|
|
|
@ -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: {
|
||||||
|
|
|
@ -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 () => {
|
||||||
|
|
Loading…
Reference in a new issue