164 lines
5.0 KiB
JavaScript
164 lines
5.0 KiB
JavaScript
import Source from '../../../../src/ol/source/Source.js';
|
|
import _ol_source_TileJSON_ from '../../../../src/ol/source/TileJSON.js';
|
|
import _ol_Observable_ from '../../../../src/ol/Observable.js';
|
|
|
|
|
|
describe('ol.source.TileJSON', function() {
|
|
|
|
describe('constructor', function() {
|
|
|
|
it('returns a tileJSON source', function() {
|
|
var source = new _ol_source_TileJSON_({
|
|
url: 'spec/ol/data/tilejson.json'
|
|
});
|
|
expect(source).to.be.a(Source);
|
|
expect(source).to.be.a(_ol_source_TileJSON_);
|
|
});
|
|
});
|
|
|
|
describe('#getTileJSON', function() {
|
|
|
|
it('parses the tilejson file', function() {
|
|
var source = new _ol_source_TileJSON_({
|
|
url: 'spec/ol/data/tilejson.json'
|
|
});
|
|
source.on('change', function() {
|
|
if (source.getState() === 'ready') {
|
|
var tileJSON = source.getTileJSON();
|
|
expect(tileJSON.name).to.eql('Geography Class');
|
|
expect(tileJSON.version).to.eql('1.0.0');
|
|
}
|
|
});
|
|
});
|
|
|
|
it ('parses inline TileJSON', function() {
|
|
var tileJSON = {
|
|
bounds: [
|
|
-180,
|
|
-85.05112877980659,
|
|
180,
|
|
85.05112877980659
|
|
],
|
|
center: [
|
|
0,
|
|
0,
|
|
4
|
|
],
|
|
created: 1322764050886,
|
|
description: 'One of the example maps that comes with TileMill - a bright & colorful world map that blends retro and high-tech with its folded paper texture and interactive flag tooltips. ',
|
|
download: 'https://a.tiles.mapbox.com/v3/mapbox.geography-class.mbtiles',
|
|
embed: 'https://a.tiles.mapbox.com/v3/mapbox.geography-class.html',
|
|
id: 'mapbox.geography-class',
|
|
mapbox_logo: true,
|
|
maxzoom: 8,
|
|
minzoom: 0,
|
|
name: 'Geography Class',
|
|
private: false,
|
|
scheme: 'xyz',
|
|
tilejson: '2.2.0',
|
|
tiles: [
|
|
'https://a.tiles.mapbox.com/v3/mapbox.geography-class/{z}/{x}/{y}.png',
|
|
'https://b.tiles.mapbox.com/v3/mapbox.geography-class/{z}/{x}/{y}.png'
|
|
],
|
|
version: '1.0.0',
|
|
webpage: 'https://a.tiles.mapbox.com/v3/mapbox.geography-class/page.html'
|
|
};
|
|
var source = new _ol_source_TileJSON_({
|
|
tileJSON: tileJSON
|
|
});
|
|
expect(source.getState()).to.be('ready');
|
|
expect(source.getTileUrlFunction()([0, 0, -1])).to.be('https://b.tiles.mapbox.com/v3/mapbox.geography-class/0/0/0.png');
|
|
});
|
|
});
|
|
|
|
describe('#getState', function() {
|
|
|
|
it('returns error on HTTP 404', function() {
|
|
var source = new _ol_source_TileJSON_({
|
|
url: 'invalid.jsonp'
|
|
});
|
|
source.on('change', function() {
|
|
expect(source.getState()).to.eql('error');
|
|
expect(source.getTileJSON()).to.eql(null);
|
|
});
|
|
});
|
|
|
|
it('returns error on CORS issues', function() {
|
|
var source = new _ol_source_TileJSON_({
|
|
url: 'http://example.com'
|
|
});
|
|
source.on('change', function() {
|
|
expect(source.getState()).to.eql('error');
|
|
expect(source.getTileJSON()).to.eql(null);
|
|
});
|
|
});
|
|
|
|
it('returns error on JSON parsing issues', function() {
|
|
var source = new _ol_source_TileJSON_({
|
|
url: '/'
|
|
});
|
|
source.on('change', function() {
|
|
expect(source.getState()).to.eql('error');
|
|
expect(source.getTileJSON()).to.eql(null);
|
|
});
|
|
});
|
|
|
|
});
|
|
|
|
describe('tileUrlFunction', function() {
|
|
|
|
var source, tileGrid;
|
|
|
|
beforeEach(function(done) {
|
|
source = new _ol_source_TileJSON_({
|
|
url: 'spec/ol/data/tilejson.json'
|
|
});
|
|
var key = source.on('change', function() {
|
|
if (source.getState() === 'ready') {
|
|
_ol_Observable_.unByKey(key);
|
|
tileGrid = source.getTileGrid();
|
|
done();
|
|
}
|
|
});
|
|
});
|
|
|
|
it('uses the correct tile coordinates', function() {
|
|
|
|
var coordinate = [829330.2064098881, 5933916.615134273];
|
|
var regex = /\/([0-9]*\/[0-9]*\/[0-9]*)\.png$/;
|
|
var tileUrl;
|
|
|
|
tileUrl = source.tileUrlFunction(
|
|
tileGrid.getTileCoordForCoordAndZ(coordinate, 0));
|
|
expect(tileUrl.match(regex)[1]).to.eql('0/0/0');
|
|
|
|
tileUrl = source.tileUrlFunction(
|
|
tileGrid.getTileCoordForCoordAndZ(coordinate, 1));
|
|
expect(tileUrl.match(regex)[1]).to.eql('1/1/0');
|
|
|
|
tileUrl = source.tileUrlFunction(
|
|
tileGrid.getTileCoordForCoordAndZ(coordinate, 2));
|
|
expect(tileUrl.match(regex)[1]).to.eql('2/2/1');
|
|
|
|
tileUrl = source.tileUrlFunction(
|
|
tileGrid.getTileCoordForCoordAndZ(coordinate, 3));
|
|
expect(tileUrl.match(regex)[1]).to.eql('3/4/2');
|
|
|
|
tileUrl = source.tileUrlFunction(
|
|
tileGrid.getTileCoordForCoordAndZ(coordinate, 4));
|
|
expect(tileUrl.match(regex)[1]).to.eql('4/8/5');
|
|
|
|
tileUrl = source.tileUrlFunction(
|
|
tileGrid.getTileCoordForCoordAndZ(coordinate, 5));
|
|
expect(tileUrl.match(regex)[1]).to.eql('5/16/11');
|
|
|
|
tileUrl = source.tileUrlFunction(
|
|
tileGrid.getTileCoordForCoordAndZ(coordinate, 6));
|
|
expect(tileUrl.match(regex)[1]).to.eql('6/33/22');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|