Add test for the metric unit displayed in the scaleline

This commit is contained in:
Frederic Junod
2017-03-24 14:59:03 +01:00
parent b4642903fd
commit 57d39109e3

View File

@@ -268,14 +268,29 @@ describe('ol.control.ScaleLine', function() {
var renderedHtmls; var renderedHtmls;
var mapView; var mapView;
var getMetricUnit = function(zoom) {
if (zoom > 30) {
return 'μm';
} else if (zoom > 20) {
return 'mm';
} else if (zoom > 10) {
return 'm';
} else {
return 'km';
}
};
beforeEach(function() { beforeEach(function() {
currentZoom = 28; currentZoom = 33;
renderedHtmls = {}; renderedHtmls = {};
ctrl = new ol.control.ScaleLine(); ctrl = new ol.control.ScaleLine({
minWidth: 10
});
ctrl.setMap(map); ctrl.setMap(map);
map.setView(new ol.View({ map.setView(new ol.View({
center: [0, 0], center: [0, 0],
zoom: currentZoom zoom: currentZoom,
maxZoom: currentZoom
})); }));
mapView = map.getView(); mapView = map.getView();
map.renderSync(); map.renderSync();
@@ -296,6 +311,9 @@ describe('ol.control.ScaleLine', function() {
var currentHtml = ctrl.element_.innerHTML; var currentHtml = ctrl.element_.innerHTML;
expect(currentHtml in renderedHtmls).to.be(false); expect(currentHtml in renderedHtmls).to.be(false);
renderedHtmls[currentHtml] = true; renderedHtmls[currentHtml] = true;
var unit = ctrl.innerElement_.textContent.match(/\d+ (.+)/)[1];
expect(unit).to.eql(getMetricUnit(currentZoom));
} }
}); });
it('degrees: is rendered differently for different zoomlevels', function() { it('degrees: is rendered differently for different zoomlevels', function() {