Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

V2 batch operation cannot post attribute for custom pydantic object #369

Open
djs0109 opened this issue Jan 8, 2025 · 1 comment · May be fixed by #376
Open

V2 batch operation cannot post attribute for custom pydantic object #369

djs0109 opened this issue Jan 8, 2025 · 1 comment · May be fixed by #376
Assignees
Labels
bug Something isn't working

Comments

@djs0109
Copy link
Contributor

djs0109 commented Jan 8, 2025

Describe the bug
V2 batch operation update( )cannot post attributes when using custom pydantic object (For example inherited from the ContextEntity/ContextEntityKeyValues)

To Reproduce

from pydantic import BaseModel, ConfigDict
from pydantic.fields import FieldInfo, Field
from filip.clients.ngsi_v2 import ContextBrokerClient
from filip.models.base import FiwareHeader
from filip.utils.cleanup import clear_context_broker
from filip.models.ngsi_v2.context import ContextEntity, \
    ContextAttribute, ContextEntityKeyValues

fiware_header = FiwareHeader(service="test369", service_path="/")
cbc = ContextBrokerClient(url="http://134.130.166.184:1026",
                          fiware_header=fiware_header)
clear_context_broker(cb_client=cbc)

# Inherit from ContextEntity
class WeatherStation(ContextEntity):
    """
    A context specific model for a weather station
    """
    # add default for type if not explicitly set
    type: str = "WeatherStation"
    temperature: ContextAttribute = ContextAttribute(type="Number")
    humidity: ContextAttribute = ContextAttribute(type="Number")
    pressure: ContextAttribute = ContextAttribute(type="Number")

weather_station_list = [WeatherStation(id=f"test369:weather_station_{i}",
                                       temperature={"type": "Number", "value": 20+i},
                                       humidity={"type": "Number", "value": 50+i},
                                       pressure={"type": "Number", "value": 1000+i}
                                       ) for i in range(5)]

cbc.update(
    entities=weather_station_list,
    action_type="append")
entities = cbc.get_entity_list()

# assert entities does not have temperature, humidity, pressure
assert all([entity.model_dump().get("temperature") is not None for entity in entities])

cbc.update(
    entities=entities,
    action_type="delete")

# Inherit from ContextEntityKeyValues
class WeatherStationKeyValues(ContextEntityKeyValues):
    """
    https://brickschema.org/schema/Brick#Weather_Station
    """
    model_config = ConfigDict(coerce_numbers_to_str=True, extra="ignore")
    type: str = "WeatherStation"
    temperature: float = Field(
            default=20.0,
            description="brick:Quantity, measure temperature in degree Celsius"
        )

weather_station_list_keyvalues = [WeatherStationKeyValues(
    id=f"test369_kv:weather_station_{i}",
    temperature=20+i) for i in range(5)]
cbc.update(
    entities=weather_station_list_keyvalues,
    update_format="keyValues",
    action_type="append")
entities = cbc.get_entity_list()
assert all([entity.model_dump().get("temperature") is not None for entity in entities])

To Fix
Add SerializeAsAny annotation to the entities. Otherwise update.model_dump() will only serialize the object based on the schema, i.e., the ContextEntity or ContextEntityKeyValues. Therefore, only predefined attribute will be serialized, such as id and type.

class Update(BaseModel):
    """
    Model for update action
    """

    action_type: Union[ActionType, str] = Field(
        alias="actionType",
        description="actionType, to specify the kind of update action to do: "
        "either append, appendStrict, update, delete, or replace. ",
    )
    entities: SerializeAsAny[List[Union[ContextEntity, ContextEntityKeyValues]]] = Field(
        description="an array of entities, each entity specified using the "
        "JSON entity representation format "
    )
@djs0109 djs0109 added the bug Something isn't working label Jan 8, 2025
@djs0109 djs0109 self-assigned this Jan 21, 2025
Copy link

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant