mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-25 00:07:47 +01:00
e952ae20a8
- Also adds metrics for min and max pool size - Metrics for free/used connections. - Metrics for pending and current acquires fixes: #705
191 lines
5.0 KiB
JavaScript
191 lines
5.0 KiB
JavaScript
/* eslint-disable no-console */
|
|
|
|
'use strict';
|
|
|
|
const test = require('ava');
|
|
const fs = require('fs');
|
|
const { createOptions } = require('./options');
|
|
|
|
delete process.env.DATABASE_URL;
|
|
|
|
test('should require DATABASE_URI', t => {
|
|
t.throws(() => {
|
|
createOptions({});
|
|
});
|
|
});
|
|
|
|
test('should use DATABASE_URL from env', t => {
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/name';
|
|
delete process.env.NODE_ENV;
|
|
process.env.DATABASE_URL = databaseUrl;
|
|
|
|
const options = createOptions({});
|
|
|
|
t.true(options.databaseUrl === databaseUrl);
|
|
});
|
|
|
|
test('should use DATABASE_URL_FILE from env', t => {
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/name';
|
|
const path = '/tmp/db_url';
|
|
fs.writeFileSync(path, databaseUrl, { mode: 0o755 });
|
|
delete process.env.NODE_ENV;
|
|
process.env.DATABASE_URL_FILE = path;
|
|
|
|
const options = createOptions({});
|
|
|
|
t.true(options.databaseUrl === databaseUrl);
|
|
});
|
|
|
|
test('should use databaseUrl from options', t => {
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/name';
|
|
|
|
const options = createOptions({ databaseUrl });
|
|
|
|
t.true(options.databaseUrl === databaseUrl);
|
|
});
|
|
|
|
test('should not override provided options', t => {
|
|
process.env.DATABASE_URL = 'postgres://test:5432/name';
|
|
process.env.NODE_ENV = 'production';
|
|
|
|
const options = createOptions({
|
|
databaseUrl: 'postgres://test:5432/name',
|
|
port: 1111,
|
|
});
|
|
|
|
t.true(options.databaseUrl === 'postgres://test:5432/name');
|
|
t.true(options.port === 1111);
|
|
});
|
|
|
|
test('should add listen options from host and port', t => {
|
|
const options = createOptions({
|
|
databaseUrl: 'postgres://test:5432/name',
|
|
port: 1111,
|
|
host: 'localhost',
|
|
});
|
|
|
|
t.deepEqual(options.listen, { port: 1111, host: 'localhost' });
|
|
});
|
|
|
|
test('should use pipe to path', t => {
|
|
const options = createOptions({
|
|
databaseUrl: 'postgres://test:5432/name',
|
|
port: 1111,
|
|
host: 'localhost',
|
|
pipe: '\\\\?\\pipe',
|
|
});
|
|
|
|
t.deepEqual(options.listen, { path: options.pipe });
|
|
});
|
|
|
|
test('should prefer databaseUrl from options', t => {
|
|
process.env.DATABASE_URL = 'postgres://test:5432/name';
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/options';
|
|
|
|
const options = createOptions({ databaseUrl });
|
|
|
|
t.deepEqual(options.databaseUrl, databaseUrl);
|
|
});
|
|
|
|
test('should expand databaseUrl from options', t => {
|
|
process.env.DATABASE_URL = 'postgres://test:5432/name';
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/options';
|
|
|
|
const options = createOptions({ databaseUrl });
|
|
|
|
t.deepEqual(options.db, {
|
|
database: 'options',
|
|
driver: 'postgres',
|
|
host: 'localhost',
|
|
password: 'p',
|
|
port: '5432',
|
|
user: 'u',
|
|
pool: {
|
|
idleTimeoutMillis: 30000,
|
|
max: 4,
|
|
min: 0,
|
|
},
|
|
});
|
|
});
|
|
|
|
test('should validate getLogger', t => {
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/options';
|
|
const getLogger = () => {};
|
|
|
|
t.throws(() => {
|
|
createOptions({ databaseUrl, getLogger });
|
|
});
|
|
});
|
|
|
|
test('should accept custome log-provider', t => {
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/options';
|
|
const getLogger = () => ({
|
|
debug: console.log,
|
|
info: console.log,
|
|
warn: console.log,
|
|
error: console.log,
|
|
});
|
|
const options = createOptions({ databaseUrl, getLogger });
|
|
|
|
t.deepEqual(options.getLogger, getLogger);
|
|
});
|
|
|
|
test('should prefer custom db connection options', t => {
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/options';
|
|
const db = {
|
|
user: 'db_user',
|
|
password: 'db_password',
|
|
host: 'db-host',
|
|
port: 3232,
|
|
database: 'db_database',
|
|
ssl: false,
|
|
driver: 'postgres',
|
|
version: '10',
|
|
pool: {
|
|
max: 4,
|
|
min: 0,
|
|
idleTimeoutMillis: 30000,
|
|
},
|
|
};
|
|
const options = createOptions({ databaseUrl, db });
|
|
|
|
t.deepEqual(options.db, db);
|
|
});
|
|
|
|
test('should baseUriPath', t => {
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/options';
|
|
const baseUriPath = 'some';
|
|
const options = createOptions({ databaseUrl, baseUriPath });
|
|
|
|
t.deepEqual(options.baseUriPath, baseUriPath);
|
|
});
|
|
|
|
test('should allow setting pool size', t => {
|
|
const min = 4;
|
|
const max = 20;
|
|
const db = {
|
|
user: 'db_user',
|
|
password: 'db_password',
|
|
host: 'db-host',
|
|
port: 5432,
|
|
database: 'unleash',
|
|
pool: {
|
|
min,
|
|
max,
|
|
},
|
|
};
|
|
const options = createOptions({ db });
|
|
t.is(options.db.pool.min, min);
|
|
t.is(options.db.pool.max, max);
|
|
t.is(options.db.driver, 'postgres');
|
|
});
|
|
|
|
test('Should allow using outer poolMin and poolMax to set poolsize', t => {
|
|
const databaseUrl = 'postgres://u:p@localhost:5432/options';
|
|
const poolMin = 10;
|
|
const poolMax = 20;
|
|
const options = createOptions({ databaseUrl, poolMax, poolMin });
|
|
t.is(options.db.pool.min, 10);
|
|
t.is(options.db.pool.max, 20);
|
|
});
|