import * as React from 'react'; import GeoJSONLayer from '../geojson-layer'; import { getMapMock, mountWithMap } from '../jest/util'; describe('GeoJSONLayer', () => { const fillPaint = { 'fill-color': '#001122' }; const data = { type: 'FeatureCollection', features: [] }; it('Should call addLayer with provided layerOptions', () => { const mapMock = getMapMock(); const GeoJSONLayerComp = ( ); mountWithMap(GeoJSONLayerComp, mapMock); const addFillLayerCall = mapMock.addLayer.mock.calls.find(([call]) => call.id.endsWith('-fill') ); expect(addFillLayerCall).toEqual([ { id: 'geojson-1-fill', source: 'geojson-1', type: 'fill', layout: { visibility: 'visible' }, minzoom: 13, paint: { 'fill-color': '#001122' } }, undefined ]); }); it('Should call addLayer when no layerOptions provided', () => { const GeoJSONLayerComp = ; const mapMock = getMapMock(); mountWithMap(GeoJSONLayerComp, mapMock); const addFillLayerCall = mapMock.addLayer.mock.calls.find(([call]) => call.id.endsWith('-fill') ); expect(addFillLayerCall).toEqual([ { id: 'geojson-2-fill', source: 'geojson-2', type: 'fill', layout: { visibility: 'visible' }, paint: { 'fill-color': '#001122' } }, undefined ]); }); it('Should start listening onClick mouse event', () => { const GeoJSONLayerComp = ( ); const mapMock = getMapMock(); mountWithMap(GeoJSONLayerComp, mapMock); expect(mapMock.on.mock.calls[0][0]).toEqual('click'); expect(mapMock.on.mock.calls[0][1]).toEqual('geojson-3-fill'); }); });