Windshaft-cartodb/test/acceptance/widgets/named-maps-test.js
2019-10-25 09:38:05 +02:00

253 lines
8.1 KiB
JavaScript

'use strict';
var assert = require('../../support/assert');
var step = require('step');
const { URL } = require('url');
var queue = require('queue-async');
var helper = require('../../support/test-helper');
var CartodbWindshaft = require('../../../lib/server');
var serverOptions = require('../../../lib/server-options');
var LayergroupToken = require('../../../lib/models/layergroup-token');
describe('named-maps widgets', function () {
var server;
before(function () {
server = new CartodbWindshaft(serverOptions);
});
var username = 'localhost';
var widgetsTemplateName = 'widgets-template';
var layergroupid;
var layergroup;
var keysToDelete;
beforeEach(function (done) {
keysToDelete = {};
var widgetsTemplate = {
version: '0.0.1',
name: widgetsTemplateName,
layergroup: {
version: '1.5.0',
layers: [
{
type: 'cartodb',
options: {
sql: 'select * from populated_places_simple_reduced_private',
cartocss: '#layer { marker-fill: blue; }',
cartocss_version: '2.3.0',
widgets: {
pop_max_formula_sum: {
type: 'formula',
options: {
column: 'pop_max',
operation: 'sum'
}
},
country_places_count: {
type: 'aggregation',
options: {
column: 'adm0_a3',
aggregation: 'count'
}
},
pop_max: {
type: 'histogram',
options: {
column: 'pop_max'
}
}
}
}
}
]
}
};
var template_params = {};
step(
function createTemplate () {
var next = this;
assert.response(
server,
{
url: '/api/v1/map/named?api_key=1234',
method: 'POST',
headers: {
host: username,
'Content-Type': 'application/json'
},
data: JSON.stringify(widgetsTemplate)
},
{
status: 200
},
function (res, err) {
next(err, res);
}
);
},
function instantiateTemplate (err, res) {
assert.ifError(err);
assert.deepStrictEqual(JSON.parse(res.body), { template_id: widgetsTemplateName });
var next = this;
assert.response(
server,
{
url: '/api/v1/map/named/' + widgetsTemplateName,
method: 'POST',
headers: {
host: username,
'Content-Type': 'application/json'
},
data: JSON.stringify(template_params)
},
{
status: 200
},
function (res) {
next(null, res);
}
);
},
function finish (err, res) {
assert.ifError(err);
layergroup = JSON.parse(res.body);
assert.ok(Object.prototype.hasOwnProperty.call(layergroup, 'layergroupid'), "Missing 'layergroupid' from: " + res.body);
layergroupid = layergroup.layergroupid;
keysToDelete['map_cfg|' + LayergroupToken.parse(layergroup.layergroupid).token] = 0;
keysToDelete['user:localhost:mapviews:global'] = 5;
return done();
}
);
});
afterEach(function (done) {
step(
function deleteTemplate (err) {
assert.ifError(err);
var next = this;
assert.response(
server,
{
url: '/api/v1/map/named/' + widgetsTemplateName + '?api_key=1234',
method: 'DELETE',
headers: {
host: username
}
},
{
status: 204
},
function (res, err) {
next(err, res);
}
);
},
function deleteRedisKeys (err) {
assert.ifError(err);
helper.deleteRedisKeys(keysToDelete, done);
}
);
});
function getWidget (widgetName, callback) {
assert.response(
server,
{
url: '/api/v1/map/' + layergroupid + '/0/widget/' + widgetName,
method: 'GET',
headers: {
host: username
}
},
{
status: 200
},
function (res, err) {
if (err) {
return callback(err);
}
var parsedBody = JSON.parse(res.body);
return callback(err, res, parsedBody);
}
);
}
it('should be able to retrieve widgets from all URLs', function (done) {
var widgetsPaths = layergroup.metadata.layers.reduce(function (paths, layer) {
var widgets = layer.widgets || {};
Object.keys(widgets).forEach(function (widget) {
paths.push(new URL(widgets[widget].url.http).pathname);
});
return paths;
}, []);
var widgetsQueue = queue(widgetsPaths.length);
widgetsPaths.forEach(function (path) {
widgetsQueue.defer(function (path, done) {
assert.response(
server,
{
url: path,
method: 'GET',
headers: {
host: username
}
},
{
status: 200
},
function (res, err) {
if (err) {
return done(err);
}
var parsedBody = JSON.parse(res.body);
return done(null, parsedBody);
}
);
}, path);
});
widgetsQueue.awaitAll(function (err, results) {
assert.strictEqual(results.length, 3);
done(err);
});
});
it('should retrieve aggregation', function (done) {
getWidget('country_places_count', function (err, response, aggregation) {
assert.ok(!err, err);
assert.strictEqual(aggregation.type, 'aggregation');
assert.strictEqual(aggregation.max, 769);
return done();
});
});
it('should retrieve histogram', function (done) {
getWidget('pop_max', function (err, response, histogram) {
assert.ok(!err, err);
assert.strictEqual(histogram.type, 'histogram');
assert.strictEqual(histogram.bin_width, 743250);
return done();
});
});
});