cesium icon indicating copy to clipboard operation
cesium copied to clipboard

EntityCluster hasLabelIndex always returns false

Open OmarShehata opened this issue 6 years ago • 2 comments

This was reported on the forum with a suggested fix but I haven't had a chance to try it out and investigate it further so I'm documenting it here.

The Problem

This is the hasLabelIndex function in EntityCluster.js:

function hasLabelIndex(entityCluster, entityId) {
   return defined(entityCluster) && defined(entityCluster._collectionIndicesByEntity[entityId]) && defined(entityCluster._collectionIndicesByEntity[entityId].labelIndex);
}

The supplied entityId is an object, not a string, so defined(entityCluster._collectionIndicesByEntity[entityId]) will always be false.

Suggested Fix

I think the problem is that in addNonClusteredItem and getBoundingBox, it passes item.id as the entityId, but that's actually the entity itself. Instead, it should perhaps pass item.id.id.

It would be good to also write a test that would start out failing and is fixed after this is fixed.

How To Test

What I did to see that this was happening was launch the test suite on the EntityCluster class (using http://localhost:8080/Specs/SpecRunner.html?spec=DataSources%2FEntityCluster) and placing a console.log to see that it does indeed always return false, and passes an object instead of a string.

@hpinkos maybe we can label this "Good First Issue" ?

OmarShehata avatar Jan 02 '19 12:01 OmarShehata

Given we've had various issues with clustering, this sounds like something that should be fixed sooner rather than later. Do we understand how this bug manifests in actual clustering behavior?

mramato avatar Jan 02 '19 15:01 mramato

Based on the report in the forum thread, it causes labels to not be clustered. I haven't had a chance to confirm this however.

OmarShehata avatar Jan 02 '19 16:01 OmarShehata