SelectFeature.html 7.97 KB
<html>
<head>
    <script src="../../lib/OpenLayers.js"></script>
    <script type="text/javascript">
    function test_Control_SelectFeature_constructor(t) {
        t.plan(2);
        var options = {
//            geometryTypes: "foo"
        };
        var layer = "bar";
        var control = new OpenLayers.Control.SelectFeature(layer, options);
        t.ok(control instanceof OpenLayers.Control.SelectFeature,
             "new OpenLayers.Control.SelectFeature returns an instance");
        t.eq(control.layer, "bar",
             "constructor sets layer correctly");        
//        t.eq(control.handlers.feature.geometryTypes, "foo",
//             "constructor sets options correctly on feature handler");
    }
    
    function test_Control_SelectFeature_destroy(t) {
        t.plan(2);
        var map = new OpenLayers.Map("map");
        var layer = new OpenLayers.Layer.Vector();
        map.addLayer(layer);
        var control = new OpenLayers.Control.SelectFeature(layer, {box: true});
        control.handlers.feature.deactivate = function() {
            t.ok(true,
                 "control.deactivate calls deactivate on feature handler");
        }
        control.handlers.box.deactivate = function() {
            t.ok(true,
                 "control.deactivate calls deactivate on box handler");
        }
// should nullify the layer property here
        control.destroy();
        
    }
    
    function test_Control_SelectFeature_select(t) {
        t.plan(2);
        var map = new OpenLayers.Map("map");
        var layer = new OpenLayers.Layer.Vector();
        map.addLayer(layer);
        var control = new OpenLayers.Control.SelectFeature(layer);
        var feature = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(0,0));
        layer.addFeatures(feature);
        layer.drawFeature = function(feature, style) {
            layer.styleMap.createSymbolizer(feature, style);
        }
        control.select(feature);
        t.eq(feature.renderIntent, "select", "render intent is set to select");
        control.unselect(feature);
        t.eq(feature.renderIntent, "default", "render intent is set back to default");
    }
    
    function test_Control_SelectFeature_clickFeature(t) {
        t.plan(4);
        // mock up layer
        var layer = {
            selectedFeatures: [],
            drawFeature: function() {},
            events: {
                triggerEvent: function() {}
            }
        };
        // mock up active control
        var control = new OpenLayers.Control.SelectFeature(layer);
        control.handlers.feature = {
            evt: {}
        };
        // mock up features
        var features = new Array(4);
        for(var i=0; i<features.length; ++i) {
            features[i] = {
                id: Math.random(),
                tested: 0,
                style: ""
            };
        }
        
        // test that onSelect gets called properly
        control.onSelect = function(feature) {
            feature.tested += 1;
            t.eq(feature, features[feature.index],
                 "onSelect called with proper feature (" + feature.index + ")");
            t.eq(feature.tested, feature.test,
                 "onSelect called only once for feature (" + feature.index + ")");
        }

        // test that onUnselect gets called properly
        control.onUnselect = function(feature) {
            feature.tested += 1;
            t.eq(feature, features[feature.index],
                 "onUnselect called with proper feature (" + feature.index + ")");
            t.eq(feature.tested, feature.test, 
                 "onUnselect called only once for feature (" + feature.index + ")");
        }
        
        // mock up first click on first feature (runs 2 tests from onSelect)
        var feature = features[0];
        feature.index = 0;
        feature.test = 1;
        control.clickFeature(feature);

        // mock up second click on first feature (runs no tests - already selected)
        control.toggle = false;
        control.clickFeature(feature);

        // mock up second click on first feature (runs 2 tests from onUnselect)
        control.toggle = true;
        feature.test = 2;
        control.clickFeature(feature);

        
    }
    
    function test_box(t) {
        t.plan(5);
        var map = new OpenLayers.Map("map");
        var layer = new OpenLayers.Layer.Vector();
        map.addLayer(layer);
        map.setBaseLayer(layer);
        map.setCenter(new OpenLayers.LonLat(1,1));
        var control = new OpenLayers.Control.SelectFeature(layer, {'multiple': true, box: true });
        var feature = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(0,0));
        var feature2 = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(1,1));
        var feature3 = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(-2,-2));
        var feature4 = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.LineString([
            new OpenLayers.Geometry.Point(0, 0), new OpenLayers.Geometry.Point(1, 1)
        ]));
        layer.addFeatures([feature, feature2, feature3, feature4]);
        control.setMap(map);
        map.getLonLatFromPixel = function(arg) {
            return new OpenLayers.LonLat(arg.x, arg.y);
        }    
        control.selectBox(new OpenLayers.Bounds(-1, -1, 2, 2));
        t.eq(layer.selectedFeatures.length, 3, "box around all features selects 3 features");
        
        control.selectBox(new OpenLayers.Bounds(-3, -3, -1, -1));
        t.eq(layer.selectedFeatures.length, 4, "box around other features doesn't turn off already selected features.");        
        
        control.multipleSelect = function() {
            return false;
        };
        control.selectBox(new OpenLayers.Bounds(-3, -3, -1, -1));
        t.eq(layer.selectedFeatures.length, 1, "box around other features correctly turns off already selected features.");
        
        control.geometryTypes = null;
        control.selectBox(new OpenLayers.Bounds(-100, -100, 100, 100));
        t.eq(layer.selectedFeatures.length, layer.features.length, "all features selected with no geometryTypes filter");
        
        control.geometryTypes = ["OpenLayers.Geometry.Point"];
        control.selectBox(new OpenLayers.Bounds(-100, -100, 100, 100));
        t.eq(layer.selectedFeatures.length, 3, "3 features selected with geometryTypes filter");
        

    }
    
    function test_Control_SelectFeature_activate(t) {
        t.plan(4);
        var map = new OpenLayers.Map("map");
        var layer = new OpenLayers.Layer.Vector();
        map.addLayer(layer);
        var control = new OpenLayers.Control.SelectFeature(layer, {box: true});
        map.addControl(control);
        t.ok(!control.handlers.feature.active,
             "feature handler is not active prior to activating control");
        t.ok(!control.handlers.box.active,
             "box handler is not active prior to activating control");
        control.activate();
        t.ok(control.handlers.feature.active,
             "feature handler is active after activating control");
        t.ok(control.handlers.box.active,
             "box handler is active after activating control");
    }

    function test_Control_SelectFeature_deactivate(t) {
        t.plan(2);
        var map = new OpenLayers.Map("map");
        var layer = new OpenLayers.Layer.Vector();
        map.addLayer(layer);
        var control = new OpenLayers.Control.SelectFeature(layer, {box: true});
        map.addControl(control);

        control.activate();
        control.handlers.feature.deactivate = function() {
            t.ok(true,
                 "control.deactivate calls deactivate on feature handler");
            OpenLayers.Handler.Feature.prototype.deactivate.apply(this, arguments);
        }
        control.handlers.box.deactivate = function() {
            t.ok(true,
                 "control.deactivate calls deactivate on box handler");
        }
        control.deactivate();
    }

    </script>
</head>
<body>
    <div id="map" style="width: 400px; height: 250px;"/>
</body>
</html>