Analysis layers adapter skips analysis if there is only source nodes
This commit is contained in:
parent
ed84ed8475
commit
5bd30b6b5f
@ -1,4 +1,5 @@
|
||||
var queue = require('queue-async');
|
||||
var debug = require('debug')('windshaft:analysis');
|
||||
|
||||
var camshaft = require('camshaft');
|
||||
var dot = require('dot');
|
||||
@ -29,6 +30,32 @@ function layerQuery(query, columnNames) {
|
||||
return layerQueryTemplate({ _query: query, _columns: skipColumns(columnNames).join(', ') });
|
||||
}
|
||||
|
||||
function replaceSourceRootQueries(requestMapConfig) {
|
||||
var analysisToRemove = {};
|
||||
var analysisSourceRootsIds = requestMapConfig.analyses.reduce(function(sourceRootsIds, analysis, analysisIndex) {
|
||||
if (analysis.type === 'source' && !!analysis.id) {
|
||||
sourceRootsIds[analysis.id] = analysis;
|
||||
analysisToRemove[analysisIndex] = true;
|
||||
}
|
||||
return sourceRootsIds;
|
||||
}, {});
|
||||
|
||||
requestMapConfig.analyses = requestMapConfig.analyses.filter(function(analysis, index) {
|
||||
return !analysisToRemove.hasOwnProperty(index);
|
||||
});
|
||||
|
||||
requestMapConfig.layers = requestMapConfig.layers.map(function(layer) {
|
||||
var sourceId = layer.options && layer.options.source && layer.options.source.id;
|
||||
if (sourceId && analysisSourceRootsIds.hasOwnProperty(sourceId)) {
|
||||
delete layer.options.source;
|
||||
layer.options.sql = analysisSourceRootsIds[sourceId].params.query;
|
||||
}
|
||||
return layer;
|
||||
});
|
||||
|
||||
return requestMapConfig;
|
||||
}
|
||||
|
||||
function shouldAdaptLayers(requestMapConfig) {
|
||||
return Array.isArray(requestMapConfig.layers) &&
|
||||
Array.isArray(requestMapConfig.analyses) && requestMapConfig.analyses.length > 0;
|
||||
@ -36,7 +63,14 @@ function shouldAdaptLayers(requestMapConfig) {
|
||||
|
||||
AnalysisMapConfigAdapter.prototype.getLayers = function(analysisConfiguration, requestMapConfig, callback) {
|
||||
|
||||
debug('mapconfig input', JSON.stringify(requestMapConfig, null, 4));
|
||||
|
||||
if (Array.isArray(requestMapConfig.analyses)) {
|
||||
requestMapConfig = replaceSourceRootQueries(requestMapConfig);
|
||||
}
|
||||
|
||||
if (!shouldAdaptLayers(requestMapConfig)) {
|
||||
debug('mapconfig output', JSON.stringify(requestMapConfig, null, 4));
|
||||
return callback(null, requestMapConfig);
|
||||
}
|
||||
|
||||
@ -77,6 +111,8 @@ AnalysisMapConfigAdapter.prototype.getLayers = function(analysisConfiguration, r
|
||||
return layer;
|
||||
});
|
||||
|
||||
debug('mapconfig output', JSON.stringify(requestMapConfig, null, 4));
|
||||
|
||||
return callback(null, requestMapConfig);
|
||||
});
|
||||
};
|
||||
|
@ -53,11 +53,12 @@ describe('analysis-layers', function() {
|
||||
|
||||
var DEFAULT_MULTITYPE_STYLE = cartocss();
|
||||
|
||||
var TILE_ANALYSIS_TABLES = { z: 14, x: 8023, y: 6177 };
|
||||
var TILE_ANALYSIS_TABLES = { z: 0, x: 0, y: 0 };
|
||||
|
||||
var useCases = [
|
||||
{
|
||||
desc: 'basic source-id mapnik layer',
|
||||
fixture: 'basic-source-id-mapnik-layer.png',
|
||||
mapConfig: mapConfig(
|
||||
[
|
||||
{
|
||||
@ -67,8 +68,7 @@ describe('analysis-layers', function() {
|
||||
"id": "2570e105-7b37-40d2-bdf4-1af889598745"
|
||||
},
|
||||
"cartocss": DEFAULT_MULTITYPE_STYLE,
|
||||
"cartocss_version": "2.1.1",
|
||||
"interactivity": []
|
||||
"cartocss_version": "2.3.0"
|
||||
}
|
||||
}
|
||||
],
|
||||
@ -82,8 +82,44 @@ describe('analysis-layers', function() {
|
||||
}
|
||||
}
|
||||
]
|
||||
),
|
||||
tile: { z: 0, x: 0, y: 0 }
|
||||
)
|
||||
},
|
||||
|
||||
{
|
||||
desc: 'buffer over source',
|
||||
fixture: 'buffer-over-source.png',
|
||||
tile: { z: 7, x: 61, y: 47 },
|
||||
mapConfig: mapConfig(
|
||||
[
|
||||
{
|
||||
"type": "cartodb",
|
||||
"options": {
|
||||
"source": {
|
||||
"id": "HEAD"
|
||||
},
|
||||
"cartocss": DEFAULT_MULTITYPE_STYLE,
|
||||
"cartocss_version": "2.3.0"
|
||||
}
|
||||
}
|
||||
],
|
||||
{},
|
||||
[
|
||||
{
|
||||
"id": "HEAD",
|
||||
"type": "buffer",
|
||||
"params": {
|
||||
"source": {
|
||||
"id": "2570e105-7b37-40d2-bdf4-1af889598745",
|
||||
"type": "source",
|
||||
"params": {
|
||||
"query": "select * from populated_places_simple_reduced"
|
||||
}
|
||||
},
|
||||
"radio": 50000
|
||||
}
|
||||
}
|
||||
]
|
||||
)
|
||||
}
|
||||
];
|
||||
|
||||
@ -100,7 +136,7 @@ describe('analysis-layers', function() {
|
||||
// To generate images use:
|
||||
// image.save('/tmp/' + useCase.desc.replace(/\s/g, '-') + '.png');
|
||||
|
||||
var fixturePath = './test/fixtures/analysis/basic-source-id-mapnik-layer.png';
|
||||
var fixturePath = './test/fixtures/analysis/' + useCase.fixture;
|
||||
assert.imageIsSimilarToFile(image, fixturePath, IMAGE_TOLERANCE_PER_MIL, function(err) {
|
||||
assert.ok(!err, err);
|
||||
|
||||
@ -110,12 +146,27 @@ describe('analysis-layers', function() {
|
||||
});
|
||||
});
|
||||
|
||||
it('should fail for non-authenticated requests', function(done) {
|
||||
it('should NOT fail for non-authenticated requests when it is just source', function(done) {
|
||||
var useCase = useCases[0];
|
||||
|
||||
// No API key here
|
||||
var testClient = new TestClient(useCase.mapConfig);
|
||||
|
||||
testClient.getLayergroup(function(err, layergroupResult) {
|
||||
assert.ok(!err, err);
|
||||
|
||||
assert.equal(layergroupResult.metadata.layers.length, 1);
|
||||
|
||||
testClient.drain(done);
|
||||
});
|
||||
});
|
||||
|
||||
it('should fail for non-authenticated requests that has a node other than "source"', function(done) {
|
||||
var useCase = useCases[1];
|
||||
|
||||
// No API key here
|
||||
var testClient = new TestClient(useCase.mapConfig);
|
||||
|
||||
var PERMISSION_DENIED_RESPONSE = {
|
||||
status: 403,
|
||||
headers: {
|
||||
@ -128,7 +179,7 @@ describe('analysis-layers', function() {
|
||||
|
||||
assert.deepEqual(layergroupResult.errors, ["permission denied for relation cdb_tablemetadata"]);
|
||||
|
||||
done();
|
||||
testClient.drain(done);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
BIN
test/fixtures/analysis/buffer-over-source.png
vendored
Normal file
BIN
test/fixtures/analysis/buffer-over-source.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 9.2 KiB |
Loading…
Reference in New Issue
Block a user