fix handling of empty files
This commit is contained in:
@@ -376,14 +376,23 @@ MBTiles.prototype.getInfo = function(callback) {
|
|||||||
if (err) return callback(err);
|
if (err) return callback(err);
|
||||||
var range = parseInt(info.maxzoom, 10) - parseInt(info.minzoom, 10);
|
var range = parseInt(info.maxzoom, 10) - parseInt(info.minzoom, 10);
|
||||||
info.minzoom = parseInt(info.minzoom, 10);
|
info.minzoom = parseInt(info.minzoom, 10);
|
||||||
|
if (isNaN(info.minzoom) || typeof info.minzoom !== 'number') delete info.minzoom;
|
||||||
info.maxzoom = parseInt(info.maxzoom, 10);
|
info.maxzoom = parseInt(info.maxzoom, 10);
|
||||||
|
if (isNaN(info.maxzoom) || typeof info.maxzoom !== 'number') delete info.maxzoom;
|
||||||
|
|
||||||
info.bounds = _((info.bounds || '').split(',')).map(parseFloat);
|
info.bounds = _((info.bounds || '').split(',')).map(parseFloat);
|
||||||
|
if (info.bounds.length !== 4 || info.bounds[0] === null) delete info.bounds;
|
||||||
|
|
||||||
if (info.center) info.center = _((info.center).split(',')).map(parseFloat);
|
if (info.center) info.center = _((info.center).split(',')).map(parseFloat);
|
||||||
if (!info.center || info.center.length !== 3) info.center = [
|
if ((!info.center || info.center.length !== 3) && info.bounds) info.center = [
|
||||||
(info.bounds[2] - info.bounds[0]) / 2 + info.bounds[0],
|
(info.bounds[2] - info.bounds[0]) / 2 + info.bounds[0],
|
||||||
(info.bounds[3] - info.bounds[1]) / 2 + info.bounds[1],
|
(info.bounds[3] - info.bounds[1]) / 2 + info.bounds[1],
|
||||||
(range <= 1) ? info.maxzoom : Math.floor(range * 0.5) + info.minzoom
|
(range <= 1) ? info.maxzoom : Math.floor(range * 0.5) + info.minzoom
|
||||||
];
|
];
|
||||||
|
if (info.center && (info.center.length !== 3 || info.center[0] === null)) {
|
||||||
|
delete info.center;
|
||||||
|
}
|
||||||
|
|
||||||
return callback(null, info);
|
return callback(null, info);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|||||||
70
test/info.test.js
Normal file
70
test/info.test.js
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
process.env.NODE_ENV = 'test';
|
||||||
|
|
||||||
|
var fs = require('fs');
|
||||||
|
var Step = require('step');
|
||||||
|
var assert = require('assert');
|
||||||
|
var MBTiles = require('..');
|
||||||
|
|
||||||
|
var fixtures = {
|
||||||
|
plain_1: __dirname + '/fixtures/plain_1.mbtiles',
|
||||||
|
empty: __dirname + '/fixtures/empty.mbtiles'
|
||||||
|
};
|
||||||
|
|
||||||
|
try { fs.unlink(fixtures.empty); } catch (err) {}
|
||||||
|
|
||||||
|
|
||||||
|
exports['get metadata'] = function(beforeExit) {
|
||||||
|
var completed = false;
|
||||||
|
|
||||||
|
new MBTiles(fixtures.plain_1, function(err, mbtiles) {
|
||||||
|
if (err) throw err;
|
||||||
|
|
||||||
|
mbtiles.getInfo(function(err, data) {
|
||||||
|
completed = true;
|
||||||
|
if (err) throw err;
|
||||||
|
|
||||||
|
assert.deepEqual({
|
||||||
|
name: 'plain_1',
|
||||||
|
description: 'demo description',
|
||||||
|
version: '1.0.3',
|
||||||
|
scheme: 'tms',
|
||||||
|
minzoom: 0,
|
||||||
|
maxzoom: 4,
|
||||||
|
formatter: null,
|
||||||
|
center: [ 0, 7.500000001278025, 2 ],
|
||||||
|
bounds: [ -179.9999999749438, -69.99999999526695, 179.9999999749438, 84.99999999782301 ],
|
||||||
|
|
||||||
|
// These aren't part of TileJSON, but exist in an MBTiles file.
|
||||||
|
filesize: 561152,
|
||||||
|
type: 'baselayer',
|
||||||
|
id: 'plain_1',
|
||||||
|
basename: 'plain_1.mbtiles'
|
||||||
|
}, data);
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
beforeExit(function() {
|
||||||
|
assert.ok(completed);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
exports['get/put metadata from empty file'] = function(beforeExit) {
|
||||||
|
var completed = false;
|
||||||
|
|
||||||
|
new MBTiles(fixtures.empty, function(err, mbtiles) {
|
||||||
|
if (err) throw err;
|
||||||
|
|
||||||
|
mbtiles.getInfo(function(err, data) {
|
||||||
|
completed = true;
|
||||||
|
if (err) throw err;
|
||||||
|
|
||||||
|
assert.deepEqual({
|
||||||
|
basename: "empty.mbtiles",
|
||||||
|
filesize: 16384,
|
||||||
|
id: "empty",
|
||||||
|
scheme: "tms"
|
||||||
|
}, data);
|
||||||
|
})
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
@@ -15,39 +15,6 @@ var fixtures = {
|
|||||||
|
|
||||||
try { fs.unlink(fixtures.non_existent); } catch (err) {}
|
try { fs.unlink(fixtures.non_existent); } catch (err) {}
|
||||||
|
|
||||||
exports['get metadata'] = function(beforeExit) {
|
|
||||||
var completed = false;
|
|
||||||
|
|
||||||
new MBTiles(fixtures.plain_1, function(err, mbtiles) {
|
|
||||||
mbtiles.getInfo(function(err, data) {
|
|
||||||
completed = true;
|
|
||||||
if (err) throw err;
|
|
||||||
|
|
||||||
assert.deepEqual({
|
|
||||||
name: 'plain_1',
|
|
||||||
description: 'demo description',
|
|
||||||
version: '1.0.3',
|
|
||||||
scheme: 'tms',
|
|
||||||
minzoom: 0,
|
|
||||||
maxzoom: 4,
|
|
||||||
formatter: null,
|
|
||||||
center: [ 0, 7.500000001278025, 2 ],
|
|
||||||
bounds: [ -179.9999999749438, -69.99999999526695, 179.9999999749438, 84.99999999782301 ],
|
|
||||||
|
|
||||||
// These aren't part of TileJSON, but exist in an MBTiles file.
|
|
||||||
filesize: 561152,
|
|
||||||
type: 'baselayer',
|
|
||||||
id: 'plain_1',
|
|
||||||
basename: 'plain_1.mbtiles'
|
|
||||||
}, data);
|
|
||||||
})
|
|
||||||
});
|
|
||||||
|
|
||||||
beforeExit(function() {
|
|
||||||
assert.ok(completed);
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
function yieldsError(status, error, msg) {
|
function yieldsError(status, error, msg) {
|
||||||
return function(err) {
|
return function(err) {
|
||||||
assert.ok(err);
|
assert.ok(err);
|
||||||
|
|||||||
Reference in New Issue
Block a user