UNPKG

aquameta-datum

Version:

Service layer for the Aquameta database API

215 lines (205 loc) 21.5 kB
import test from 'tape'; import connection from '../../query/connection.js'; import sinon from 'sinon'; import pg from '@micburks/pg'; test('#connection', async t => { const fakeRow = { name: 'fake-name' }; let loggedIn = false; const fakeQuery = queryString => { if (/^select .* role_name from endpoint.session/.test(queryString)) { loggedIn = true; return { rows: [{ response: JSON.stringify({ result: [{ row: { role_name: 'logged-in-user' } }] }) }] }; } else { return { rows: [{ response: JSON.stringify({ result: [{ row: fakeRow }] }) }] }; } }; const clientAPI = { query: sinon.fake(fakeQuery), connect: sinon.fake(), end: sinon.fake() }; sinon.stub(pg, 'Client').callsFake(config => { if (loggedIn) { t.is(config.user, 'logged-in-user', 'updates config to use logged in user'); } else { t.is(config.user, 'anonymous', 'uses default config'); } t.is(config.host, 'override-host', 'merges given client config'); return clientAPI; }); const client = { sessionId: '123', connection: { host: 'override-host' } }; const user = await connection(client, {}); t.deepEquals(user[0], fakeRow, 'returns data'); t.is(clientAPI.connect.callCount, clientAPI.end.callCount, 'all clients are released'); pg.Client.restore(); t.end(); }); test('#connection - without sessionId', async t => { const fakeRow = { name: 'fake-name' }; const fakeQuery = queryString => { if (/^select .* role_name from endpoint.session/.test(queryString)) { t.fail('tried to login'); } else { return { rows: [{ response: JSON.stringify({ result: [{ row: fakeRow }] }) }] }; } }; const clientAPI = { query: sinon.fake(fakeQuery), connect: sinon.fake(), end: sinon.fake() }; sinon.stub(pg, 'Client').callsFake(config => { t.is(config.user, 'anonymous', "doesn't alter user"); return clientAPI; }); const result = await connection({}, {}); t.deepEqual(result[0], fakeRow, 'returns data'); t.is(clientAPI.connect.callCount, clientAPI.end.callCount, 'all clients are released'); pg.Client.restore(); t.end(); }); test('#connection - uses anonymous if login fails', async t => { const fakeRow = { name: 'fake-name' }; const fakeQuery = queryString => { if (/^select .* role_name from endpoint.session/.test(queryString)) { return { rows: [{ response: JSON.stringify({ result: [] }) }] }; } else { return { rows: [{ response: JSON.stringify({ result: [{ row: fakeRow }] }) }] }; } }; const clientAPI = { query: sinon.fake(fakeQuery), connect: sinon.fake(), end: sinon.fake() }; sinon.stub(pg, 'Client').callsFake(config => { t.is(config.user, 'anonymous', "doesn't alter user"); return clientAPI; }); const client = { rawSession: true, sessionId: '123' }; const result = await connection(client, {}); t.deepEqual(result[0], fakeRow, 'still returns data'); t.is(clientAPI.connect.callCount, clientAPI.end.callCount, 'all clients are released'); pg.Client.restore(); t.end(); }); test('#connection - deals with error in running queries', async t => { const fakeQuery = () => { throw new Error('db connection failed'); }; const clientAPI = { query: sinon.fake(fakeQuery), connect: sinon.fake(), end: sinon.fake() }; sinon.stub(pg, 'Client').callsFake(() => clientAPI); const client = { sessionId: '123' }; const result = await connection(client, {}); t.is(result, null, 'returns null'); t.is(clientAPI.connect.callCount, clientAPI.end.callCount, 'all clients are released'); pg.Client.restore(); t.end(); }); test('#connection - passes all query params', async t => { const sessionId = '123'; const version = 'v2'; const query = { method: 'POST', url: '/widget/dependency', args: { limit: 5 }, data: { id: '999' } }; const fakeQuery = (queryString, args) => { if (/^select .* role_name from endpoint.session/.test(queryString)) { t.deepEqual(args, [sessionId]); return { rows: [{ role_name: 'logged-in-user' }] }; } else { t.deepEqual(args, [version, query.method, query.url, JSON.stringify(query.args), JSON.stringify(query.data)]); return { rows: [{ response: JSON.stringify({ result: [] }) }] }; } }; const clientAPI = { query: sinon.fake(fakeQuery), connect: sinon.fake(), end: sinon.fake() }; sinon.stub(pg, 'Client').callsFake(() => clientAPI); const client = { sessionId, version }; await connection(client, query); pg.Client.restore(); t.end(); }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["connection.js"],"names":["test","connection","sinon","pg","t","fakeRow","name","loggedIn","fakeQuery","queryString","rows","response","JSON","stringify","result","row","role_name","clientAPI","query","fake","connect","end","stub","callsFake","config","is","user","host","client","sessionId","deepEquals","callCount","Client","restore","fail","deepEqual","rawSession","Error","version","method","url","args","limit","data","id"],"mappings":"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","sourcesContent":["import test from 'tape';\nimport connection from '../../query/connection.js';\nimport sinon from 'sinon';\nimport pg from '@micburks/pg';\n\ntest('#connection', async t => {\n  const fakeRow = {name: 'fake-name'};\n  let loggedIn = false;\n\n  const fakeQuery = queryString => {\n    if (/^select .* role_name from endpoint.session/.test(queryString)) {\n      loggedIn = true;\n      return {\n        rows: [\n          {\n            response: JSON.stringify({\n              result: [{row: {role_name: 'logged-in-user'}}],\n            }),\n          },\n        ],\n      };\n    } else {\n      return {\n        rows: [{response: JSON.stringify({result: [{row: fakeRow}]})}],\n      };\n    }\n  };\n  const clientAPI = {\n    query: sinon.fake(fakeQuery),\n    connect: sinon.fake(),\n    end: sinon.fake(),\n  };\n  sinon.stub(pg, 'Client').callsFake(config => {\n    if (loggedIn) {\n      t.is(\n        config.user,\n        'logged-in-user',\n        'updates config to use logged in user',\n      );\n    } else {\n      t.is(config.user, 'anonymous', 'uses default config');\n    }\n    t.is(config.host, 'override-host', 'merges given client config');\n\n    return clientAPI;\n  });\n\n  const client = {\n    sessionId: '123',\n    connection: {host: 'override-host'},\n  };\n  const user = await connection(client, {});\n  t.deepEquals(user[0], fakeRow, 'returns data');\n  t.is(\n    clientAPI.connect.callCount,\n    clientAPI.end.callCount,\n    'all clients are released',\n  );\n\n  pg.Client.restore();\n  t.end();\n});\n\ntest('#connection - without sessionId', async t => {\n  const fakeRow = {name: 'fake-name'};\n\n  const fakeQuery = queryString => {\n    if (/^select .* role_name from endpoint.session/.test(queryString)) {\n      t.fail('tried to login');\n    } else {\n      return {\n        rows: [\n          {\n            response: JSON.stringify({\n              result: [{row: fakeRow}],\n            }),\n          },\n        ],\n      };\n    }\n  };\n  const clientAPI = {\n    query: sinon.fake(fakeQuery),\n    connect: sinon.fake(),\n    end: sinon.fake(),\n  };\n  sinon.stub(pg, 'Client').callsFake(config => {\n    t.is(config.user, 'anonymous', \"doesn't alter user\");\n\n    return clientAPI;\n  });\n\n  const result = await connection({}, {});\n  t.deepEqual(result[0], fakeRow, 'returns data');\n  t.is(\n    clientAPI.connect.callCount,\n    clientAPI.end.callCount,\n    'all clients are released',\n  );\n\n  pg.Client.restore();\n  t.end();\n});\n\ntest('#connection - uses anonymous if login fails', async t => {\n  const fakeRow = {name: 'fake-name'};\n\n  const fakeQuery = queryString => {\n    if (/^select .* role_name from endpoint.session/.test(queryString)) {\n      return {\n        rows: [\n          {\n            response: JSON.stringify({\n              result: [],\n            }),\n          },\n        ],\n      };\n    } else {\n      return {\n        rows: [\n          {\n            response: JSON.stringify({\n              result: [{row: fakeRow}],\n            }),\n          },\n        ],\n      };\n    }\n  };\n  const clientAPI = {\n    query: sinon.fake(fakeQuery),\n    connect: sinon.fake(),\n    end: sinon.fake(),\n  };\n  sinon.stub(pg, 'Client').callsFake(config => {\n    t.is(config.user, 'anonymous', \"doesn't alter user\");\n\n    return clientAPI;\n  });\n\n  const client = {rawSession: true, sessionId: '123'};\n  const result = await connection(client, {});\n  t.deepEqual(result[0], fakeRow, 'still returns data');\n  t.is(\n    clientAPI.connect.callCount,\n    clientAPI.end.callCount,\n    'all clients are released',\n  );\n\n  pg.Client.restore();\n  t.end();\n});\n\ntest('#connection - deals with error in running queries', async t => {\n  const fakeQuery = () => {\n    throw new Error('db connection failed');\n  };\n  const clientAPI = {\n    query: sinon.fake(fakeQuery),\n    connect: sinon.fake(),\n    end: sinon.fake(),\n  };\n  sinon.stub(pg, 'Client').callsFake(() => clientAPI);\n\n  const client = {sessionId: '123'};\n  const result = await connection(client, {});\n  t.is(result, null, 'returns null');\n  t.is(\n    clientAPI.connect.callCount,\n    clientAPI.end.callCount,\n    'all clients are released',\n  );\n\n  pg.Client.restore();\n  t.end();\n});\n\ntest('#connection - passes all query params', async t => {\n  const sessionId = '123';\n  const version = 'v2';\n  const query = {\n    method: 'POST',\n    url: '/widget/dependency',\n    args: {limit: 5},\n    data: {id: '999'},\n  };\n\n  const fakeQuery = (queryString, args) => {\n    if (/^select .* role_name from endpoint.session/.test(queryString)) {\n      t.deepEqual(args, [sessionId]);\n      return {rows: [{role_name: 'logged-in-user'}]};\n    } else {\n      t.deepEqual(args, [\n        version,\n        query.method,\n        query.url,\n        JSON.stringify(query.args),\n        JSON.stringify(query.data),\n      ]);\n      return {\n        rows: [\n          {\n            response: JSON.stringify({\n              result: [],\n            }),\n          },\n        ],\n      };\n    }\n  };\n  const clientAPI = {\n    query: sinon.fake(fakeQuery),\n    connect: sinon.fake(),\n    end: sinon.fake(),\n  };\n  sinon.stub(pg, 'Client').callsFake(() => clientAPI);\n\n  const client = {sessionId, version};\n  await connection(client, query);\n  pg.Client.restore();\n  t.end();\n});\n"]}