Leaflet/spec/suites/layer/vector/PathSpec.js
Per Liedman ed1a612e6f Make paths insensitive to the order of its map's moveend handlers (#4855)
* Make Paths always update after renderer updates

Close #4851

* Add test

* Add docs for update event

* Remove listener when layer is removed
2016-08-31 17:58:46 +03:00

82 lines
2.0 KiB
JavaScript

describe('Path', function () {
describe('#bringToBack', function () {
it('is a no-op for layers not on a map', function () {
var path = new L.Path();
expect(path.bringToBack()).to.equal(path);
});
});
describe('#bringToFront', function () {
it('is a no-op for layers not on a map', function () {
var path = new L.Path();
expect(path.bringToFront()).to.equal(path);
});
});
describe('#events', function () {
var c, map;
beforeEach(function () {
c = document.createElement('div');
c.style.width = '400px';
c.style.height = '400px';
map = new L.Map(c);
map.setView(new L.LatLng(0, 0), 0);
document.body.appendChild(c);
});
afterEach(function () {
document.body.removeChild(c);
});
it('fires click event', function () {
var spy = sinon.spy();
var layer = new L.Polygon([[1, 2], [3, 4], [5, 6]]).addTo(map);
layer.on('click', spy);
happen.click(layer._path);
expect(spy.called).to.be.ok();
});
it('propagates click event by default', function () {
var spy = sinon.spy();
var spy2 = sinon.spy();
var mapSpy = sinon.spy();
var layer = new L.Polygon([[1, 2], [3, 4], [5, 6]]).addTo(map);
layer.on('click', spy);
layer.on('click', spy2);
map.on('click', mapSpy);
happen.click(layer._path);
expect(spy.called).to.be.ok();
expect(spy2.called).to.be.ok();
expect(mapSpy.called).to.be.ok();
});
it('can add a layer while being inside a moveend handler', function (done) {
var zoneLayer = L.layerGroup();
var polygon;
map.addLayer(zoneLayer);
map.on('moveend', function () {
zoneLayer.clearLayers();
polygon = new L.Polygon([[1, 2], [3, 4], [5, 6]]);
zoneLayer.addLayer(polygon);
});
map.invalidateSize();
map.setView([1, 2], 12, {animate: false});
map.panBy([-260, 0]);
setTimeout(function () {
expect(polygon._parts.length).to.be(0);
map.panBy([260, 0]);
setTimeout(function () {
expect(polygon._parts.length).to.be(1);
done();
}, 300);
}, 300);
});
});
});