UNPKG

maplibre-gl

Version:

BSD licensed community fork of mapbox-gl, a WebGL interactive maps library

85 lines (63 loc) 4.05 kB
import {beforeEach, test, expect} from 'vitest'; import {createMap, beforeMapTest} from '../../util/test/util'; import {fixedLngLat, fixedNum} from '../../../test/unit/lib/fixed'; beforeEach(() => { beforeMapTest(); global.fetch = null; }); test('Creating a map without style constrains invalid hash values to valid Mercator transform values', () => { const container = window.document.createElement('div'); Object.defineProperty(container, 'offsetWidth', {value: 512}); Object.defineProperty(container, 'offsetHeight', {value: 512}); const map = createMap({container, center: [-180, -90], zoom: -2}); expect(fixedLngLat(map.getCenter(), 4)).toEqual({lng: 180, lat: 0}); expect(fixedNum(map.getZoom(), 3)).toBe(-0.771); }); test('Creating a map without style keeps valid hash values as Mercator transform values', () => { const container = window.document.createElement('div'); Object.defineProperty(container, 'offsetWidth', {value: 512}); Object.defineProperty(container, 'offsetHeight', {value: 512}); const map = createMap({container, center: [15, 30], zoom: 3}); expect(fixedLngLat(map.getCenter(), 4)).toEqual({lng: 15, lat: 30}); expect(fixedNum(map.getZoom(), 3)).toBe(3); }); test('Creating a map with style but no projection uses Mercator transform constrains', () => { const container = window.document.createElement('div'); Object.defineProperty(container, 'offsetWidth', {value: 512}); Object.defineProperty(container, 'offsetHeight', {value: 512}); const map = createMap({container, center: [-180, -90], zoom: -2, style: {version: 8, sources: {}, layers: []}}); expect(fixedLngLat(map.getCenter(), 4)).toEqual({lng: 180, lat: 0}); expect(fixedNum(map.getZoom(), 3)).toBe(-0.771); }); test('Creating a map with style but no projection does not constrain valid values', () => { const container = window.document.createElement('div'); Object.defineProperty(container, 'offsetWidth', {value: 512}); Object.defineProperty(container, 'offsetHeight', {value: 512}); const map = createMap({container, center: [15, 30], zoom: 3, style: {version: 8, sources: {}, layers: []}}); expect(fixedLngLat(map.getCenter(), 4)).toEqual({lng: 15, lat: 30}); expect(fixedNum(map.getZoom(), 3)).toBe(3); }); test('Creating a map with style defining mercator projection uses Mercator transform constrains', () => { const container = window.document.createElement('div'); Object.defineProperty(container, 'offsetWidth', {value: 512}); Object.defineProperty(container, 'offsetHeight', {value: 512}); const map = createMap({container, center: [-180, -90], zoom: -2, style: {version: 8, sources: {}, layers: [], projection: {type: 'mercator'}}}); expect(fixedLngLat(map.getCenter(), 4)).toEqual({lng: 180, lat: 0}); expect(fixedNum(map.getZoom(), 3)).toBe(-0.771); }); test('Creating a map with style defining mercator projection does not constrain valid values', () => { const container = window.document.createElement('div'); Object.defineProperty(container, 'offsetWidth', {value: 512}); Object.defineProperty(container, 'offsetHeight', {value: 512}); const map = createMap({container, center: [15, 30], zoom: 3, style: {version: 8, sources: {}, layers: [], projection: {type: 'mercator'}}}); expect(fixedLngLat(map.getCenter(), 4)).toEqual({lng: 15, lat: 30}); expect(fixedNum(map.getZoom(), 3)).toBe(3); }); test('Creating a map with style defining globe projection uses Globe transform constrains', () => { const container = window.document.createElement('div'); Object.defineProperty(container, 'offsetWidth', {value: 512}); Object.defineProperty(container, 'offsetHeight', {value: 512}); const map = createMap({container, center: [65.7, -38.2], zoom: -2, style: {version: 8, sources: {}, layers: [], projection: {type: 'globe'}}}); expect(fixedLngLat(map.getCenter(), 4)).toEqual({lng: 65.7, lat: -38.2}); expect(fixedNum(map.getZoom(), 3)).toBe(-2); });