import TileState from '../../../src/ol/TileState.js'; import {defaultLoadFunction} from '../../../src/ol/source/VectorTile.js'; import VectorTileSource from '../../../src/ol/source/VectorTile.js'; import {listen, listenOnce, unlistenByKey} from '../../../src/ol/events.js'; import GeoJSON from '../../../src/ol/format/GeoJSON.js'; import {createXYZ} from '../../../src/ol/tilegrid.js'; import TileGrid from '../../../src/ol/tilegrid/TileGrid.js'; import {getKey} from '../../../src/ol/tilecoord.js'; import EventType from '../../../src/ol/events/EventType.js'; describe('ol.VectorRenderTile', function() { it('triggers "change" when previously failed source tiles are loaded', function(done) { let sourceTile; const source = new VectorTileSource({ format: new GeoJSON(), url: 'spec/ol/data/unavailable.json', tileLoadFunction: function(tile, url) { sourceTile = tile; defaultLoadFunction(tile, url); } }); const tile = source.getTile(0, 0, 0, 1, source.getProjection()); tile.load(); let calls = 0; listen(tile, 'change', function(e) { ++calls; if (calls === 1) { expect(tile.getState()).to.be(TileState.ERROR); setTimeout(function() { sourceTile.setState(TileState.LOADED); }, 0); } else if (calls === 2) { done(); } }); }); it('sets ERROR state when source tiles fail to load', function(done) { const source = new VectorTileSource({ format: new GeoJSON(), url: 'spec/ol/data/unavailable.json' }); const tile = source.getTile(0, 0, 0, 1, source.getProjection()); tile.load(); listen(tile, 'change', function(e) { expect(tile.getState()).to.be(TileState.ERROR); done(); }); }); it('sets EMPTY state when tile has only empty source tiles', function() { const source = new VectorTileSource({ format: new GeoJSON(), url: '' }); const tile = source.getTile(0, 0, 0, 1, source.getProjection()); tile.load(); expect(tile.getState()).to.be(TileState.EMPTY); }); it('only loads tiles within the source tileGrid\'s extent', function(done) { const url = 'spec/ol/data/point.json'; const source = new VectorTileSource({ projection: 'EPSG:4326', format: new GeoJSON(), tileGrid: new TileGrid({ resolutions: [0.02197265625, 0.010986328125, 0.0054931640625], origin: [-180, 90], extent: [-88, 35, -87, 36] }), tileUrlFunction: function(zxy) { return url; }, url: url }); const tile = source.getTile(0, 0, 0, 1, source.getProjection()); tile.load(); const key = listen(tile, EventType.CHANGE, function() { if (tile.getState() === TileState.LOADED) { unlistenByKey(key); const sourceTiles = source.getSourceTiles(1, source.getProjection(), tile); expect(sourceTiles.length).to.be(1); expect(sourceTiles[0].tileCoord).to.eql([0, 16, 9]); done(); } }); }); it('#dispose() while loading', function() { const source = new VectorTileSource({ format: new GeoJSON(), url: 'spec/ol/data/point.json', tileGrid: createXYZ() }); source.getTileGridForProjection = function() { return createXYZ({tileSize: 512}); }; const tile = source.getTile(0, 0, 0, 1, source.getProjection()); tile.load(); expect(tile.getState()).to.be(TileState.LOADING); tile.dispose(); expect(source.sourceTilesByTileKey_[getKey(tile)]).to.be(undefined); expect(tile.getState()).to.be(TileState.ABORT); }); it('#dispose() when source tiles are loaded', function(done) { const source = new VectorTileSource({ format: new GeoJSON(), url: 'spec/ol/data/point.json', tileGrid: createXYZ() }); source.getTileGridForProjection = function() { return createXYZ({tileSize: 512}); }; const tile = source.getTile(0, 0, 0, 1, source.getProjection()); tile.load(); listenOnce(tile, 'change', function() { expect(tile.getState()).to.be(TileState.LOADED); expect(tile.loadingSourceTiles).to.be(0); const sourceTiles = source.getSourceTiles(1, source.getProjection(), tile); expect(sourceTiles.length).to.be(4); for (let i = 0, ii = sourceTiles.length; i < ii; ++i) { expect(sourceTiles[i].consumers).to.be(1); } tile.dispose(); expect(tile.getState()).to.be(TileState.ABORT); for (let i = 0, ii = sourceTiles.length; i < ii; ++i) { expect(sourceTiles[i].consumers).to.be(0); expect(sourceTiles[i].getState()).to.be(TileState.ABORT); } done(); }); }); });