Windshaft-cartodb/test/integration/pg-query-runner-test.js
2019-10-21 19:41:03 +02:00

47 lines
1.3 KiB
JavaScript

'use strict';
require('../support/test-helper');
var assert = require('assert');
var RedisPool = require('redis-mpool');
var cartodbRedis = require('cartodb-redis');
var PgConnection = require('../../lib/backends/pg-connection');
var PgQueryRunner = require('../../lib/backends/pg-query-runner');
describe('PgQueryRunner', function () {
var queryRunner;
before(function () {
var redisPool = new RedisPool(global.environment.redis);
var metadataBackend = cartodbRedis({ pool: redisPool });
var pgConnection = new PgConnection(metadataBackend);
queryRunner = new PgQueryRunner(pgConnection);
});
it('should work for happy case', function (done) {
var query = 'select cartodb_id from test_table limit 3';
queryRunner.run('localhost', query, function (err, result) {
assert.ok(!err, err);
assert.ok(Array.isArray(result));
assert.strictEqual(result.length, 3);
done();
});
});
it('should receive rows array even on error', function (done) {
var query = 'select __error___ from test_table';
queryRunner.run('localhost', query, function (err, result) {
assert.ok(err);
assert.ok(Array.isArray(result));
assert.strictEqual(result.length, 0);
done();
});
});
});