maplibre-gl
Version:
BSD licensed community fork of mapbox-gl, a WebGL interactive maps library
154 lines (137 loc) • 5.61 kB
text/typescript
import {fakeServer, FakeServer} from 'nise';
import RasterDEMTileSource from './raster_dem_tile_source';
import {OverscaledTileID} from './tile_id';
import {RequestManager} from '../util/request_manager';
import Dispatcher from '../util/dispatcher';
import Tile from './tile';
function createSource(options, transformCallback?) {
const source = new RasterDEMTileSource('id', options, {send() {}} as any as Dispatcher, options.eventedParent);
source.onAdd({
transform: {angle: 0, pitch: 0, showCollisionBoxes: false},
_getMapId: () => 1,
_requestManager: new RequestManager(transformCallback),
getPixelRatio() { return 1; }
} as any);
source.on('error', (e) => {
throw e.error;
});
return source;
}
describe('RasterTileSource', () => {
let server: FakeServer;
beforeEach(() => {
global.fetch = null;
server = fakeServer.create();
});
afterEach(() => {
server.restore();
});
test('transforms request for TileJSON URL', done => {
server.respondWith('/source.json', JSON.stringify({
minzoom: 0,
maxzoom: 22,
attribution: 'MapLibre',
tiles: ['http://example.com/{z}/{x}/{y}.pngraw'],
bounds: [-47, -7, -45, -5]
}));
const transformSpy = jest.fn().mockImplementation((url) => {
return {url};
});
createSource({url: '/source.json'}, transformSpy);
server.respond();
expect(transformSpy.mock.calls[0][0]).toBe('/source.json');
expect(transformSpy.mock.calls[0][1]).toBe('Source');
done();
});
test('transforms tile urls before requesting', done => {
server.respondWith('/source.json', JSON.stringify({
minzoom: 0,
maxzoom: 22,
attribution: 'MapLibre',
tiles: ['http://example.com/{z}/{x}/{y}.png'],
bounds: [-47, -7, -45, -5]
}));
const source = createSource({url: '/source.json'});
const transformSpy = jest.spyOn(source.map._requestManager, 'transformRequest');
source.on('data', (e) => {
if (e.sourceDataType === 'metadata') {
const tile = {
tileID: new OverscaledTileID(10, 0, 10, 5, 5),
state: 'loading',
loadVectorData () {},
setExpiryData() {}
} as any as Tile;
source.loadTile(tile, () => {});
expect(transformSpy).toHaveBeenCalledTimes(1);
expect(transformSpy.mock.calls[0][0]).toBe('http://example.com/10/5/5.png');
expect(transformSpy.mock.calls[0][1]).toBe('Tile');
done();
}
});
server.respond();
});
test('populates neighboringTiles', done => {
server.respondWith('/source.json', JSON.stringify({
minzoom: 0,
maxzoom: 22,
attribution: 'MapLibre',
tiles: ['http://example.com/{z}/{x}/{y}.png']
}));
const source = createSource({url: '/source.json'});
source.on('data', (e) => {
if (e.sourceDataType === 'metadata') {
const tile = {
tileID: new OverscaledTileID(10, 0, 10, 5, 5),
state: 'loading',
loadVectorData () {},
setExpiryData() {}
} as any as Tile;
source.loadTile(tile, () => {});
expect(Object.keys(tile.neighboringTiles)).toEqual([
new OverscaledTileID(10, 0, 10, 4, 5).key,
new OverscaledTileID(10, 0, 10, 6, 5).key,
new OverscaledTileID(10, 0, 10, 4, 4).key,
new OverscaledTileID(10, 0, 10, 5, 4).key,
new OverscaledTileID(10, 0, 10, 6, 4).key,
new OverscaledTileID(10, 0, 10, 4, 6).key,
new OverscaledTileID(10, 0, 10, 5, 6).key,
new OverscaledTileID(10, 0, 10, 6, 6).key
]);
done();
}
});
server.respond();
});
test('populates neighboringTiles with wrapped tiles', done => {
server.respondWith('/source.json', JSON.stringify({
minzoom: 0,
maxzoom: 22,
attribution: 'MapLibre',
tiles: ['http://example.com/{z}/{x}/{y}.png']
}));
const source = createSource({url: '/source.json'});
source.on('data', (e) => {
if (e.sourceDataType === 'metadata') {
const tile = {
tileID: new OverscaledTileID(5, 0, 5, 31, 5),
state: 'loading',
loadVectorData () {},
setExpiryData() {}
} as any as Tile;
source.loadTile(tile, () => {});
expect(Object.keys(tile.neighboringTiles)).toEqual([
new OverscaledTileID(5, 0, 5, 30, 6).key,
new OverscaledTileID(5, 0, 5, 31, 6).key,
new OverscaledTileID(5, 0, 5, 30, 5).key,
new OverscaledTileID(5, 1, 5, 0, 5).key,
new OverscaledTileID(5, 0, 5, 30, 4).key,
new OverscaledTileID(5, 0, 5, 31, 4).key,
new OverscaledTileID(5, 1, 5, 0, 4).key,
new OverscaledTileID(5, 1, 5, 0, 6).key
]);
done();
}
});
server.respond();
});
});