CartoDB-SQL-API/test/acceptance/x-cache-channel-test.js

113 lines
4.1 KiB
JavaScript
Raw Normal View History

2018-10-24 21:42:33 +08:00
'use strict';
require('../helper');
var server = require('../../lib/server')();
2015-05-13 17:21:44 +08:00
var assert = require('../support/assert');
var querystring = require('querystring');
var _ = require('underscore');
2019-12-24 01:19:08 +08:00
describe('X-Cache-Channel header', function () {
function createGetRequest (sqlQuery) {
2015-09-08 00:09:42 +08:00
var query = querystring.stringify({
q: sqlQuery,
api_key: 1234
});
return {
url: '/api/v1/sql?' + query,
headers: {
host: 'vizzuality.cartodb.com'
},
method: 'GET'
};
}
2015-09-08 00:09:42 +08:00
var RESPONSE_OK = {
statusCode: 200
};
2019-12-24 01:19:08 +08:00
function xCacheChannelHeaderHasTables (xCacheChannel, expectedTablesNames) {
2015-09-08 00:09:42 +08:00
var databaseAndTables = xCacheChannel.split(':');
var databaseName = databaseAndTables[0];
2019-12-26 21:01:18 +08:00
assert.strictEqual(databaseName, 'cartodb_test_user_1_db');
2015-09-08 00:09:42 +08:00
var headerTableNames = databaseAndTables[1].split(',');
2019-12-26 21:01:18 +08:00
assert.strictEqual(headerTableNames.length, expectedTablesNames.length);
2015-09-08 00:09:42 +08:00
var tablesDiff = _.difference(expectedTablesNames, headerTableNames);
2019-12-26 21:01:18 +08:00
assert.strictEqual(tablesDiff.length, 0, 'X-Cache-Channel header missing tables: ' + tablesDiff.join(','));
2015-09-08 00:09:42 +08:00
}
2019-12-24 01:19:08 +08:00
function tableNamesInCacheChannelHeader (expectedTableNames, done) {
return function (err, res) {
2019-12-26 21:51:09 +08:00
assert.ifError(err);
2015-09-08 00:09:42 +08:00
xCacheChannelHeaderHasTables(res.headers['x-cache-channel'], expectedTableNames);
done();
};
}
2019-12-24 01:19:08 +08:00
it('supports joins', function (done) {
var sql = 'SELECT a.name as an, b.name as bn FROM untitle_table_4 a ' +
'left join private_table b ON (a.cartodb_id = b.cartodb_id)';
2015-09-08 00:09:42 +08:00
assert.response(server, createGetRequest(sql), RESPONSE_OK, tableNamesInCacheChannelHeader([
2015-09-08 00:09:42 +08:00
'public.private_table',
'public.untitle_table_4'
], done));
});
2015-09-08 00:09:42 +08:00
2019-12-24 01:19:08 +08:00
it('supports multistatements', function (done) {
var sql = 'SELECT * FROM untitle_table_4; SELECT * FROM private_table';
2015-09-08 00:09:42 +08:00
assert.response(server, createGetRequest(sql), RESPONSE_OK, tableNamesInCacheChannelHeader([
2015-09-08 00:09:42 +08:00
'public.private_table',
'public.untitle_table_4'
], done));
});
2019-12-24 01:19:08 +08:00
it('supports explicit transactions', function (done) {
var sql = 'BEGIN; SELECT * FROM untitle_table_4; COMMIT; BEGIN; SELECT * FROM private_table; COMMIT;';
2015-09-08 00:09:42 +08:00
assert.response(server, createGetRequest(sql), RESPONSE_OK, tableNamesInCacheChannelHeader([
2015-09-08 00:09:42 +08:00
'public.private_table',
'public.untitle_table_4'
], done));
});
2015-09-08 00:09:42 +08:00
2019-12-24 01:19:08 +08:00
it('survives partial transactions', function (done) {
var sql = 'BEGIN; SELECT * FROM untitle_table_4';
2015-09-08 00:09:42 +08:00
assert.response(server, createGetRequest(sql), RESPONSE_OK, tableNamesInCacheChannelHeader([
2015-09-08 00:09:42 +08:00
'public.untitle_table_4'
], done));
});
2019-12-24 01:19:08 +08:00
it('should not add header for functions', function (done) {
var sql = "SELECT format('%s', 'wadus')";
2019-12-24 01:19:08 +08:00
assert.response(server, createGetRequest(sql), RESPONSE_OK, function (err, res) {
2019-12-26 21:51:09 +08:00
assert.ifError(err);
assert.ok(!Object.prototype.hasOwnProperty.call(res.headers, 'x-cache-channel'), res.headers['x-cache-channel']);
done();
});
});
2019-12-24 01:19:08 +08:00
it('should not add header for CDB_QueryTables', function (done) {
var sql = "SELECT CDB_QueryTablesText('select * from untitle_table_4')";
2019-12-24 01:19:08 +08:00
assert.response(server, createGetRequest(sql), RESPONSE_OK, function (err, res) {
2019-12-26 21:51:09 +08:00
assert.ifError(err);
assert.ok(!Object.prototype.hasOwnProperty.call(res.headers, 'x-cache-channel'), res.headers['x-cache-channel']);
done();
});
});
2019-12-24 01:19:08 +08:00
it('should not add header for non table results', function (done) {
var sql = "SELECT 'wadus'::text";
2019-12-24 01:19:08 +08:00
assert.response(server, createGetRequest(sql), RESPONSE_OK, function (err, res) {
2019-12-26 21:51:09 +08:00
assert.ifError(err);
assert.ok(!Object.prototype.hasOwnProperty.call(res.headers, 'x-cache-channel'), res.headers['x-cache-channel']);
done();
});
});
});