2023-05-15 13:55:28 +02:00

106 lines
2.9 KiB
JavaScript

describe('Path', () => {
let container, map;
beforeEach(() => {
container = container = createContainer();
map = L.map(container);
map.setView([0, 0], 0);
});
afterEach(() => {
removeMapContainer(map, container);
});
// The following two tests are skipped, as the ES6-ifycation of Leaflet
// means that L.Path is no longer visible.
describe('#bringToBack', () => {
it('is a no-op for layers not on a map', () => {
const path = L.polyline([[1, 2], [3, 4], [5, 6]]);
expect(path.bringToBack()).to.equal(path);
});
it('is a no-op for layers no longer in a LayerGroup', () => {
const group = L.layerGroup().addTo(map);
const path = L.polyline([[1, 2], [3, 4], [5, 6]]).addTo(group);
group.clearLayers();
expect(path.bringToBack()).to.equal(path);
});
});
describe('#bringToFront', () => {
it('is a no-op for layers not on a map', () => {
const path = L.polyline([[1, 2], [3, 4], [5, 6]]);
expect(path.bringToFront()).to.equal(path);
});
it('is a no-op for layers no longer in a LayerGroup', () => {
const group = L.layerGroup().addTo(map);
const path = L.polyline([[1, 2], [3, 4], [5, 6]]).addTo(group);
group.clearLayers();
expect(path.bringToFront()).to.equal(path);
});
});
describe('#events', () => {
it('fires click event', () => {
const spy = sinon.spy();
const layer = L.polygon([[1, 2], [3, 4], [5, 6]]).addTo(map);
layer.on('click', spy);
UIEventSimulator.fire('click', layer._path);
expect(spy.called).to.be.true;
});
it('propagates click event by default', () => {
const spy = sinon.spy();
const spy2 = sinon.spy();
const mapSpy = sinon.spy();
const layer = L.polygon([[1, 2], [3, 4], [5, 6]]).addTo(map);
layer.on('click', spy);
layer.on('click', spy2);
map.on('click', mapSpy);
UIEventSimulator.fire('click', layer._path);
expect(spy.called).to.be.true;
expect(spy2.called).to.be.true;
expect(mapSpy.called).to.be.true;
});
it('can add a layer while being inside a moveend handler', () => {
const zoneLayer = L.layerGroup();
let polygon;
map.addLayer(zoneLayer);
map.on('moveend', () => {
zoneLayer.clearLayers();
polygon = L.polygon([[1, 2], [3, 4], [5, 6]]);
zoneLayer.addLayer(polygon);
});
map.invalidateSize();
map.setView([1, 2], 12, {animate: false});
map.panBy([-260, 0], {animate: false});
expect(polygon._parts.length).to.equal(0);
map.panBy([260, 0], {animate: false});
expect(polygon._parts.length).to.equal(1);
});
it('it should return tolerance with stroke', () => {
const path = L.polyline([[1, 2], [3, 4], [5, 6]]);
path.addTo(map);
expect(path._clickTolerance()).to.equal(path.options.weight / 2);
});
it('it should return zero tolerance without stroke', () => {
const path = L.polyline([[1, 2], [3, 4], [5, 6]]);
path.addTo(map);
path.options.stroke = false;
expect(path._clickTolerance()).to.equal(0);
});
});
});