Files
openlayers/test/browser/spec/ol/source/TileJSON.test.js
2021-12-27 15:30:48 -07:00

245 lines
7.9 KiB
JavaScript

import Source from '../../../../../src/ol/source/Source.js';
import TileJSON from '../../../../../src/ol/source/TileJSON.js';
import {transformExtent} from '../../../../../src/ol/proj.js';
import {unByKey} from '../../../../../src/ol/Observable.js';
describe('ol/source/TileJSON', function () {
describe('constructor', function () {
it('returns a tileJSON source', function () {
const source = new TileJSON({
url: 'spec/ol/data/tilejson.json',
});
expect(source).to.be.a(Source);
expect(source).to.be.a(TileJSON);
});
});
describe('#getInterpolate()', function () {
it('is true by default', function () {
const source = new TileJSON({url: 'spec/ol/data/tilejson.json'});
expect(source.getInterpolate()).to.be(true);
});
it('is false if constructed with interpolate: false', function () {
const source = new TileJSON({
interpolate: false,
url: 'spec/ol/data/tilejson.json',
});
expect(source.getInterpolate()).to.be(false);
});
it('is false if constructed with imageSmoothing: false', function () {
const source = new TileJSON({
imageSmoothing: false,
url: 'spec/ol/data/tilejson.json',
});
expect(source.getInterpolate()).to.be(false);
});
});
describe('#getTileJSON', function () {
it('parses the tilejson file', function () {
const source = new TileJSON({
url: 'spec/ol/data/tilejson.json',
});
source.on('change', function () {
if (source.getState() === 'ready') {
const tileJSON = source.getTileJSON();
expect(tileJSON.name).to.eql('Geography Class');
expect(tileJSON.version).to.eql('1.0.0');
}
});
});
const tileJSON = {
attribution: 'TileMill',
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',
'https://c.tiles.mapbox.com/v3/mapbox.geography-class/{z}/{x}/{y}.png',
'https://d.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',
};
it('parses inline TileJSON', function () {
const source = new TileJSON({
tileJSON: tileJSON,
});
expect(source.getState()).to.be('ready');
expect(source.getTileUrlFunction()([0, 0, 0])).to.be(
'https://a.tiles.mapbox.com/v3/mapbox.geography-class/0/0/0.png'
);
expect(source.getTileUrlFunction()([1, 0, 0])).to.be(
'https://a.tiles.mapbox.com/v3/mapbox.geography-class/1/0/0.png'
);
expect(source.getTileUrlFunction()([1, 0, 1])).to.be(
'https://b.tiles.mapbox.com/v3/mapbox.geography-class/1/0/1.png'
);
expect(source.getTileUrlFunction()([1, 1, 0])).to.be(
'https://c.tiles.mapbox.com/v3/mapbox.geography-class/1/1/0.png'
);
expect(source.getTileUrlFunction()([1, 1, 1])).to.be(
'https://d.tiles.mapbox.com/v3/mapbox.geography-class/1/1/1.png'
);
});
it('returns attributions, but not when outside bounds', function () {
tileJSON.bounds = [
-10.764179999935878, 49.528423000201656, 1.9134115551745678,
61.3311509999582,
];
const source = new TileJSON({
tileJSON: tileJSON,
});
expect(source.getState()).to.be('ready');
const attributions = source.getAttributions();
expect(attributions).to.not.be(null);
expect(typeof attributions).to.be('function');
const frameState = {};
frameState.extent = transformExtent(
[1, 51, 2, 52],
'EPSG:4326',
'EPSG:3857'
);
expect(attributions(frameState)).to.eql(['TileMill']);
frameState.extent = transformExtent(
[2, 51, 3, 52],
'EPSG:4326',
'EPSG:3857'
);
expect(attributions(frameState)).to.be(null);
});
it('attributions bounds default to the tilegrid extent', function () {
delete tileJSON.bounds;
const source = new TileJSON({
tileJSON: tileJSON,
});
expect(source.getState()).to.be('ready');
const attributions = source.getAttributions();
expect(attributions).to.not.be(null);
expect(typeof attributions).to.be('function');
const frameState = {};
frameState.extent = transformExtent(
[1, 51, 2, 52],
'EPSG:4326',
'EPSG:3857'
);
expect(attributions(frameState)).to.eql(['TileMill']);
frameState.extent = transformExtent(
[2, 51, 3, 52],
'EPSG:4326',
'EPSG:3857'
);
expect(attributions(frameState)).to.eql(['TileMill']);
});
});
describe('#getState', function () {
it('returns error on HTTP 404', function () {
const source = new 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 () {
const source = new 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 () {
const source = new TileJSON({
url: '/',
});
source.on('change', function () {
expect(source.getState()).to.eql('error');
expect(source.getTileJSON()).to.eql(null);
});
});
});
describe('tileUrlFunction', function () {
let source, tileGrid;
beforeEach(function (done) {
source = new TileJSON({
url: 'spec/ol/data/tilejson.json',
});
const key = source.on('change', function () {
if (source.getState() === 'ready') {
unByKey(key);
tileGrid = source.getTileGrid();
done();
}
});
});
it('uses the correct tile coordinates', function () {
const coordinate = [829330.2064098881, 5933916.615134273];
const regex = /\/([0-9]*\/[0-9]*\/[0-9]*)\.png$/;
let 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');
});
});
});