703ae02aa8
* WIP ES6 modules & rollup * WIP ES6 modules & rollup 2 * WIP ES6 modules & rollup 3 * WIP ES6 modules Browser * WIP ES6 module fixes * WIP ES6 modules: simpler browser exports * WIP ES6: refactor CRS/Projection modules, CRS obj -> CRS.Base * get rid of unnecessary index.js * WIP ES6 modules, dom events and stuff * Make linter happy, rollup to dist/ * revert to CRS namespace/class for now * WIP rollup: export more stuff * export controls * rollup: export Layer * rollup: export DomEvent * rollup: export more layer types * rollup: export Popup/Tooltip * WIP: ES6-ify marker, icon, domutil, draggable. * ES6-ify gridlayer, tilelayer. * ES6-ify: Tweak imports-exports, code is now runnable!! * ES6-ify: Fix scope in some DomUtils * ES6-ify: Path, fix Popup * ES6-ify: Lint & cleanup * ES6-ify map handlers, more linting * ES6-ify: Icon.Default namespacing * ES6-ify: Renderers, CircleMarker * ES6-ify: Circle, Polyline, LineUtil * ES6-ify: Polygon, Rectangle, LineUtil, PolyUtil, linting * ES6-ify: SVG.VML * ES6-ify: DomEvent.Pointer, DomEvent.DoubleTap * ES6-ify: Linting, make Karma play nice with Rollup * ES6-ify: More work on fixing bits breaking some unit tests. * ES6-ify: rollup the version number, fiddled with build scripts * ES6-ify: Fiddle with test scripts * ES6-ify: cleanup (refs to global L, imports from (DOM)Util), prevent cyclic loop on Map imports * ES6-ify: More cleanup of (DOM)Util/Browser/DomEvent imports * ES6ify: Use rollup's "legacy" option for ES3 (IE8) builds * ES6-ify: Clean up build scripts, fix CONTRIBUTING.md instructions * Typo * ES6-ify: minor fixes and lefovers after rebasing on top of 1.0.2 * ES6-ify: upgrade to rollup 0.38 for proper IE8 builds, fix L.SVG.VML * Make linter happy. * ES6: Fixing typos and sxrew-ups after big rebase * Fix symlink for debugging scripts * ES6: Cleanup old build scripts * ES6-ify: Update build system to include git rev in L.version * ES6-ify: re-enable unit tests replacing L.Path with L.Polyline * Export Path * ES6ify: cleanup old banner file * ES6-ify: whitespace in var declarations * ES6-ify: Export toTransformation as L.transformation * ES6-ify: cleanup L.transform exports * ES6-ify: "import Util" in Transformation and SVG.VML
85 lines
2.2 KiB
JavaScript
85 lines
2.2 KiB
JavaScript
describe('Path', function () {
|
|
|
|
// The following two tests are skipped, as the ES6-ifycation of Leaflet
|
|
// means that L.Path is no longer visible.
|
|
describe('#bringToBack', function () {
|
|
it('is a no-op for layers not on a map', function () {
|
|
var path = new L.Polyline([[1, 2], [3, 4], [5, 6]]);
|
|
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.Polyline([[1, 2], [3, 4], [5, 6]]);
|
|
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);
|
|
});
|
|
|
|
});
|
|
});
|