Windshaft-cartodb/test/acceptance/overviews-metadata-named-maps-test.js

298 lines
9.7 KiB
JavaScript
Raw Normal View History

'use strict';
var testHelper = require('../support/test-helper');
2016-04-01 00:36:50 +08:00
var assert = require('../support/assert');
2019-10-07 16:55:26 +08:00
var CartodbWindshaft = require('../../lib/server');
var serverOptions = require('../../lib/server-options');
2016-04-01 00:36:50 +08:00
2019-10-07 15:40:50 +08:00
var LayergroupToken = require('../../lib/models/layergroup-token');
2016-04-01 00:36:50 +08:00
var RedisPool = require('redis-mpool');
var step = require('step');
const MapStore = require('../support/map-store');
2016-04-01 00:36:50 +08:00
2019-10-22 01:07:24 +08:00
describe('overviews metadata for named maps', function () {
var server;
before(function () {
server = new CartodbWindshaft(serverOptions);
});
2016-04-01 00:36:50 +08:00
// configure redis pool instance to use in tests
var redisPool = new RedisPool(global.environment.redis);
var overviewsLayer = {
2016-04-01 00:36:50 +08:00
type: 'cartodb',
options: {
sql: 'SELECT * FROM test_table_overviews',
cartocss: '#layer { marker-fill: black; }',
cartocss_version: '2.3.0'
}
};
var nonOverviewsLayer = {
2016-04-01 00:36:50 +08:00
type: 'cartodb',
options: {
sql: 'SELECT * FROM test_table',
cartocss: '#layer { marker-fill: black; }',
cartocss_version: '2.3.0'
}
};
var keysToDelete;
2019-10-22 01:07:24 +08:00
beforeEach(function () {
2016-04-01 00:36:50 +08:00
keysToDelete = {};
});
2019-10-22 01:07:24 +08:00
afterEach(function (done) {
testHelper.deleteRedisKeys(keysToDelete, done);
2016-04-01 00:36:50 +08:00
});
var templateId = 'overviews-template-1';
var template = {
version: '0.0.1',
name: templateId,
auth: { method: 'open' },
2019-10-22 01:07:24 +08:00
layergroup: {
2016-04-01 00:36:50 +08:00
version: '1.0.0',
layers: [overviewsLayer, nonOverviewsLayer]
2016-04-01 00:36:50 +08:00
}
};
2019-10-22 01:07:24 +08:00
it('should add overviews data to layers', function (done) {
step(
2019-10-22 01:07:24 +08:00
function postTemplate () {
var next = this;
assert.response(server, {
url: '/api/v1/map/named?api_key=1234',
method: 'POST',
headers: { host: 'localhost', 'Content-Type': 'application/json' },
data: JSON.stringify(template)
}, {}, function (res, err) {
next(err, res);
});
},
2019-10-22 01:07:24 +08:00
function checkTemplate (err, res) {
assert.ifError(err);
var next = this;
assert.strictEqual(res.statusCode, 200);
assert.deepStrictEqual(JSON.parse(res.body), {
template_id: templateId
});
next(null);
},
2019-10-22 01:07:24 +08:00
function instantiateTemplate (err) {
assert.ifError(err);
var next = this;
assert.response(server, {
url: '/api/v1/map/named/' + templateId,
method: 'POST',
headers: {
host: 'localhost',
'Content-Type': 'application/json'
}
}, {},
2019-10-22 01:07:24 +08:00
function (res, err) {
return next(err, res);
});
},
2019-10-22 01:07:24 +08:00
function checkInstanciation (err, res) {
assert.ifError(err);
var next = this;
assert.strictEqual(res.statusCode, 200);
var parsedBody = JSON.parse(res.body);
keysToDelete['map_cfg|' + LayergroupToken.parse(parsedBody.layergroupid).token] = 0;
keysToDelete['user:localhost:mapviews:global'] = 5;
assert.ok(parsedBody.layergroupid);
assert.ok(parsedBody.last_updated);
next(null, parsedBody.layergroupid);
},
2019-10-22 01:07:24 +08:00
function checkMapconfig (err, layergroupId) {
assert.ifError(err);
var next = this;
const mapStore = new MapStore(redisPool);
2019-10-22 01:07:24 +08:00
mapStore.load(LayergroupToken.parse(layergroupId).token, function (err, mapConfig) {
assert.ifError(err);
assert.deepStrictEqual(nonOverviewsLayer, mapConfig._cfg.layers[1]);
assert.strictEqual(mapConfig._cfg.layers[0].type, 'cartodb');
assert.ok(mapConfig._cfg.layers[0].options.query_rewrite_data);
var expectedData = {
overviews: {
test_table_overviews: {
2019-10-22 01:07:24 +08:00
schema: 'public',
1: { table: '_vovw_1_test_table_overviews' },
2: { table: '_vovw_2_test_table_overviews' }
}
}
};
assert.deepStrictEqual(mapConfig._cfg.layers[0].options.query_rewrite_data, expectedData);
});
next(err);
},
2019-10-22 01:07:24 +08:00
function deleteTemplate (err) {
assert.ifError(err);
var next = this;
assert.response(server, {
url: '/api/v1/map/named/' + templateId + '?api_key=1234',
method: 'DELETE',
headers: { host: 'localhost' }
}, {}, function (res, err) {
next(err, res);
});
},
2019-10-22 01:07:24 +08:00
function checkDeleteTemplate (err, res) {
assert.ifError(err);
assert.strictEqual(res.statusCode, 204);
assert.ok(!res.body);
return null;
},
2019-10-22 01:07:24 +08:00
function finish (err) {
done(err);
}
);
2016-04-01 00:36:50 +08:00
});
2019-10-22 01:07:24 +08:00
describe('Overviews Flags', function () {
it('Overviews used', function (done) {
step(
2019-10-22 01:07:24 +08:00
function postTemplate () {
var next = this;
assert.response(server, {
url: '/api/v1/map/named?api_key=1234',
method: 'POST',
headers: { host: 'localhost', 'Content-Type': 'application/json' },
data: JSON.stringify(template)
}, {}, function (res, err) {
next(err, res);
});
},
2019-10-22 01:07:24 +08:00
function instantiateTemplate (err) {
assert.ifError(err);
var next = this;
assert.response(server, {
url: '/api/v1/map/named/' + templateId,
method: 'POST',
headers: {
host: 'localhost',
'Content-Type': 'application/json'
}
}, {},
2019-10-22 01:07:24 +08:00
function (res, err) {
return next(err, res);
});
},
2019-10-22 01:07:24 +08:00
function checkFlags (err, res) {
assert.ifError(err);
var next = this;
var parsedBody = JSON.parse(res.body);
keysToDelete['map_cfg|' + LayergroupToken.parse(parsedBody.layergroupid).token] = 0;
keysToDelete['user:localhost:mapviews:global'] = 5;
const headers = JSON.parse(res.headers['x-tiler-profiler']);
assert.ok(headers.overviewsAddedToMapconfig);
assert.strictEqual(headers.mapType, 'named');
next();
},
2019-10-22 01:07:24 +08:00
function finish (err) {
done(err);
}
);
});
2019-10-22 01:07:24 +08:00
it('Overviews NOT used', function (done) {
const nonOverviewsTemplateId = 'non-overviews-template';
var nonOverviewsTemplate = {
version: '0.0.1',
name: nonOverviewsTemplateId,
auth: { method: 'open' },
layergroup: {
version: '1.0.0',
layers: [nonOverviewsLayer]
}
};
step(
2019-10-22 01:07:24 +08:00
function postTemplate () {
var next = this;
assert.response(server, {
url: '/api/v1/map/named?api_key=1234',
method: 'POST',
headers: { host: 'localhost', 'Content-Type': 'application/json' },
data: JSON.stringify(nonOverviewsTemplate)
}, {}, function (res, err) {
next(err, res);
});
},
2019-10-22 01:07:24 +08:00
function instantiateTemplate (err) {
assert.ifError(err);
var next = this;
assert.response(server, {
url: '/api/v1/map/named/' + nonOverviewsTemplateId,
method: 'POST',
headers: {
host: 'localhost',
'Content-Type': 'application/json'
}
}, {},
2019-10-22 01:07:24 +08:00
function (res, err) {
return next(err, res);
});
},
2019-10-22 01:07:24 +08:00
function checkFlags (err, res) {
assert.ifError(err);
var next = this;
var parsedBody = JSON.parse(res.body);
keysToDelete['map_cfg|' + LayergroupToken.parse(parsedBody.layergroupid).token] = 0;
keysToDelete['user:localhost:mapviews:global'] = 5;
const headers = JSON.parse(res.headers['x-tiler-profiler']);
assert.strictEqual(headers.overviewsAddedToMapconfig, false);
assert.strictEqual(headers.mapType, 'named');
next();
},
2019-10-22 01:07:24 +08:00
function finish (err) {
done(err);
}
);
});
});
2016-04-01 00:36:50 +08:00
});