Merge pull request #6636 from fredj/scaleline_test

Add test for the metric unit displayed in the scaleline
This commit is contained in:
Frédéric Junod
2017-03-28 15:04:33 +02:00
committed by GitHub

View File

@@ -268,14 +268,29 @@ describe('ol.control.ScaleLine', function() {
var renderedHtmls;
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() {
currentZoom = 28;
currentZoom = 33;
renderedHtmls = {};
ctrl = new ol.control.ScaleLine();
ctrl = new ol.control.ScaleLine({
minWidth: 10
});
ctrl.setMap(map);
map.setView(new ol.View({
center: [0, 0],
zoom: currentZoom
zoom: currentZoom,
maxZoom: currentZoom
}));
mapView = map.getView();
map.renderSync();
@@ -296,6 +311,9 @@ describe('ol.control.ScaleLine', function() {
var currentHtml = ctrl.element_.innerHTML;
expect(currentHtml in renderedHtmls).to.be(false);
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() {