[OpenLayers-Commits] r5622 - in trunk/openlayers: lib/OpenLayers/Layer tests/Layer
commits at openlayers.org
commits at openlayers.org
Wed Jan 2 10:23:45 EST 2008
Author: crschmidt
Date: 2008-01-02 10:23:45 -0500 (Wed, 02 Jan 2008)
New Revision: 5622
Modified:
trunk/openlayers/lib/OpenLayers/Layer/MapServer.js
trunk/openlayers/tests/Layer/test_MapServer.html
Log:
Make MapServer multi-url selection deterministic. (Closes #803)
Modified: trunk/openlayers/lib/OpenLayers/Layer/MapServer.js
===================================================================
--- trunk/openlayers/lib/OpenLayers/Layer/MapServer.js 2008-01-01 23:45:45 UTC (rev 5621)
+++ trunk/openlayers/lib/OpenLayers/Layer/MapServer.js 2008-01-02 15:23:45 UTC (rev 5622)
@@ -144,19 +144,19 @@
// use layer's url unless altUrl passed in
var url = (altUrl == null) ? this.url : altUrl;
- // if url is not a string, it should be an array of strings,
- // in which case we will randomly select one of them in order
- // to evenly distribute requests to different urls.
- if (typeof url == "object") {
- url = url[Math.floor(Math.random()*url.length)];
- }
- // requestString always starts with url
- var requestString = url;
-
// create a new params hashtable with all the layer params and the
// new params together. then convert to string
var allParams = OpenLayers.Util.extend({}, this.params);
allParams = OpenLayers.Util.extend(allParams, newParams);
+ var paramsString = OpenLayers.Util.getParameterString(allParams);
+
+ // if url is not a string, it should be an array of strings,
+ // in which case we will deterministically select one of them in
+ // order to evenly distribute requests to different urls.
+ if (url instanceof Array) {
+ url = this.selectUrl(paramsString, url);
+ }
+
// ignore parameters that are already in the url search string
var urlParams = OpenLayers.Util.upperCaseObject(
OpenLayers.Util.getParameters(url));
@@ -165,8 +165,11 @@
delete allParams[key];
}
}
- var paramsString = OpenLayers.Util.getParameterString(allParams);
+ paramsString = OpenLayers.Util.getParameterString(allParams);
+ // requestString always starts with url
+ var requestString = url;
+
// MapServer needs '+' seperating things like bounds/height/width.
// Since typically this is URL encoded, we use a slight hack: we
// depend on the list-like functionality of getParameterString to
Modified: trunk/openlayers/tests/Layer/test_MapServer.html
===================================================================
--- trunk/openlayers/tests/Layer/test_MapServer.html 2008-01-01 23:45:45 UTC (rev 5621)
+++ trunk/openlayers/tests/Layer/test_MapServer.html 2008-01-02 15:23:45 UTC (rev 5622)
@@ -156,9 +156,7 @@
}
function test_07_Layer_MapServer_getFullRequestString (t) {
-
-
- t.plan( 1 );
+ t.plan( 3 );
var map = new OpenLayers.Map('map');
tUrl = "http://labs.metacarta.com/cgi-bin/mapserv";
tParams = { layers: 'basic',
@@ -178,6 +176,23 @@
t.eq(str, sStr , "getFullRequestString() works");
map.destroy();
+
+ tUrl = ["http://octo.metacarta.com/cgi-bin/mapserv","http://labs.metacarta.com/cgi-bin/mapserv"];
+ layer = new OpenLayers.Layer.MapServer(name, tUrl, tParams, null);
+ str = layer.getFullRequestString({'c':'d'});
+ t.eq(str, tUrl[1] + '?' + OpenLayers.Util.getParameterString(OpenLayers.Util.extend(tParams,{'c':'d'})), "getFullRequestString() works for list of two urls and is deterministic");
+ layer.destroy();
+ var tParams = {
+ layers: 'basic',
+ format: 'png',
+ mode: 'map',
+ map_imagetype: 'png'
+ };
+ tUrl = ["http://octo.metacarta.com/cgi-bin/mapserv","http://labs.metacarta.com/cgi-bin/mapserv"];
+ layer = new OpenLayers.Layer.MapServer(name, tUrl, tParams, null);
+ str = layer.getFullRequestString({'a':'b'});
+ t.eq(str, tUrl[0] + '?' + OpenLayers.Util.getParameterString(OpenLayers.Util.extend(tParams,{'a':'b'})), "getFullRequestString() works for list of two urls and is deterministic");
+ layer.destroy();
}
More information about the Commits
mailing list